# VSC7415 Datasheet 6-Port SGMII Gigabit Ethernet Switch with VeriTime™ and Integrated DPLL and Gigabit Ethernet PHYs a MICROCHIP company #### Microsemi Headquarters One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 Email: sales.support@microsemi.com www.microsemi.com ©2019 Microsemi, a wholly owned ©2019 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice. #### **About Microsemi** Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com. # **Contents** | 1 | Revisi | on Hist | tory | . 1 | |---|--------|----------------|-------------------------------------------------------------|-----| | | 1.1 | Revision | n 4.1 | . 1 | | | 1.2 | Revision | n 4.0 | . 1 | | | | | | | | 2 | Produ | ct Ove | rview | 2 | | | 2.1 | General | Features | . 2 | | | | 2.1.1 | Layer 2 and Layer 3 Forwarding | | | | | 2.1.2 | Timing and Synchronization | | | | | 2.1.3 | Quality of Service | . 3 | | | | 2.1.4 | Security | . 3 | | | | 2.1.5 | Management | | | | | 2.1.6 | Product Parameters | | | | 2.2 | Applicat | ions | | | | | 2.2.1 | Wireless Backhaul | | | | | 2.2.2 | Small Cell Application | . 7 | | 3 | Eupoti | onal D | operintions | C | | 3 | | | escriptions | | | | 3.1 | • | Notations | | | | 3.2 | | nal Overview | | | | | 3.2.1 | Frame Arrival in Ports and Port Modules | | | | | 3.2.2 | Basic Classification | | | | | 3.2.3<br>3.2.4 | Security and Control Protocol Classification | | | | | 3.2.4 | Layer 2 Forwarding | | | | | 3.2.6 | Layer 3 Forwarding | | | | | 3.2.7 | Shared Queue System and Hierarchical Scheduler | | | | | 3.2.8 | Rewriter and Frame Departure | | | | | 3.2.9 | CPU Port Module | | | | | 3.2.10 | Synchronous Ethernet and Precision Time Protocol (PTP) | | | | | 3.2.11 | CPU Subsystem | 17 | | | 3.3 | Frame F | Headers | | | | | 3.3.1 | Internal Frame Header Placement | | | | | 3.3.2 | Internal Frame Header Layout | | | | | 3.3.3 | VStaX Header | | | | 3.4 | | mbering and Mappings | | | | | 3.4.1 | Supported SerDes Interfaces | | | | | 3.4.2<br>3.4.3 | Dual-Media Mode | | | | 2.5 | SERDE: | | | | | 3.5 | | | | | | 3.6 | | S6G | | | | 3.7 | | Transceivers | | | | | 3.7.1<br>3.7.2 | Register Access | | | | | 3.7.2 | Cat5 Twisted Pair Media Interface Wake-On-LAN and SecureOn | | | | | 3.7.4 | Ethernet Inline Powered Devices | | | | | 3.7.5 | IEEE 802.3af PoE Support | | | | | 3.7.6 | ActiPHY™ Power Management | | | | | 3.7.7 | Testing Features | | | | | 3.7.8 | VeriPHY™ Cable Diagnostics | | | | 3.8 | DEV1G | and DEV2G5 Port Modules | 36 | | | | 3.8.1 | MAC | | | | 3.8.2<br>3.8.3<br>3.8.4 | Half-Duplex Mode Physical Coding Sublayer (PCS) Port Statistics | . 41 | |-------|-------------------------|-----------------------------------------------------------------|------| | 3.9 | | ler | | | 3.9 | 3.9.1 | Setting Up a Port in the Assembler | | | | 3.9.2 | Setting Up a Port for Frame Injection | | | | 3.9.3 | Setting Up MAC Control Sublayer PAUSE Frame Detection | | | | 3.9.4 | Setting Up PFC | | | | 3.9.5 | Setting Up Assembler Port Statistics | | | | 3.9.6 | Setting Up the Loopback Path | . 48 | | 3.10 | Versatile | e Content-Aware Processor (VCAP) | | | | 3.10.1 | Configuring VCAP | | | | 3.10.2 | Wide VCAP Entries and Actions | | | | 3.10.3 | Individual VCAPs | | | | 3.10.4 | VCAP Programming Examples | | | 3.11 | | Points | | | 0.40 | 3.11.1 | Pipeline Definitions | | | 3.12 | - | r | | | 0.40 | 3.12.1 | Initializing the Analyzer | | | 3.13 | 3.13.1 | LM Keys and Actions | | | | 3.13.1 | VCAP CLM X1 Key Details | | | | 3.13.2 | VCAP CLM X1 Key Details | | | | 3.13.4 | VCAP CLM X4 Key Details | | | | 3.13.5 | VCAP CLM X8 Key Details | | | | 3.13.6 | VCAP CLM X16 Key Details | . 82 | | | 3.13.7 | VCAP CLM Actions | . 87 | | 3.14 | Analyze | r Classifier | | | | 3.14.1 | Basic Classifier | | | | 3.14.2 | VCAP CLM Processing | | | | 3.14.3<br>3.14.4 | QoS Mapping Table | | | 0.45 | | Analyzer Classifier Diagnostics | | | 3.15 | 3.15.1 | nd MSTP | | | | 3.15.1 | VLAN Pseudo Code | | | 3.16 | | PM: Keys and Action | | | 3.10 | 3.16.1 | VCAP LPM SGL_IP4 Key Details | | | | 3.16.2 | VCAP LPM DBL IP4 Key Details | | | | 3.16.3 | VCAP LPM SGL IP6 Key Details | | | | 3.16.4 | VCAP LPM DBL_IP6 Key Details | 127 | | | 3.16.5 | VCAP LPM Actions | 127 | | 3.17 | IP Proce | essing | 129 | | | 3.17.1 | IP Source/Destination Guard | | | | 3.17.2 | IP Routing | | | | 3.17.3 | Statistics | | | 0.40 | 3.17.4 | IGMP/MLD Snooping Switch | | | 3.18 | 3.18.1 | S2 Keys and Actions | | | | 3.18.2 | VCAP IS2 Keys | | | 3.19 | | r Access Control Lists | | | J. 13 | 3.19.1 | VCAP IS2 | | | | 3.19.2 | Analyzer Access Control List Frame Rewriting | | | 3.20 | | r Layer 2 Forwarding and Learning | | | | 3.20.1 | Analyzer MAC Table | | | | 3.20.2 | MAC Table Updates | | | | 3.20.3 | CPU Access to MAC Table | 167 | | | | IVIICI | USCIII | 1 | |---|---|----------|-----------|---| | 3 | M | Місвосні | p company | | | | SCAN Command | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3.20.5 | Forwarding Lookups | | | 3.20.6 | Source Check and Automated Learning | . 175 | | 3.20.7 | Automated Aging (AUTOAGE) | . 178 | | 3.20.8 | Interrupt Handling | . 179 | | Analyze | r Access Control Forwarding, Policing, and Statistics | . 180 | | | | | | | | | | | | | | - | | | | | | | | | <del>-</del> | | | | | | | | | | | | | | | | · · · · · · · · · · · · · · · · · · · | | | | | | | - | | | | | | | | | | | | - | • | | | 3.22.9 | Miscellaneous Features | . 225 | | Automat | iic Frame Injector | . 228 | | 3.23.1 | Injection Tables | . 229 | | 3.23.2 | Frame Table | . 230 | | 3.23.3 | Delay Triggered Injection | . 231 | | 3.23.4 | | | | 3.23.5 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3.24.2 | Supported Ports | $\sim 4$ | | 0 0 4 0 | 0 115 5 1 | | | 3.24.3 | Supported Frame Formats | . 243 | | 3.24.4 | Rewriter Initialization | . 243<br>. 243 | | 3.24.4<br>3.24.5 | Rewriter Initialization | . 243<br>. 243<br>. 243 | | 3.24.4<br>3.24.5<br>3.24.6 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables | . 243<br>. 243<br>. 243 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing | . 243<br>. 243<br>. 243<br>. 255 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking | . 243<br>. 243<br>. 243<br>. 255<br>. 256 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion | . 243<br>. 243<br>. 255<br>. 256<br>. 262 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 263 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 266 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 267<br>. 268 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 266<br>. 267 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 266<br>. 268<br>. 268<br>. 268 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3 | Rewriter Initialization VCAP_ESO Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 266<br>. 267<br>. 268<br>. 268 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3<br>3.25.4 | Rewriter Initialization VCAP_ESO Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function Setting up Flow Control in Half-Duplex Mode | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 262<br>. 265<br>. 265<br>. 265<br>. 266<br>. 266<br>. 268<br>. 268<br>. 268<br>. 268<br>. 269<br>. 269<br>. 270 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3<br>3.25.4<br>3.25.5 | Rewriter Initialization VCAP_ESO Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function Setting up Flow Control in Half-Duplex Mode Setting Up Frame Aging | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 262<br>. 265<br>. 265<br>. 266<br>. 266<br>. 268<br>. 268<br>. 268<br>. 269<br>. 270<br>. 270 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3<br>3.25.4<br>3.25.5<br>3.25.6 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function Setting Up Frame Aging Setting Up Transmit Data Rate Limiting | . 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 266<br>. 266<br>. 268<br>. 268<br>. 269<br>. 270<br>. 270<br>. 271 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.9<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3<br>3.25.4<br>3.25.5<br>3.25.6<br>3.25.6<br>3.25.7 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function Setting Up Frame Aging Setting Up Transmit Data Rate Limiting Error Detection | . 243<br>. 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 265<br>. 266<br>. 267<br>. 268<br>. 269<br>. 270<br>. 271<br>. 273 | | 3.24.4<br>3.24.5<br>3.24.6<br>3.24.7<br>3.24.8<br>3.24.10<br>3.24.11<br>3.24.12<br>3.24.13<br>3.24.14<br>Disasse<br>3.25.1<br>3.25.2<br>3.25.3<br>3.25.4<br>3.25.5<br>3.25.6<br>3.25.7<br>Layer 1 | Rewriter Initialization VCAP_ES0 Lookup Mapping Tables VLAN Editing DSCP Remarking VStaX Header Insertion Forwarding to GCPU Layer 3 Routing Mirror Frames Internal Frame Header Insertion Frame Injection from Internal CPU mbler Setting Up Ports Maintaining the Cell Buffer Setting Up MAC Control Sublayer PAUSE Function Setting Up Frame Aging Setting Up Transmit Data Rate Limiting | . 243<br>. 243<br>. 243<br>. 255<br>. 256<br>. 262<br>. 263<br>. 265<br>. 266<br>. 267<br>. 268<br>. 268<br>. 269<br>. 270<br>. 271<br>. 273<br>. 273 | | | 3.20.8<br>Analyze<br>3.21.1<br>3.21.2<br>3.21.3<br>3.21.4<br>3.21.5<br>Shared (3.22.1<br>3.22.2<br>3.22.3<br>3.22.4<br>3.22.5<br>3.22.6<br>3.22.7<br>3.22.8<br>3.22.9<br>Automat<br>3.23.1<br>3.23.2<br>3.23.3<br>3.23.4<br>3.23.5<br>3.23.6<br>3.23.7<br>3.23.8<br>3.23.9<br>3.23.10 | 3.20.8 Interrupt Handling Analyzer Access Control Forwarding, Policing, and Statistics 3.21.1 Mask Handling 3.21.2 Policing 3.21.3 Analyzer Statistics 3.21.4 Analyzer statistics 3.21.5 Mirroring Shared Queue System and Hierarchical Scheduler 3.22.1 Analyzer Result 3.22.2 Buffer Control 3.22.3 Forwarding 3.22.4 Congestion Control 3.22.5 Queue Mapping 3.22.6 Queue Congestion Control 3.22.7 Scheduling 3.22.8 Queue System Initialization 3.22.9 Miscellaneous Features Automatic Frame Injector 3.23.1 Injection Tables 3.23.2 Frame Table 3.23.3 Delay Triggered Injection 3.23.4 Timer Triggered Injection 3.23.5 Injection Queues 3.23.6 Adding Injection Frame 3.23.7 Starting Injection 3.23.8 Stopping Injection 3.23.9 Removing Injection Frames 3.23.10 Port Parameters Rewriter 3.24.1 Rewriter Operation | | 278 | |-----| | 279 | | 280 | | 280 | | 281 | | 281 | | 282 | | 282 | | 284 | | 284 | | 285 | | 287 | | 288 | | 288 | | 290 | | 291 | | 293 | | 293 | | 294 | | 294 | | 294 | | 295 | | 295 | | 296 | | 296 | | 296 | | 298 | | 298 | | 298 | | 299 | | 299 | | 299 | | 299 | | 301 | | 301 | | 301 | | 304 | | 304 | | 305 | | 305 | | 306 | | 306 | | 306 | | | | 308 | | 309 | | | | | | | | | | | | | | | | | | | | | | | 4 | | 4.4.2 | Software Debug and Development | 4 | |--------|---------|-------------------------------------------|---| | 4.5 | Externa | I CPU Support | 4 | | | 4.5.1 | Register Access and Multimaster Systems | 5 | | | 4.5.2 | Serial Interface in Slave Mode | | | | 4.5.3 | MIIM Interface in Slave Mode | | | | 4.5.4 | Access to the VCore Shared Bus | | | | 4.5.5 | Mailbox and Semaphores | | | 4.0 | | · | | | 4.6 | | ndpoint Controller | | | | 4.6.1 | Accessing Endpoint Registers | | | | 4.6.2 | Enabling the Endpoint | | | | 4.6.3 | Base Address Registers Inbound Requests | | | | 4.6.4 | Outbound Interrupts | | | | 4.6.5 | Outbound Access | 5 | | | 4.6.6 | Power Management | 6 | | | 4.6.7 | Device Reset Using PCIe | 7 | | 4.7 | Frame [ | DMA 32 | 8 | | | 4.7.1 | DMA Control Block Structures | | | | 4.7.2 | Enabling and Disabling FDMA Channels | | | | 4.7.3 | Channel Counters | | | | 4.7.4 | FDMA Events and Interrupts | | | | 4.7.5 | <u>.</u> | | | | _ | FDMA Extraction | | | | 4.7.6 | FDMA Injection | | | | 4.7.7 | Manual Mode | | | 4.8 | VCore-I | II System Peripherals | | | | 4.8.1 | SI Boot Controller | 6 | | | 4.8.2 | SI Master Controller | 8 | | | 4.8.3 | DDR3/DDR3L Memory Controller | 3 | | | 4.8.4 | Timers | 8 | | | 4.8.5 | UARTs | 9 | | | 4.8.6 | Two-Wire Serial Interface | | | | 4.8.7 | MII Management Controller | | | | 4.8.8 | GPIO Controller | | | | 4.8.9 | Serial GPIO Controller | | | | 4.8.10 | Fan Controller | | | | 4.8.11 | Temperature Sensor | | | | 4.8.12 | Memory Integrity Monitor | | | | 4.8.13 | | | | | 4.0.13 | Interrupt Controller | 1 | | Domio | toro | 279 | 2 | | Regis | ters | 373 | ) | | | | | | | Electr | ical Sp | ecifications | 4 | | 6.1 | DC Cha | racteristics | 4 | | | 6.1.1 | Reference Clock | | | | 6.1.2 | PLL Clock Output | | | | 6.1.3 | DPLL Clocks | | | | 6.1.4 | DDR3/DDR3L SDRAM Interface | | | | 6.1.5 | SERDES1G | | | | 6.1.6 | SERDES6G | | | | | GPIO, SI, JTAG, and Miscellaneous Signals | | | | 6.1.7 | • • • • | | | | 6.1.8 | Thermal Diode | | | 6.2 | | racteristics | | | | 6.2.1 | Reference Clock | | | | 6.2.2 | PLL Clock Outputs | 1 | | | 6.2.3 | DPLL Clocks | 2 | | | 6.2.4 | Jitter Transfer 38 | 3 | | | 6.2.5 | SERDES1G | 3 | | | 6.2.6 | SERDES6G | 4 | 5 6 | | | 6.2.7<br>6.2.8 | Reset Timing | | |---|--------|------------------|-------------------------------------------|------------| | | | 6.2.9 | Serial Interface (SI) Boot Master Mode | | | | | 6.2.10 | Serial Interface (SI) Master Mode | | | | | 6.2.11 | Serial Interface (SI) for Slave Mode | | | | | 6.2.12 | DDR SDRAM Interface | | | | | 6.2.13 | JTAG Interface | | | | | 6.2.14 | Serial Inputs/Outputs | | | | | 6.2.15 | Recovered Clock Outputs | | | | | 6.2.16 | Two-Wire Serial Interface | | | | 0.0 | 6.2.17 | IEEE 1588 Time Tick Outputs | | | | 6.3 | | and Power Consumption | | | | | 6.3.1<br>6.3.2 | Current Consumption | | | | | 6.3.3 | Power Supply Sequencing | | | | 6.4 | | ng Conditions | | | | 6.5 | - | | | | | 0.5 | Stress F | Ratings | . 400 | | 7 | Pin De | escripti | ons | 401 | | | 7.1 | | gram | | | | 7.1 | - | Function | | | | 1.2 | 7.2.1 | DDR SDRAM Interface | | | | | 7.2.1 | DPLL Clock | | | | | 7.2.3 | General-Purpose Inputs and Outputs | | | | | 7.2.4 | JTAG Interface | | | | | 7.2.5 | MII Management Interface | | | | | 7.2.6 | Miscellaneous | . 405 | | | | 7.2.7 | PCI Express Interface | | | | | 7.2.8 | Power Supplies and Ground | | | | | 7.2.9 | SERDES1G | | | | | 7.2.10 | SERDES6G | | | | | 7.2.11 | Serial CPU Interface | | | | | 7.2.12<br>7.2.13 | System Clock Interface | | | | 7.3 | _ | Number | | | | | • | | | | | 7.4 | Pins by | Name | . 413 | | 8 | Packa | ae Info | ormation | 416 | | • | | • | | | | | 8.1 | • | e Drawing | | | | 8.2 | | I Specifications | | | | 8.3 | Moisture | e Sensitivity | . 418 | | 9 | Design | n Guide | elines | <b>410</b> | | J | _ | | | | | | 9.1 | | Supplies | | | | 9.2 | | Supply Decoupling | | | | | 9.2.1<br>9.2.2 | Reference Clock Single-Ended REFCLK Input | | | | 0.3 | | | | | | 9.3 | 9.3.1 | es | | | | | 9.3.1 | SerDes Interfaces (SGMII, 2.5G) | | | | | 9.3.3 | Serial Interface | | | | | 9.3.4 | PCI Express Interface | | | | | 9.3.5 | Two-Wire Serial Interface | | | | | 9.3.6 | DDR3 SDRAM Interface | . 422 | | | | 9.3.7 | Thermal Diode External Connection | . 423 | | | | • | | 12.00 | | | | |----|-----------------------|---|------|-------|--|--------|---| | 10 | Design Considerations | | <br> | | | <br>42 | 5 | | 11 | Ordering Information | | <br> | | | <br>42 | 6 | # **Figures** | Figure 1 | Wireless Backhaul Application | 6 | |-----------|---------------------------------------------------------------------|-------| | Figure 2 | 4G/LTE Small Cell Application | 7 | | Figure 3 | RTL Block Diagram | | | Figure 4 | Block Diagram | | | Figure 5 | Default Scheduler-Shaper Configuration | | | Figure 6 | Frame with Internal Frame Header | | | Figure 7 | Internal Frame Header | | | Figure 8 | Frame With VStaX Header | | | Figure 9 | VStaX Header Layout | | | Figure 10 | Register Space Layout | | | Figure 11 | Cat5 Media Interface | | | Figure 12 | Low Power Idle Operation | | | Figure 13 | Wake-On-LAN Functionality | | | Figure 14 | Inline Powered Ethernet Switch | | | Figure 15 | ActiPHY State Diagram | | | | · · · · · · · · · · · · · · · · · · · | | | Figure 16 | Far-End Loopback Diagram | | | Figure 17 | Near-End Loopback Diagram | | | Figure 18 | Connector Loopback Diagram | | | Figure 19 | Frame Injection Formats | | | Figure 20 | VCAP Cache Layout Example | | | Figure 21 | VCAP Cache Type-Group Example | | | Figure 22 | Processing Flow | | | Figure 23 | VLAN Acceptance Filter | | | Figure 24 | Basic QoS Classification Flow Chart | | | Figure 25 | Basic DP Classification Flow Chart | | | Figure 26 | Basic DSCP Classification Flow Chart | | | Figure 27 | Basic VLAN Classification Flow Chart | . 107 | | Figure 28 | Example of QoS Mappings | . 119 | | Figure 29 | VLAN Table Update Engine (TUPE) | | | Figure 30 | Router Model | | | Figure 31 | Unicast Routing Table Overview | | | Figure 32 | Multicast Routing Table Overview | | | Figure 33 | Ingress Router Leg Lookup Flow | | | Figure 34 | Ingress Router Leg MAC Address Matching for Unicast Packets | | | Figure 35 | IP Unicast Routing Example | | | Figure 36 | ARP Pointer Remapping | | | Figure 37 | IP Multicast Routing Example | | | Figure 38 | MAC Table Organization | | | Figure 39 | DMAC Lookup | | | Figure 40 | Source Check | | | Figure 41 | PGID Layout | | | Figure 41 | PGID Lookup Decision Forwarding | | | • | · | | | Figure 43 | GLAG Port of Exit Calculation | | | Figure 44 | Port Mask Operation | | | Figure 45 | Policer Hierarchy | | | Figure 46 | Sticky Events Available as Global Events | | | Figure 47 | Port Statistics Counters | | | Figure 48 | Queue Statistics | | | Figure 49 | BUM Policer Statistics | | | Figure 50 | ACL Policer Statistics | | | Figure 51 | Ingress and Egress Routing Statistics per Router Leg per IP Version | | | Figure 52 | sFlow Stamp Format in FCS | | | Figure 53 | Ingress Mirroring in Specific VLAN | | | Figure 54 | Shared Queue System Block Diagram | . 205 | | Figure 55 | Translation of Transmit Requests | 200 | |------------|--------------------------------------------------|-----| | | | | | Figure 56 | Accounting Sheet Example | | | Figure 57 | Reserved and Shared Resource Overview | | | Figure 58 | Strict Priority Sharing | | | Figure 59 | Per Priority Sharing | | | Figure 60 | WRED Sharing | 213 | | Figure 61 | WRED Profiles | 214 | | Figure 62 | Scheduler Hierarchy (Normal Scheduling Mode) | | | Figure 63 | Queue Mapping Tables | | | Figure 64 | Group Scheduling Mode | | | Figure 65 | Mobile Backhaul Mode | | | Figure 66 | Drop Decision Flow | | | • | | | | Figure 67 | Queue Limitation Share | | | Figure 68 | Default Scheduling Hierarchy | | | Figure 69 | Scheduler | | | Figure 70 | Internal Bus | | | Figure 71 | Injection Tables | 230 | | Figure 72 | DTI Frame/Delay Sequence Example | 232 | | Figure 73 | Fine Tuning Bandwidth of DTI Sequence | 232 | | Figure 74 | Fine Tuning Bandwidth of Multiframe DTI Sequence | | | Figure 75 | DTI Frame/Delay Sequence Using Inject Forever | | | Figure 76 | DTI Concatenation | | | Figure 77 | TTI Calendar Example | | | • | AFI TUPE | | | Figure 78 | | | | Figure 79 | Frame Forward Options | | | Figure 80 | Mapping Tables | | | Figure 81 | VLAN Pushing | | | Figure 82 | VLAN Tag Construction | | | Figure 83 | Supported KEEP_IFH_SEL Formats | | | Figure 84 | Supported Time Stamping Flows | 276 | | Figure 85 | Frame Flow | 277 | | Figure 86 | Time Stamp Bus and FIFO | 280 | | Figure 87 | Timing Distribution | | | Figure 88 | SyncE Controller | | | Figure 89 | Guard Soak Timing | | | Figure 90 | EEC State Machine | | | Figure 91 | VRAP Request Frame Format | | | | | | | Figure 92 | VRAP Header Format | | | Figure 93 | READ Command | | | Figure 94 | WRITE Command | | | Figure 95 | READ-MODIFY-WRITE Command | | | Figure 96 | IDLE Command | 296 | | Figure 97 | PAUSE Command | 296 | | Figure 98 | EEE State Diagram | 297 | | Figure 99 | PFC Generation Per Port | 300 | | Figure 100 | Ethernet Ring Protection Example | | | Figure 101 | Ethernet Ring with Failure | | | Figure 102 | VCore-III System Block Diagram | | | Figure 103 | Shared Bus Memory Map | | | Figure 103 | Chip Registers Memory Map | | | - | | | | Figure 105 | SI Slave Mode Register | | | Figure 106 | Write Sequence for SI | | | Figure 107 | Read Sequence for SI_CLK Slow | | | Figure 108 | Read Sequence for SI_CLK Pause | | | Figure 109 | Read Sequence for One-Byte Padding | | | Figure 110 | MIIM Slave Write Sequence | | | Figure 111 | MIIM Slave Read Sequence | 319 | | Figure 112 | FDMA DCB Layout | 330 | | Figure 113 | FDMA Channel States | | | Figure 114 | FDMA Channel Interrupt Hierarchy | 333 | |------------|-----------------------------------------------------------|-----| | Figure 115 | Extraction Status Word Encoding | | | Figure 116 | Injection Status Word Encoding | | | Figure 117 | SI Boot Controller Memory Map in 24-Bit Mode | | | Figure 118 | SI Boot Controller Memory Map in 32-Bit Mode | | | Figure 119 | SI Read Timing in Normal Mode | | | Figure 120 | SI Read Timing in Fast Mode | | | Figure 121 | SIMC SPI Clock Configurations | | | Figure 122 | SIMC SPI 3x Transfers | | | Figure 123 | Memory Controller ODT Hookup | 346 | | Figure 124 | UART Timing | | | Figure 125 | Two-Wire Serial Interface Timing for 7-bit Address Access | | | Figure 126 | MII Management Timing | 354 | | Figure 127 | SIO Timing | | | Figure 128 | SIO Timing with SGPIOs Disabled | | | Figure 129 | SGPIO Output Order | | | Figure 130 | Link Activity Timing | | | Figure 131 | Monitor State Diagram | | | Figure 132 | Memory Detection Logic | | | Figure 133 | Interrupt Source Logic | 370 | | Figure 134 | Interrupt Destination Logic | 371 | | Figure 135 | Port Module Interrupt Logic | | | Figure 136 | Thermal Diode | | | Figure 137 | REFCLK/REFCLK2 Jitter Transfer Curves | 381 | | Figure 138 | nRESET Signal Timing Specifications | 387 | | Figure 139 | MIIM Timing Diagram | | | Figure 140 | SI Timing Diagram for Master Mode | 389 | | Figure 141 | SI Input Data Timing Diagram for Slave Mode | 390 | | Figure 142 | SI Output Data Timing Diagram for Slave Mode | 390 | | Figure 143 | SI_DO Disable Test Circuit | 391 | | Figure 144 | DDR SDRAM Input Timing Diagram | 391 | | Figure 145 | DDR SDRAM Output Timing Diagram | 392 | | Figure 146 | Test Load Circuit for DDR3 Outputs | 393 | | Figure 147 | JTAG Interface Timing Diagram | | | Figure 148 | Test Circuit for TDO Disable Time | 394 | | Figure 149 | Serial I/O Timing Diagram | | | Figure 150 | Test Circuit for Recovered Clock Output Signals | 396 | | Figure 151 | Two-Wire Serial Read Timing Diagram | 396 | | Figure 152 | Two-Wire Serial Write Timing Diagram | 397 | | Figure 153 | Pin Diagram, Top Left | | | Figure 154 | Pin Diagram, Top Right | | | Figure 155 | Package Drawing | | | Figure 156 | 2.5 V CMOS Single-Ended REFCLK Input Resistor Network | | | Figure 157 | 3.3 V CMOS Single-Ended REFCLK Input Resistor Network | | | Figure 158 | 16-Bit DDR3 SDRAM Point-to-Point Routing | | | Figure 159 | External Temperature Monitor Connection | 424 | # **Tables** | Table 1 | Product Parameters | . 3 | |----------|--------------------------------------------------------------|-----| | Table 2 | Internal Frame Header Fields | 19 | | Table 3 | VStaX Header Fields | 26 | | Table 4 | Default Port Numbering and Port Mappings | 28 | | Table 5 | Interface Macro to I/O Pin Mapping | | | Table 6 | Supported SerDes Interfaces | 29 | | Table 7 | Supported MDI Pair Combinations | | | Table 8 | DEV1G and DEV2G5 MAC Configuration Registers Overview | | | Table 9 | DEV1G and DEV2G5 Reset | | | Table 10 | DEV1G and DEV2G5 Interrupt Sources Register Overview | | | Table 11 | DEV1G and DEV2G5 Port Mode Configuration Registers Overview | | | Table 12 | DEV1G and DEV2G5 PCS Configuration Registers Overview | | | Table 13 | DEV1G and DEV2G5 PCS Test Pattern Configuration Registers | | | Table 14 | DEV1G and DEV2G5 PCS EEE Configuration Registers Overview | | | Table 15 | DEV1G and DEV2G5 100BASE-FX Configuration Registers Overview | | | Table 16 | Port Configuration Register Overview | | | Table 17 | Port Status Register Overview | | | Table 18 | Injection VLAN Register Overview | | | Table 19 | PAUSE Frame Detection Configuration Register Overview | | | Table 20 | PFC Configuration Register Overview | 17 | | Table 21 | Port Statistics Configuration Register Overview | 47 | | Table 22 | Loopback FIFO Configuration Register Overview | | | Table 23 | Loopback FIFO Sticky-Bit Registers Overview | | | Table 23 | VCAP_ES0 and VCAP_SUPER Registers | | | Table 25 | | | | | Entry Bit Encoding | | | Table 26 | VCAP CLM Parameters | | | Table 27 | VCAP CLM Entry Type-Group Fields | | | Table 28 | VCAP CLM Action Type-Group Fields | | | Table 29 | VCAP CLM Entry/Action Bit Distribution | 55 | | Table 30 | VCAP CLM Default Rule Addresses | | | Table 31 | VCAP IS2 Parameters | | | Table 32 | VCAP IS2 Entry Type-Group Fields | | | Table 33 | VCAP IS2 Entry/Action Bit Distribution | | | Table 34 | VCAP LPM Parameters | | | Table 35 | VCAP LPM Entry Type-Group Fields | 5/ | | Table 36 | VCAP LPM Entry/Action Bit Distribution | | | Table 37 | VCAP ES0 Parameters | | | Table 38 | VCAP ES0 Entry/Action Bit Distribution | | | Table 39 | CLM X2 Entry Type-Group and Distribution Summary | | | Table 40 | CLM X4 Action Type-Group and Distribution Summary | | | Table 41 | Pipeline Definitions | | | Table 42 | Pipeline Actions | | | Table 43 | VCAP CLM Keys and Sizes | | | Table 44 | VCAP CLM Key Overview | | | Table 45 | VCAP CLM X1 Key Details | | | Table 46 | VCAP CLM X2 Key Details | | | Table 47 | VCAP CLM X4 Key Details | | | Table 48 | VCAP CLM X8 Key Details | | | Table 49 | VCAP CLM X16 Key Details | | | Table 50 | VCAP CLM Action Selection | | | Table 51 | VCAP CLM Actions | | | Table 52 | VLAN Tag Extraction Register | | | Table 53 | Routing Tag Control Register | | | Table 54 | Frame Acceptance Filtering Registers | 100 | | Table 55 | QoS, DP, and DSCP Classification Registers | | |----------------------|---------------------------------------------------------|-----| | Table 56 | VLAN Configuration Registers | | | Table 57 | Aggregation Code Generation Registers | | | Table 58 | CPU Forwarding Registers | | | Table 59 | Frame Type Definitions for CPU Forwarding | | | Table 60 | Port Configuration of VCAP CLM | | | Table 61 | Miscellaneous VCAP CLM Key Configuration | | | Table 62 | VCAP CLM Range Checker Configuration Registers Overview | | | Table 63 | VCAP CLM QoS Mapping Table Registers Overview | | | Table 64<br>Table 65 | MSTP Table (66 Entries) | | | Table 65 | Common VLAN and MSTP Parameters | | | Table 67 | VLAN Table Update Engine (TUPE) Parameters | | | Table 68 | VCAP LPM Key and Sizes | | | Table 69 | VCAP LPM Key Overview | | | Table 70 | VCAP LPM SGL_IP4 Key Details | | | Table 71 | VCAP LPM DBL_IP4 Key Details | | | Table 72 | VCAP LPM SGL_IP6 Key Details | | | Table 73 | VCAP LPM DBL IP6 Key Details | | | Table 74 | VCAP LPM Action Selection | | | Table 75 | VCAP LPM Actions | | | Table 76 | CPU Queue Overview | | | Table 77 | Ingress Router Leg Events | | | Table 78 | Ingress Router Leg Statistics Example | | | Table 79 | Egress Router Leg Events | | | Table 80 | Egress Router Leg Statistics Example | | | Table 81 | VCAP IS2 Keys and Sizes | | | Table 82 | VCAP IS2 Key Overview | | | Table 83 | VCAP IS2 Actions | | | Table 84 | VCAP IS2 Frame Types | | | Table 85 | Port Configuration of VCAP IS2 | | | Table 86 | VCAP IS2 Key Selection | | | Table 87 | VCAP IS2 Range Checker Configuration | | | Table 88 | Other VCAP IS2 Key Configurations | | | Table 89 | Combining VCAP IS2 Actions | | | Table 90 | VCAP IS2 Statistics and Diagnostics | | | Table 91 | ANA_ACL Address Swapping and Rewriting Registers | | | Table 92 | ANA_ACL Routing Registers | | | Table 93 | ANA_ACL PTP Processing and Rewriting Registers | | | Table 94 | MAC Table Entry | | | Table 95 | MAC Table Access Registers | | | Table 96 | MAC Table Access Commands | 169 | | Table 97 | Scan Filters | 172 | | Table 98 | Scan Modification Actions | 172 | | Table 99 | Forwarding Registers | 173 | | Table 100 | Hardware-Based Learning | 175 | | Table 101 | Automated Age Scan Registers Overview | 178 | | Table 102 | Analyzer Interrupt Handling Registers Overview | 179 | | Table 103 | PGID Registers Overview | | | Table 104 | Source Table Registers Overview | | | Table 105 | Aggregation Table Registers Overview | | | Table 106 | GLAG Forward Registers Overview | | | Table 107 | Policer Control Registers Overview | | | Table 108 | Service and Bundle Dual Leaky Bucket Table Entries | | | Table 109 | BUM Single Leaky Bucket Table Entries | | | Table 110 | ACL Policer Table Entries | | | Table 111 | Priority Policer Table Entry | | | Table 112 | Port Policer Table Entry | | | Table 113 | Storm Policer Table Entry | 193 | | Table 114 | Analyzer Port Statistics Register Overview | 194 | |-----------|----------------------------------------------------|-------| | Table 115 | Queue Statistics Registers Overview | | | | | | | Table 116 | BUM Policer Statistics Registers Overview | | | Table 117 | ACL Policer Statistics Registers Overview | | | Table 118 | Analyzer Routing Statistics Registers Overview | | | Table 119 | Analyzer sFlow Registers Overview | | | Table 120 | ANA_AC Mirror Registers Overview | | | Table 121 | Port Definitions in Shared Queue System | | | Table 122 | Ingress Port Modes | | | Table 123 | Analyzer Result | . 206 | | Table 124 | Buffer Control Registers Overview | . 207 | | Table 125 | Buffer Status Registers Overview | . 207 | | Table 126 | Statistics Modes | | | Table 127 | Forward Pressure Configuration Registers Overview | . 208 | | Table 128 | Analyzer Destination Selection | | | Table 129 | Frame Forwarder Registers Overview | . 209 | | Table 130 | Analyzer Congestion Results | | | Table 131 | Strict Priority Sharing Configuration Settings | | | Table 132 | Per Priority Sharing Configuration Settings | | | Table 133 | WRED Sharing Configuration | | | Table 134 | Threshold Configuration Overview | | | Table 134 | Congestion Control Registers Overview | | | Table 135 | | | | | Frame Forwarder Monitoring Registers Overview | | | Table 137 | Queue Mapping Registers Overview | | | Table 138 | Queue Limitation Conditions | | | Table 139 | Queue Limitation Registers | | | Table 140 | Shaper Registers Overview | | | Table 141 | Scheduler Arbitration Registers Overview | | | Table 142 | Miscellaneous Scheduler Registers Overview | | | Table 143 | Frame Aging Registers Overview | | | Table 144 | Statistics Address Mapping | | | Table 145 | Statistics Registers Overview | . 226 | | Table 146 | EEE Registers Overview | . 227 | | Table 147 | Calendar Registers Overview | . 228 | | Table 148 | Frame Table Entry Register Overview (2048 entries) | . 230 | | Table 149 | DTI Table Entry Registers Overview | | | Table 150 | Miscellaneous DTI Parameters | | | Table 151 | TTI Timer Ticks Registers Overview | | | Table 152 | TTI Parameters (2048 entries) | | | Table 153 | TTI Calendar Registers Overview | | | Table 154 | Miscellaneous TTI Registers Overview | | | Table 155 | AFI TUPE Registers Overview | | | Table 156 | Port Parameters | | | Table 157 | ES0 Configuration Registers | | | Table 158 | VCAP_ES0 Keys | | | Table 150 | VCAP_ES0 Actions | | | Table 159 | | | | | Rewriter Pipeline Point Definitions | | | Table 161 | Pipeline Actions | | | Table 162 | Pipeline Point Updating Rules | | | Table 163 | Frame Loopback Options | | | Table 164 | Pipeline Action Updates | | | Table 165 | Loopback IFH Updates | | | Table 166 | Egress Statistics Control Registers | | | Table 167 | ESDX Index Selection | | | Table 168 | Egress Statistics Update | | | Table 169 | Mapping Table Configuration Registers | | | Table 170 | Port VLAN Tag Configuration Registers | | | Table 171 | ES0 VLAN Tag Actions | | | Table 172 | Port-Based DSCP Editing Registers | . 262 | | Table 173 | Rewriter VStaX Configuration Registers | | |-----------|------------------------------------------------------------------|-------| | Table 174 | GCPU Configuration Registers | | | Table 175 | Routing SMAC Configuration Registers | | | Table 176 | L3 Routing Egress Mapping VLAN (EVMID) | | | Table 177 | Mirror Probe Configuration Registers | | | Table 178 | IFH Configuration Registers | | | Table 179 | Replication Terminology | . 268 | | Table 180 | Basic Port Setup Configuration Registers Overview | . 268 | | Table 181 | Buffer Maintenance Configuration Register Overview | . 269 | | Table 182 | PAUSE Frame Generation Configuration Registers Overview | | | Table 183 | PAUSE Frame Reception Configuration Registers Overview | . 270 | | Table 184 | PFC PAUSE Frame Generation Configuration Registers Overview | . 270 | | Table 185 | Half-Duplex Mode Flow Control Configuration Register Overview | | | Table 186 | Aging Configuration Register Overview | . 271 | | Table 187 | Aging Status Register Overview | . 271 | | Table 188 | Rate Limiting Common Configuration Registers Overview | . 271 | | Table 189 | Rate Limiting Frame Overhead Configuration Registers Overview | | | Table 190 | Rate Limiting Payload Data Rate Configuration Registers Overview | . 272 | | Table 191 | Rate Limiting Frame Rate Registers Overview | . 273 | | Table 192 | Error Detection Status Registers Overview | . 273 | | Table 193 | Layer 1 Timing Configuration Registers | . 273 | | Table 194 | Layer 1 Timing Recovered Clock Pins | . 274 | | Table 195 | Recovered Clock Settings for 1 Gbps or Lower | . 274 | | Table 196 | Recovered Clock Settings for 2.5 Gbps | . 275 | | Table 197 | Recovered Clock Settings for PLL | . 275 | | Table 198 | Squelch Configuration for Sources | | | Table 199 | Timing Parameters | . 277 | | Table 200 | Rewriter PTP Configuration | . 278 | | Table 201 | Rewriter Operations for One-Step Operation | . 279 | | Table 202 | LoadStore Controller | . 282 | | Table 203 | IEEE 1588 Configuration Registers Overview | . 282 | | Table 204 | PTP Actions in Rewriter | | | Table 205 | Rewriter Registers | . 283 | | Table 206 | Port Module Registers | . 284 | | Table 207 | I/O Delays at 156.25 MHz | | | Table 208 | I/O Delays at 52 MHz | | | Table 209 | Common Ethernet Frequency Outputs | . 291 | | Table 210 | PTP/SyncE Operating Mode Support | . 291 | | Table 211 | Interface Macro to I/O Pin Mapping | . 293 | | Table 212 | VRAP Registers | | | Table 213 | VLAN Table Configuration Before APS | . 302 | | Table 214 | VLAN TUPE Command for Ring Protection Switching | | | Table 215 | VLAN Table Configuration After APS | . 303 | | Table 216 | MAC Table Flush, First Command | . 304 | | Table 217 | Strapping | . 307 | | Table 218 | Clocking and Reset Configuration Registers | . 309 | | Table 219 | Shared Bus Configuration Registers | | | Table 220 | SI Slave Mode Pins | . 316 | | Table 221 | MIIM Slave Pins | . 318 | | Table 222 | MIIM Registers | . 318 | | Table 223 | VCore Shared Bus Access Registers | . 319 | | Table 224 | Mailbox and Semaphore Registers | . 320 | | Table 225 | Manual PCle Bring-Up Registers | | | Table 226 | Base Address Registers | | | Table 227 | PCIe Outbound Interrupt Registers | | | Table 228 | Outbound Access Registers | | | Table 229 | PCIe Access Header Fields | | | Table 230 | FDMA PCIe Access Header Fields | . 326 | | Table 231 | Power Management Registers | | | Table 232 | PCIe Wake Pin | . 327 | |-----------|-------------------------------------------------------------|-------| | Table 233 | FDMA Registers | | | Table 234 | SI Boot Controller Configuration Registers | . 336 | | Table 235 | Serial Interface Pins | | | Table 236 | SI Master Controller Configuration Registers Overview | . 339 | | Table 237 | SI Master Controller Pins | | | Table 238 | DDR3/DDR3L Controller Registers | | | Table 239 | General DDR3/DDR3L Timing and Mode Parameters | | | Table 240 | Memory Controller Configuration | | | Table 241 | Timer Registers | | | Table 242 | UART Registers | | | Table 243 | UART Interface Pins | | | Table 244 | Two-Wire Serial Interface Registers | | | Table 245 | Two-Wire Serial Interface Pins | | | Table 246 | MIIM Registers | | | Table 247 | MIIM Management Controller Pins | | | Table 248 | GPIO Registers | | | Table 249 | GPIO Overlaid Functions | | | Table 250 | Parallel Signal Detect Pins | | | Table 251 | SIO Registers | | | Table 252 | SIO Controller Pins | | | Table 253 | Blink Modes | | | Table 254 | SIO Controller Port Mapping | | | Table 255 | Fan Controller | | | Table 256 | Fan Controller Pins | | | Table 257 | Temperature Sensor Registers | | | Table 258 | Integrity Monitor Registers | | | Table 259 | Memories with Integrity Support | | | Table 260 | Interrupt Controller Registers | | | Table 261 | Interrupt Sources | | | Table 262 | Interrupt Destinations | | | Table 263 | External Interrupt Pins | | | Table 264 | Reference Clock Inputs | | | Table 265 | PLL Clock Output | | | Table 266 | DPLL Clock Outputs | | | Table 267 | DPLL Clock Inputs | | | Table 268 | DDR3 SDRAM Signals | | | Table 269 | DDR3L SDRAM Signals | | | Table 270 | 1G Transmitter | | | Table 271 | 1G Receiver | | | Table 272 | 6G Transmitter | | | Table 273 | 6G Receiver | | | Table 274 | I/O Signals | | | Table 275 | GPIO, SI, JTAG, and Miscellaneous Signals DC Specifications | | | Table 276 | Thermal Diode Parameters | | | Table 277 | REFCLK Reference Clock | | | Table 278 | REFCLK2 Reference Clock | | | Table 279 | PLL Clock Outputs | | | Table 280 | DPLL Clock Outputs | | | Table 281 | DPLL Clock Inputs | | | Table 282 | Jitter Transfer | | | Table 283 | 100BASE-FX, SGMII, SFP, 1000BASE-KX Transmitter | | | Table 284 | 100BASE-FX, SGMII, SFP, 1000BASE-KX Receiver | | | Table 285 | 100BASE-FX, SGMII, SFP, 2.5G, 1000BASE-KX Transmitter | | | Table 286 | 100BASE-FX, SGMII, SFP, 2.5G, 1000BASE-KX Receiver | | | Table 287 | PCle Transmitter | | | Table 288 | PCIe Receiver | | | Table 289 | nRESET Timing Specifications | . 387 | | Table 290 | MIIM Timing Specifications | | | Table 291 | SI Boot Timing Specifications for Master Mode | 388 | |-----------|---------------------------------------------------|-----| | Table 292 | SI Timing Specifications for Master Mode | 389 | | Table 293 | SI Timing Specifications for Slave Mode | 390 | | Table 294 | DDR3/DDR3L SDRAM Input Signal AC Characteristics | 391 | | Table 295 | DDR3/DDR3L SDRAM Output Signal AC Characteristics | 393 | | Table 296 | JTAG Interface AC Specifications | 394 | | Table 297 | Serial I/O Timing Specifications | 395 | | Table 298 | Recovered Clock Output AC Specifications | 396 | | Table 299 | Two-Wire Serial Interface AC Specifications | 397 | | Table 300 | IEEE1588 Time Tick Output AC Specifications | 398 | | Table 301 | Operating Current | 398 | | Table 302 | Power Consumption | 399 | | Table 303 | Power Consumption, Reduced Configuration | 399 | | Table 304 | Recommended Operating Conditions | 399 | | Table 305 | Stress Ratings | | | Table 306 | Pin Type Symbol Definitions | 402 | | Table 307 | DDR3/DDR3L SDRAM Pins | 403 | | Table 308 | DPLL Clock Pins | 404 | | Table 309 | GPIO Pins | | | Table 310 | JTAG Interface Pins | 404 | | Table 311 | MII Management Interface Pins | | | Table 312 | Miscellaneous Pins | | | Table 313 | PCI Express Interface Pins | | | Table 314 | Power Supply and Ground Pins | | | Table 315 | SERDES1G Pins | | | Table 316 | SERDES6G Pins | | | Table 317 | Serial CPU Interface Pins | | | Table 318 | System Clock Interface Pins | | | Table 319 | Twisted Pair Interface Pins | 408 | | Table 320 | Thermal Resistances | | | Table 321 | Recommended Skew Budget | | | Table 322 | Ordering Information | 426 | # 1 Revision History The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication. ## 1.1 **Revision 4.1** Revision 4.1 was published in April 2019. The following is a summary of changes in revision 4.1 of this document. - VeriPHY<sup>™</sup> Cable Diagnostics section was updated. For more information, see VeriPHY<sup>™</sup> Cable Diagnostics, page 38. - The Pins by Function section was updated with proper heading style. ## 1.2 **Revision 4.0** Revision 4.0 was published in September 2017. It was the first production-level publication of this document. # 2 Product Overview The VSC7415 Serval-T™ Gigabit Ethernet switch targets small cell equipment to deliver Enterprise and Mobile Backhaul. VSC7415 integrates VeriTime™, Microsemi's patent-pending timing technology. Combined with CEServices PTP software and market leading IEEE1588 servo algorithm it delivers the industry's most accurate IEEE 1588v2 timing implementation to meet today's LTE/LTE-A requirements. The VSC7415 switch contains four 10/100/1000 Mbps ports (up to two copper ports), and two 10/100/1000/2500 Mbps ports. An integrated DPLL reduces BOM costs, simplifies system design, and provides proven interoperability between switch and DPLL. VSC7415 provides a rich set of Ethernet switching features such as advanced TCAM-based VLAN and QoS processing that enable delivery of differentiated services, security through TCAM-based frame processing using Vers Content-Aware Processor (VCAP™), protection switching, IEEE 1588, Synchronous Ethernet, and integrated EEC/PEC DPLL controller. IPv4/IPv6 Layer 3 (L3) routing and IPv4/IPv6 L3 multicast groups are supported. L3 security features include source guard and unicast Reverse Path Forwarding (uRPF) tasks. VSC7415 supports Microsemi's application programming interface for easy integration with third-party application software. The device also supports Microsemi's CEServices application software, dramatically reducing time-to-market. The VSC7415 Serval-T™ device is a 9 Gbps Gigabit Ethernet switch with up to six ports supporting the following main port configurations: - 4 × 1G SGMII ports + 2 × 2.5G SGMII ports - 6 × 1G SGMII ports - Two of the 1G SGMII ports are dual-media ports with a choice of 1G SGMII or 1G CuPHY In addition, the device supports one 10/100/1000 Mbps SGMII/SerDes Node Processor Interface (NPI) Ethernet port. ### 2.1 General Features This section lists the key device features and benefits. # 2.1.1 Layer 2 and Layer 3 Forwarding - IEEE802.1Q switch with 4K VLANs and 8K MAC table entries - Push/pop/translate up to three VLAN tags on ingress and egress - RSTP and MSTP support - · Fully non-blocking wire-speed switching performance for all frame sizes - IPv4/IPv6 unicast and multicast Layer 2 switching with up to 8K groups and 128 port masks - IPv4/IPv6 unicast and multicast Layer 3 forwarding (routing) with reverse path forwarding (RPF) support - IGMPv2, IGMPv3, MLDv1, and MLDv2 support # 2.1.2 Timing and Synchronization - Fully integrated advanced Synchronous Ethernet and PTP equipment clocks with four outputs and four inputs - Programmable low-pass filtering down to 1 millihertz (mHz) allow support for G.8262 Option 1 and Option 2 compliant operation - Four DPLL clock outputs (programmable from 1 MHz to 250 MHz) locked to recovered clocks from any internal port, one of four clock inputs, to PTP or running in digital controlled oscillator (DCO) mode. - Advanced PTP and SyncE hybrid mode support - Four clock input qualifiers for qualification and monitoring, automatically disqualifies references based on frequency and phase irregularities - IEEE 1588-2008 (v2) with nanosecond-accurate time stamping for one-step and two-step clocks - · Hardware processing and PTP frame generation ### 2.1.3 Quality of Service - · One megabytes of integrated shared packet memory - Eight QoS classes per port - TCAM-based classification with pattern matching against Layer 2 through Layer 4 information - Dual-rate policers selected by VCAP IS2, eight single-rate priority policers per port, and two singlerate port policers for each port - · Flexible 2K ingress QoS mappings and 4K egress QoS mappings for VLAN tags and DSCP values - Up to 512 egress VLAN tag operations - Priority-based flow control (PFC) (IEEE 802.1Qbb) - Audio/Video bridging (AVB) with support for time-synchronized, low-latency audio and video streaming services ## 2.1.4 Security - Versatile Content Aware Processor (VCAP™) packet filtering engine using ACLs for ingress and egress packet inspection - · Storm controllers for flooded broadcast, flooded multicast, and flooded unicast traffic - Per-port, per-address registration for copying/redirecting/discarding - 32 VCAP single-rate policers ### 2.1.5 Management - VCore-III<sup>TM</sup> CPU system with integrated 500 MHz MIPS 24KEc CPU with MMU and DDR3/DDR3L SDRAM controller - PCIe 1.x CPU interface - CPU frame extraction (eight queues) and injection (two queues) through DMA, which enables efficient data transfer between Ethernet ports and CPU/PCIe - EJTAG debug interface - Configurable 16-bit or 8-bit DDR3 SDRAM interface supporting up to one gigabyte (GB) of memory - Thirty-seven, pin-shared general-purpose I/Os - Serial GPIO and LED controller controlling up to 32 ports with four LEDs each - Triple PHY management controller (MIIM) - Dual UART - · Dual built-in two wire serial interface multiplexer - External interrupts - 1588 synchronization I/Os - · SFP loss of signal inputs - External access to registers through PCIe, SPI, MIIM, or through an Ethernet port with inline Versatile Register Access Protocol (VRAP) - Per-port counter set with support for the RMON statistics group (RFC 2819) and SNMP interfaces group (RFC 2863) - Energy Efficient Ethernet (EEE) (IEEE 802.3az) - · Synchronous Ethernet, with four clock outputs recovered from any port - Support for CPU modes with internal CPU only, external CPU only, or dual CPU ### 2.1.6 Product Parameters All SerDes, copper transceivers, packet memory, and configuration tables necessary to support network applications are integrated. The following table lists the primary parameters for the device. #### Table 1 • Product Parameters | Features and Port Configurations | | |--------------------------------------------------|--------| | Maximum bandwidth excluding 1G NPI port | 9 Gbps | | Maximum number of ports excluding 1G NPI port | 6 | | 10G SFI ports (also capable of 2.5G or 1G SGMII) | 0 | | 2.5G SGMII ports (also capable of 1G SGMII) | 2 | | 1G SGMII ports excluding 1G NPI port | 2 | #### Table 1 • Product Parameters (continued) | 1G dual media ports (1G SGMII or 1G CuPHY) | 2 | |------------------------------------------------------------------------------------------------------|------------------------| | 1G SGMII NPI port | 1 | | Integrated SyncE DPLL | | | EEC/PEC DPLL clocks | 4 | | Layer 2 Switching | | | Packet buffer | 8 Mb | | MAC table size | 8K | | Layer 2 multicast port masks | 128 | | Super VCAP blocks (1K x 36 bits per block) | 6 | | VCAP CLM entries (36 bits) per super VCAP block | 1K | | VCAP LPM entries (36 bits) per super VCAP block | 1K | | VCAP IS2 entries (288 bits) per super VCAP block | 128 | | VCAP ES0 entries | 512 | | Layer 3 Routing | | | Router legs | 32 | | IP unicast routes/hosts per super VCAP block allocated to VCAP LPM for unicast routing | IPv4: 1K<br>IPv6: 256 | | Next-hop/ARP table entries | 256 | | IP (S,G) or (*, G) multicast groups per super VCAP block allocated to VCAP LPM for multicast routing | IPv4: 512<br>IPv6: 128 | | Multicast router leg masks | 256 | | ECMPs | 16 | | Quality of Service and Security | | | Ingress QoS mapping table entries | 2K | | Egress QoS mapping table entries | 4K | | Security enforcement (ACL) rules (288 bits) per super VCAP block allocated to VCAP IS2 | 128 | | | | # 2.2 Applications The device targets the following applications. - Small cell backhaul (microwave and millimeter wave, for example) equipment such as split-mount Outdoor Unit (ODU), Indoor Unit (IDU), and all-integrated ODU. - Small Cell equipment (micro, femto, and pico) targeting delivery of 4G/LTE mobile services. This small cell equipment integrates radio front-end and networking components. The following illustration shows these applications on a single-carrier network with fixed/mobile convergence. ### 2.2.1 Wireless Backhaul Wireless backhaul equipment is available with the following configuration options: - Traditional split-mount with separate Outdoor Units (ODUs) and Indoor Units (IDUs). In the traditional split, the modem functionality exists in the IDU, and the interface between the ODU and IDU is a modulated waveform. - Ethernet split-mount also with separate ODU and IDU. In this configuration, the modem functionality exists in the ODU along with some packet switching functions such as redundancy protection. The interface between the ODU and IDU is Ethernet packets. All-integrated ODU, where the full ODU and IDU functionality is integrated into one piece of outdoor equipment. The device targets all of these configurations. Networking features enable wireless backhaul topologies such as chains, trees, and rings. Networking features are especially important in wireless backhaul, which can result in relatively arbitrary daisy-chaining in the backhaul. Typically, smaller switches are present in ODUs and larger switches in IDUs, which often act as aggregators or localized switching centers. The following illustration shows an all-integrated ODU on the left, a traditional split- mount ODU/IDU in the middle, and an Ethernet split-mount ODU/IDU on the right. In some installations, the Radio Base Station and the all-integrated ODU functionality can also be built into a single piece of equipment. In the illustration, the full backhaul is made up of the wireless backhaul section plus the wired backhaul section, operated by two separate network providers. Only the wireless backhaul section is illustrated. Other models of network ownership are possible. The wireless backhaul network provides a transport service between each Radio Base Station and the Pre-aggregation network. The wireless backhaul operator provides an Ethernet connection between each Radio Base Station (Metro Ethernet Forum UNI interface) and the Pre-aggregation Router (Metro Ethernet Forum E-NNI interface). The application shown is somewhat simplified. In actual deployment, more complex configurations are common, such as equipment redundancy, network redundancy (linear, ring, mesh, link aggregation), and increased wireless capacity through link bonding. Figure 1 • Wireless Backhaul Application # IEEE-1588 TRANSPARENT CLOCK OVER WIRELESS # IEEE-1588 TRANSPARENT CLOCK OVER WIRELESS Microwave radio links are highly susceptible to weather and use adaptive modulation techniques to deliver data reliably during bad weather. As a result, the microwave data transfer rate (link speed) can change rapidly, causing jitter problems for IEEE 1588 and Quality of Service (QoS) problems for the networking gear. The link speed is also limited to a few hundred Mbps per microwave link under good weather conditions, so link bundling and load balancing are common. Next-generation ODUs must support timing and synchronization such as Synchronous Ethernet and IEEE 1588 packet based timing. Integrated ODU/IDU equipment also exists, especially for 4G/LTE small cell backhaul. These units have a low port count but include advanced features such as protection switching mechanisms, and strong QoS. The following key features are supported for wireless backhaul. - Low size, low cost, and low power, especially for the ODUs and all-integrated ODU - Integrated 1G copper PHYs - Ethernet and IP networking features at the IDUs and all-integrated ODUs - IEEE 1588 functionality delivering high-precision timing to 4G/LTE Base Stations. Various proprietary techniques are supported to combat the jitter created by adaptive modulation on a wireless link, including ability to provide an IEEE 1588 transparent clock function over a wireless link. - Strong QoS to handle the varying link speed - IEEE 802.1Qbb priority-based flow control can be used as in-band dynamic flow control. - Versatile Register Access Protocol (VRAP) may also be used to dynamically adjust scheduler/shaper rates in-band. - Large integrated buffer memory, advanced hierarchical scheduling and shaping, and WRED enable efficient bandwidth use without jeopardizing low-latency traffic such as voice. - Linear and ring protection mechanisms - -40 °C ambient to 125 °C junction operating temperature ### 2.2.2 Small Cell Application The following illustration shows multiple 4G/LTE small cells being backhauled to a pre-aggregation switch or router at the edge of a wired network. Figure 2 • 4G/LTE Small Cell Application For small cell applications, the device provides strong backhaul networking along with integrated timing functions, as listed below: - Integrated 1G copper PHY ports. - Routing for network management and control. - Small cell timing based on Synchronous Ethernet, IEEE-1588 packets, or optional local GPS receiver. - Synchronous Ethernet Equipment Clock (EEC) compliant with G.8262. - IEEE-1588 Packet Equipment Clock (PEC) compliant with G.8264. IEEE-1588 Transparent Clock functions supported for backhaul chaining. - Client hybrid mode using the SyncE high-speed clock for frequency and the 1588 algorithm solely for phase. - Full separation of SyncE and 1588 clock domains where SyncE wander has no influence on the 1588 performance. - Coupled mode where the SyncE clock is pre-qualified before it is used as the 1588 frequency reference. Any SyncE wander above a programmable threshold is rejected from being used in the 1588 domain. - External reference clock can be supplied at an arbitrary frequency to the radio clock generation circuit. Alternately, a high-quality radio clock can be used as the reference clock to the VSC7415 device's PLL. # 3 Functional Descriptions This section describes the functional aspects of the VSC7415 device, including available configurations, operational features, and testing functionality. It also defines the device setup parameters that configure the device for a particular application. The functional descriptions in this section contain some information shared across multiple switch families. As a result, some functional descriptions do not apply to this device. For example, support for MEF services is built around an ISDX—an internal parameter used to identify a service instance when service processing a frame. The ISDX is part of many functional blocks, such as the VCAP CLM keys and actions, the analyzer, the rewriter, and the queue system. The VSC7415 does not support MEF services, and the concept of the ISDX cannot be used. Any reference to ISDX and use of the ISDX is therefore not applicable. The following lists features and hardware handles that are mentioned in this section, but not supported by VSC7415: #### MEF Services - ISDX. VSI. ESDX - Service statistics (ingress, egress) - ISDX selected SDLB policing #### Versatile OAM processor (VOP) - Hardware OAM processing - Port VOEs, service VOEs, path VOEs - MIPs and MEPs - Y.1564 SAM, SAM sequence - OAM COSID and color #### MPLS-TP processing (LSR, LER) - VCAP CLM keys: SGL\_MLBS, DBL\_MLBS, TRI\_MLBS - MPLS TC mapping - Hierarchical QoS and dual-rate shaping - Stacking. The VStaX header is used by all switch families as an internal frame header and when communicating with external CPUs. - · Learn all frames - Stacking links - 10G port modes The following illustration shows an RTL block diagram of the physical blocks in the device and how the blocks interconnect. The functional aspects of each block are provided in following sections. The grayed-out blocks represent the VCore-III and DEVCPU blocks. For more information about the VCore-III and DEVCPU blocks, see VCore-III System and CPU Interfaces, page 308. Figure 3 • RTL Block Diagram # 3.1 Register Notations This datasheet uses the following general register notations. - <TARGET>:<REGISTER\_GROUP>:<REGISTER>.<FIELD> - <REGISTER\_GROUP> is not always present. In that case the following notation is used: - <TARGET>::<REGISTER>.<FIELD> When a register group does exist, it is always prepended with a target in the notation. In sections where only one register is discussed or the target (and register group) is known from the context, the <TARGET>:<REGISTER\_GROUP>: may be omitted for brevity leading to the following notation: <REGISTER>.<FIELD> When a register contains only one field, the .<FIELD> is not included in the notation. When referring to a specific instance of a register group, specific register instance, or a specific bit in a field, square brackets are used, for example: - <TARGET>:<REGISTER\_GROUP>[<register group instance>]:<REGISTER>.<FIELD> - <TARGET>:<REGISTER GROUP>:<REGISTER>[<register instance>].<FIELD> - <TARGET>:<REGISTER\_GROUP>:<REGISTER>.<FIELD>[<bit number>] ## 3.2 Functional Overview This section provides an overview of all the major blocks and functions involved in the forwarding operation, in the same order as a frame traverses through the device. Other major functions of the device, such as the CPU subsystem and IEEE 1588 PTP processing are also outlined. The following illustration shows the VSC7415 block diagram. Figure 4 • Block Diagram #### 3.2.1 Frame Arrival in Ports and Port Modules The Ethernet interfaces receive incoming frames and forward these to the port modules. Two ports are dual media ports supporting either a 1G copper PHY or a 1G SGMII SerDes macro. The remaining ports all support SerDes macros. Each port contains a Media Access Controller (MAC) that performs a full suite of checks, such as VLAN tag-aware frame size checking, frame check sequence (FCS) checking, and pause frame identification. SerDes ports contain a Physical Coding Sublayer (PCS), which performs 8b/10b or 64b/66b encoding, auto-negotiation of link speed and duplex mode, and monitoring of the link status. Symmetric and asymmetric pause flow control are both supported as well as priority-based flow control (IEEE 802.1Qbb). All Ethernet ports support Energy Efficient Ethernet (EEE) according to IEEE 802.3az. The shared queue system is capable of controlling the PCS operating states, which are active or low power. The PCS understands the line signaling as required for EEE. This includes signaling of active, sleep, quiet, refresh, and wake. ### 3.2.1.1 1G Copper PHY Ports 1G copper PHY ports operate in 1000BASE-T. Auto-negotiation is supported for pause settings and remote fault signaling. Full-duplex is supported for 10/100/1000 Mbps, while half-duplex is supported for 10/100 Mbps. #### 3.2.1.2 1G SGMII Line Ports 1G SGMII line ports operate in one of the following modes: - 10/100/1000 Mbps SGMII. The SGMII interface connects to an external copper PHY device or copper SFP optical module with SGMII interface. In this mode, auto-negotiation is supported for link speed, duplex settings, pause settings, and remote fault signaling. Full-duplex is supported for all speeds, while half-duplex is supported for 10/100 Mbps. - 100BASE-FX. The 100BASE-FX interface connects directly to a 100BASE-FX SFP optical module. Auto-negotiation is not specified for 100BASE-FX and is not supported. Operation is always 100 Mbps and full duplex. - 1000BASE-X. The 1000BASE-X interface connects directly to a 1000BASE-X SFP optical module. Auto-negotiation is supported for pause settings and remote fault signaling. Operation is always 1000 Mbps and full duplex. 1G backplane Ethernet 1000BASE-KX is fully supported, including auto-negotiation. #### 3.2.1.3 2.5G SGMII Line Ports The 2.5G interface connects directly to an SFP optical module. Operation is always 2500 Mbps and full duplex. 2.5G backplane Ethernet is also supported. The 2.5G SGMII line port can also operate in the modes supported by the 1G SGMII line port. #### 3.2.2 Basic Classification Basic frame classification in the ingress processing module (the analyzer) receives all frames before further classification processing is performed. The basic classifier uses configurable logic to classify each frame to a VLAN, QoS class, drop precedence (DP) level, DSCP value, and an aggregation code. This information is carried through the switch together with the frame and affects policing, drop precedence marking, statistics collecting, security enforcement, Layer 2 and Layer 3 forwarding, and rewriting. The basic classifier also performs a general frame acceptance check. The output from the basic classification can be overwritten or changed by the more intelligent advanced classification using the TCAM-based VCAP. # 3.2.3 Security and Control Protocol Classification Before being passed on to the Layer 2 forwarding, all frames are inspected by the VCAP IS2 for security enforcement and control protocol actions. The action associated with each IS2 entry (programmed into the IS2 action RAM) includes frame filtering, single leaky bucket rate limiting (frame or byte based), snooping to CPU, redirecting to CPU, mirroring, time stamping, and accounting. Although the VCAP IS2 is located in the ingress path of the device, it has both ingress and egress capabilities. The VCAP IS2 engine embeds powerful protocol awareness for well-known protocols such as LLC, SNAP, ARP, IPv4, IPv6, and UDP/TCP. IPv6 is supported with full matching against both the source and the destination IP addresses. For each frame, up to two lookup keys are generated and matched against the VCAP entries. # 3.2.4 Policing Each frame is subject to one or more of the following policing operations. - Single-rate priority policers. Ingress port number and QoS class determine which policer to use. - Single-rate port policers. Ingress port number determines which policer to use. - VCAP single-rate policers. IS2 action selects which VCAP single-rate policer to use. - VCAP dual-rate policers. IS2 action selects which VCAP dual-rate policer to use. - Single-rate global storm policers. Frame characteristicS such as broadcast, unicast, multicast, or learn frame select which policer to use. - Single-rate service broadcast, unicast, and multicast (BUM) policers for flooded frames. Service classification and destination MAC address select which policer to use. Each frame can trigger up to fourteen policers: - One BUM policer - · One priority policer or one dual-rate VCAP policer - · One port policer - One VCAP policer - Two port policers - · Eight storm policers Dual-rate policers are MEF-compliant, supporting both color-blind and color-aware operation. The initial frame color is derived from the drop precedence level from the frame classification. The MEF coupling mode is also configurable for each policer. Dual-rate policers ensure Service Level Agreement (SLA) compliance. The outcome of this policing operation is to mark each accepted frame as in-profile (green) or out-of-profile (yellow). Yellow frames are treated as excess or discard-eligible and green frames are committed. Frames that exceed the yellow/excess limits are discarded (red). The two port policers and eight storm policers can be programmed to limit different types of traffic, such as CPU-forwarded frames, learn frames, known or unknown unicast, multicast, or broadcast. ### 3.2.5 Layer 2 Forwarding After the policers, the Layer 2 forwarding block of the analyzer handles all fundamental Layer 2 forwarding operations and maintains the associated MAC table, the VLAN table, and the aggregation table. The device implements an 8K MAC table and a 4K VLAN table. The main task of the analyzer is to determine the destination port set of each frame. The Layer 2 forwarding decision is based on various information such as the frame's ingress port, source MAC address, destination MAC address, and the VLAN identifier, as well as the frame's VCAP actions, mirroring, and the destination port's link aggregation configuration. Layer 2 forwarding of unicast and Layer 2 multicast frames is based on the destination MAC address and the VLAN. The switch can also L2-forward IPv4 and IPv6 multicast frames using additional Layer-3 information, such as the source IP address. The latter enables source-specific IPv4 multicast forwarding (IGMPv3) and source-specific IPv6 multicast forwarding (MLDv2). This process of L2-forwarding multicast frames using Layer 3 information is called "snooping", which is different from L3-forwarding (routing) of multicast frames. The following describes some of the contributions to the Layer 2 forwarding. - VLAN Classification VLAN-based forward filtering includes source port filtering, destination port filtering, VLAN mirroring, and asymmetric VLANs. - Security Enforcement The security decision made by the VCAP IS2 can, for example, redirect the frame to the CPU based on security filters. - MSTP The VLAN identifier maps to a Multiple Spanning Tree instance, which determines MSTPbased destination port filtering. - MAC Addresses Destination and source MAC address lookups in the MAC table determine if a frame is a learn frame, a flood frame, a multicast frame, or a unicast frame. - Learning By default, the device performs hardware learning on all ports. However, certain ports could be configured with secure learning enabled, where an incoming frame with unknown source MAC address is classified as a "learn frame" and is redirected to the CPU. The CPU performs the learning decision and also decides whether the frame is forwarded. - Learning can also be disabled. If learning is disabled, it does not matter if the source MAC address is in the MAC table. - Link Aggregation A frame targeted to a link aggregate is processed to determine which physical port of the link aggregate group the frame must be forwarded to. - **Mirroring** Mirror probes may be set up in different places in the forwarding path for monitoring purposes. As part mirroring, a copy of the frame is sent either to the CPU or to another port. ### 3.2.6 Layer 3 Forwarding The device supports Layer 3 forwarding (routing), which is performed by the analyzer. With Layer 3 forwarding, the IPv4 or IPv6 addresses determine the destination port set and Layer 3 processing is performed on IP header. The Layer 3 forwarding process also replaces the arrival Layer-2 Ethernet header (including MAC addresses and VLAN tags) with a new Layer 2 Ethernet header after departure from the switch. The analyzer supports 32 router legs, and supports Virtual Router Redundancy Protocol (VRRP). Ingress router legs are addressed using classified arrival VLAN and DMAC address. If an arrival frame is determined to belong to an ingress router leg and routing is enabled, Layer 3 forwarding is applied. Note that this is in addition to any Layer 2 forwarding, so for example, an arrival multicast frame may be Layer 2 forwarded on the classified arrival VLAN and also Layer 3 forwarded to one or more additional VLANs. IP unicast frames only use Layer 2 forwarding or Layer 3 forwarding, but never both. Layer 3 forwarding always uses the classified arrival VLAN. Layer 3 forwarding first checks the IP header for validity. IP header checks include IP version, header length, and header checksum. The Time-to-Live (TTL) or Hop Limit values are also checked for validity and decremented if the packet is forwarded. The analyzer then searches the Longest Prefix Match (LPM) table for an exact match of the destination IP address. If there is not an exact match, the table is searched for the best partial match. If there is no partial match in the LPM table, the frame is Layer 3 forwarded to the location of the default gateway. With Layer 3 forwarding, each egress frame copy uses an egress router leg to determine the per-copy egress encapsulation. There can be up to 16 egress router legs associated with one forwarding entry in support of Equal Cost Multipath (ECMP) functionality, where multiple forwarding paths are used between adjacent routers for increased forwarding bandwidth. Reverse path forwarding (RPF) is optionally performed on multicast and unicast (uRPF) packets as a security check. This source IP address check helps detect and prevent address spoofing. Multicast frames can be Layer 2 forwarded on the arrival VLAN as well as Layer 3 forwarded to different VLANs. Layer 3 forwarding of IP multicast is different from Layer 2 forwarding of IP multicast using IGMP/MLD snooping in the following ways: - · IP header checks and TTL processing are performed - The Ethernet header is swapped - The egress VLANs may be different from the ingress VLANs - · Multiple frame copies can be generated per physical port Network control such as ICMP and ARP are redirected to the CPU, along with malformed packets, packets with expired TTL, and packets with options. ## 3.2.7 Shared Queue System and Hierarchical Scheduler The analyzer provides the destination port set of a frame to the shared queue system. It is the queue system's task to control the frame forwarding to all destination ports. The shared queue system embeds memory that can be shared between all queues and ports. Frames are mapped to queues through a programmable mapping function allowing ingress ports, egress ports, QoS classes to be taken into account. The sharing of resources between queues and ports is controlled by an extensive set of thresholds. Each egress port implements default schedulers and shapers as shown in the following illustration. Per egress port, the scheduler sees the outcome of aggregating the egress queues (one per ingress port per QoS class) into eight QoS classes. ### 3.2.7.1 Class-Based Queuing (Default Configuration) By default, aggregation is done in a Deficit Weighted Round Robin fashion (DWRR) with equal weights to all ingress ports within a QoS class, so byte-accurate weighted round robin scheduling between ingress ports is performed for each QoS class. The following illustration shows the default scheduler-shaper configuration. Hierarchical scheduling-shaping is also possible. Figure 5 • Default Scheduler-Shaper Configuration Scheduling between QoS classes within the port can use one of the three following methods: - Strict Priority scheduling. Frames with the highest QoS class are always transmitted before frames with lower QoS class. - Deficit Weighted Round Robin (DWRR) scheduling. Each QoS class serviced using DWRR sets a DWRR weight ranging from 0 to 31. - Combination of Strict Priority and DWRR scheduling. The default configuration is shown, where QoS classes 7 and 6 use strict priority while QoS classes 5 through 0 use DWRR. But any split between strict and DWRR QoS classes can be configured. ## 3.2.8 Rewriter and Frame Departure Before transmitting the frame on the egress line, the rewriter can modify selected fields in the frame such as Ethernet headers and VLAN tags, IPv4/IPv6 fields, PTP fields, and FCS. The rewriter also updates the frame's COS and color indications such as DEI, PCP, and DSCP. Departure statistics are also kept based on the classified VLAN. - Basic VLAN Tagging Operations (Port-based) By default, the egress VLAN actions are determined by the egress port settings and classified VLAN. These include basic VLAN operations such as pushing a VLAN tag, untagging for specific VLANs, and simple translations of DEI, PCP, and DSCP. - Advanced VLAN Tagging Operations (Port-based and VCAP-based) By using the egress VCAP ES0, significantly more advanced VLAN tagging operations can be achieved. ES0 enables pushing up to three VLAN tags and flexible VLAN tag translation for VLAN tag/TPID, PCP, DEI, and DSCP control. The lookup by VCAP ES0 includes classified VLAN, egress port, and COS/color indications. - Layer 3 Forwarding (Routing) Operations Supports per-router-leg control of Ethernet link layer encapsulation and VID, as well as modification of other Layer 3 fields such as IPv4 TTL, IPv4 checksum, and IPv6 hop limit. - PTP (IEEE 1588) Operations PTP PDU modifications include insertion/update of time stamps and correction fields, as well as updating the UDP checksum. The rewriter pads frames to minimum legal size if needed, and updates the FCS if the frame was modified before the frame is transmitted. The egress port module controls the flow control exchange of pause frames with a neighboring device when the interconnection link operates in full-duplex flow control mode. #### 3.2.9 CPU Port Module The CPU port module (DEVCPU) contains eight CPU extraction queues and two CPU injection queues. These queues provide an interface for exchanging frames between the internal CPU system and the switch core. An external CPU using the serial interface can also inject and extract frames to and from the switch core by using the CPU port module. In addition, any Ethernet interface on the device can be used for extracting and injecting frames. The Ethernet interface used in this way is called the Node Processor Interface (NPI) and is typically connected to an external CPU. Injected frames may be prepended with an injection header to control processing and forwarding of these frames. Extracted frames may be prepended with an extraction header to supply frame arrival and classification information associated with each frame. These headers may be used by internal CPU or external CPU. The switch core can intercept a variety of different frame types and copy or redirect these to the CPU extraction queues. The classifier can identify a set of well-known frames, such as IEEE reserved destination MAC addresses (BPDUs, GARPs, CCM/Link trace), as well as IP-specific frames (IGMP, MLD). Security VCAP IS2 provides another flexible way of intercepting all kinds of frames, such as specific OAM frames, ARP frames or explicit applications based on TCP/UDP port numbers. In addition, frames can be intercepted based on the MAC table, the VLAN table, or the learning process. Whenever a frame is copied or redirected to the CPU, a CPU extraction queue number is associated with the frame and used by the CPU port module when enqueuing the frame into the eight CPU extraction queues. The CPU extraction queue number is programmable for every interception option in the switch core. # 3.2.10 Synchronous Ethernet and Precision Time Protocol (PTP) Synchronous Ethernet allows for the transfer of precise network timing (frequency) using physical Ethernet link timing. Each piece of network equipment in the SyncE network must support Ethernet Equipment Clock, EEC, functionality where the possible input clocks (recovered clocks from Ethernet ports) are selected based on pre-programmed priority or by the ESMC software protocol. The selected clock is cleaned up for any jitter above a certain frequency (1 Hz to 10 Hz for EEC option 1 and 0.1 Hz for EEC option 2) and a clean output clock is generated and used as transmit reference for the Ethernet ports. If the port currently selected as an input to the EEC is disqualified based on link-down, performance, or the ESMC protocol, the EEC selects the next reference in the priority list. If there is none, it goes into holdover. The device has an integrated EEC/PEC controller that can take clock inputs from any internal Ethernet port or a number of clock inputs. It has four input qualifiers that can be programmed to qualify/disqualify the selected input based on long-term frequency accuracy, short-term frequency accuracy, and missing clock transitions. The clock inputs can be any frequency between 1 MHz and 250 MHz. The SyncE EEC/PEC controller is configured to select between up to four inputs based on priority and will collect holdover data to ensure that the correct holdover frequency is kept in case the selected input fails and no other input is available. If another input is available the device supports hitless switching to the backup port. The timers required to support wait-to-restore and holdoff are implemented in hardware to ensure compliance independent of software processing times. The output synthesizers generating the output frequencies can be programmed to generate any frequency from 1 MHz to 250 MHz and can be controlled by the EEC/PEC controller or directly from a selected clock input. They can also be software-controlled to have a set offset compared to the selected input or to the free-running frequency. The output phase can also be adjusted independently. The low-pass filtering bandwidth of the DPLL can be configured as low as 1 millihertz (mHz) to match the required operation mode. When operating in SyncE mode and SyncE/PTP hybrid mode, one of the clock output synthesizers is used to drive the transmit clock of the device and the other output synthesizers can be used to generate output clocks to external devices. If PTP is used together with SyncE in separate timing domains, an additional clock output synthesizer is used to generate the PTP frequency of the system. The reference clock for the EEC/PEC is the REFCLK2 PLL, and the oscillator used to drive the REFCLK2 is determining the SyncE and PTP stability and holdover performance of the system. The Precision Time Protocol (PTP) allows for the transfer of precise network timing (frequency) and time of day (phase) using Ethernet packets. PTP can operate as a one-step clock or a two-step clock. For one-step clocks, a precise time is calculated and stamped directly into the PTP frames at departure. For two-step clocks, a precise time is simply recorded and provided to the CPU for further processing. The CPU can then initiate a follow-up message with the recorded timing. The device supports PTP Delay\_req/Delay\_resp processing in hardware where the Delay\_req frame is terminated and a Delay\_resp frame is generated based on the request. In addition to updating relevant PTP time stamps and message fields, the frame encapsulation can be changed. This includes swapping and rewriting MAC addresses, IP addresses, and TCP/UDP ports, and updating the IPv4 TTL or IPv6 hop limit. The device also supports generation of PTP Sync frames using the automatic frame injector (AFI) functionality. PTP is supported for a range of encapsulations including: - · PTP over Ethernet - PTP over UDP over IPv4/IPv6 over Ethernet - Either of the above encapsulations over MPLS pseudowire over Ethernet - PTP over UDP over IPv4/IPv6 over MPLS over Ethernet The switch supports two separate timing domains: one for Synchronous Ethernet and data path forwarding, and one for PTP timing synchronization. This gives the system designer control over how these two timing architectures interact. # 3.2.11 CPU Subsystem The device contains a powerful, 500 MHz MIPS24KEc-compatible microprocessor, a high bandwidth Ethernet Frame DMA engine, and a DDR3/DDR3L controller supporting up to 1 gigabyte (GB) of memory. This complete system-on-chip supports Linux or embedded operating systems, enabling full management of the switch and advanced software applications. The device supports external CPU register access by the on-chip PCIe 1.x endpoint controller, by specially formatted Ethernet frames on the NPI port (Versatile Register Access Protocol), or by register access interface using SPI protocol. External CPUs can inject or extract Ethernet frames by the NPI port, by PCIe DMA access, or by register read/writes (using any register-access interface). ## 3.3 Frame Headers This section describes the internal header formats used within the device that are visible in frames to and from the CPU, NPI port, and in frames exchanged between devices in multichip configurations. The header formats are internal frame header (IFH) and VStaX header. Internal frame header (IFH) IFH is used when extracting frames to CPU and injecting frames from CPU. The IFH can also be inserted into frames transmitted on the NPI port. The IFH includes a VStaX header. VStaX header The VStaX header can be used for transmission to and from an NPI port. ### 3.3.1 Internal Frame Header Placement The following illustration shows internal frame header placement. Figure 6 • Frame with Internal Frame Header Frames are injected without prefix from internal CPU or directly attached CPU. Frames can be injected with a prefix to accommodate CPU injection from a front port (that may be directly attached), controlled by ASM:CFG:PORT\_CFG.INJ\_FORMAT\_CFG. The internal frame header and optional prefix is removed before transmitting the frame on a port. It is only visible to the user when injecting and extracting frames to or from the switch core and optionally when sending/receiving frames using the NPI port. It is possible to configure a port to transmit frames with internal frame headers using REW:COMMON:PORT\_CTRL.KEEP\_IFH\_SEL. It is also possible to only transmit CPU redirected frames with Internal frame headers using REW:COMMON:GCPU\_CFG.GCPU\_KEEP\_IFH. ### 3.3.2 Internal Frame Header Layout The internal frame header is 28 bytes long. The following illustration shows the layout. Figure 7 • Internal Frame Header The following table shows the internal frame header fields, including information whether a field is relevant for injection, extraction, or both. Table 2 • Internal Frame Header Fields | Field Category | Field Name | Bit | Width | Description | |----------------|------------|---------|---------|------------------------------------| | TS | TSTAMP | 223:192 | 32 bits | Arrival time stamp in nanoseconds. | Table 2 • Internal Frame Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |------------------------|----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | DST when | RSV | 191:181 | 11 bits | Reserved field. Must be set to 0. | | FWD.DST_MODE is INJECT | DST PORT_MASK | 180:128 | 53 bits | Injection destination port mask where each bit representing a physical port (only used for injection). | | DST when | RSV | 191:190 | 2 bits | Reserved field. Must be set to 0. | | FWD.DST_MODE is ENCAP | RT_FWD | 189 | 1 bit | Update IP4 TTL and chksum/ip6 Hopcnt. | | | SWAP_MAC | 188 | 1 bit | Instruct rewriter to swap MAC addresses. | | | TAG_TPID | 187:186 | 2 bits | Tag protocol IDs. 0: Standard TPID as specified in VSTAX.TAG.TAG_TYPE. 1: custom1 stag TPID. 2: custom2 stag TPID. 3: custom3 stag TPID. | | | RSV | 185:184 | 2 bits | Reserved field. Must be set to 0. | | | GEN_IDX | 183:174 | 10 bit | Generic index. VSI when GEN_IDX_MODE = 1. | | | GEN_IDX_MODE | 173 | 1 bit | 0: Reserved.<br>1: VSI. | | | PROT_ACTIVE | 172 | 1 bit | Protect is active. | | | PDU_W16_OFFSET | 171:166 | 6 bits | PDU WORD16 (= 2 bytes) offset from W16_POP_CNT to Protocol data unit (PDU). | | | PDU_TYPE | 165:163 | 3 bits | PDU type used to handle OAM, PTP and SAT. 0: None. 1: OAM_Y1731. 2: OAM_MPLS_TP. 3: PTP. 4: IP4_UDP_PTP. 5: IP6_UDP_PTP. 6: Reserved. 7: SAM_SEQ. | | | CL_RSLT | 162:147 | 16 bits | Classified MATCH_ID combined from VCAP CLM and VCAP IS2. Used if the frame is forwarded to the CPU. | | | MPLS_TTL | 146:139 | 8 bits | TTL value for possible use in MPLS label. | | | MDI C CDIT | 138 | 1 bit | SBIT of last popped MPLS label. for | | | MPLS_SBIT | | | possible use in MPLS label. | Table 2 • Internal Frame Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |---------------------------------|----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DST when FWD.DST_MODE is ENCAP | TYPE_AFTER_POP | 134:133 | 2 bits | 0: ETH - Normal Ethernet header, starting with DMAC. 1: CW. First 4 bits: 4: IPv4 header. 6: IPv6 header. Others: MPLS CW (see RFC 4385) 2: MPLS. MPLS shim header follows. | | | W16_POP_CNT | 132:128 | 5 bits | Number of WORD16 (= 2 bytes) to be popped by rewriter, starting from beginning of frame. | | DST when | RSV | 191:183 | 9 bits | Reserved field. Must be set to 0. | | FWD.DST_MODE is "L3UC" | ERLEG | 182:176 | 7 bits | Egress router leg. | | 1300 | NEXT_HOP_DMAC | 175:128 | 48 bits | Next hop DMAC. Only used for unicast routing. | | DST when FWD.DST_MODE is "L3MC" | RSV | 191:152 | 40 bits | Reserved field. Must be set to 0. | | | L3MC_GRP_IDX | 151:142 | 10 bits | IP multicast group used for L3 multicast copies. | | | ERLEG | 141:135 | 7 bits | Egress router leg. | | | COPY_CNT | 134:128 | 7 bits | Number of multicast routed copies. Only used for multicast routing. | | VSTAX | | 127:48 | 80 bits | VStaX. See VStaX Header, page 24. | Table 2 • Internal Frame Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |----------------|----------------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | FWD | AFI_INJ | 47 | 1 bit | Injected into AFI. | | | RSV | 46 | 1 bit | Reserved field. Must be set to 0. | | | ES0_ISDX_KEY_EN<br>A | 45 | 1 bit | Controls use of ISDX in ES0 key. | | | RSV | 44 | 1 bit | Reserved field. Must be set to 0. | | | VSTAX_AVAIL | 43 | 1 bit | Received by ANA with valid VSTAX section. Extract: Frame received by ANA with valid VSTAX section. Inject: Frame to be forwarded based on VSTAX section. | | | UPDATE_FCS | 42 | 1 bit | Forces update of FCS. 0: Does not update FCS. FCS is only updated if frame is modified by hardware. 1: Forces unconditional update of FCS. | | | RSV | 41 | 1 bit | Reserved field. Must be set to 0. | | | DST_MODE | 40:38 | 3 bits | Controls format of IFH.DST. 0: ENCAP 1: L3UC routing 2: L3MC routing 3: INJECT Others: Reserved | | | SFLOW_MARKING | 37 | 1 bit | Frame forwarded to CPU due to sFlow sampling. | | | AGED | 36 | 1 bit | Must be set to 0. Set if frame is aged by QSYS. Only valid for extraction. | | | RX_MIRROR | 35 | 1 bit | Signals that the frame is Rx mirrored. | | | MIRROR_PROBE | 34:33 | 2 bits | Signals mirror probe for mirrored traffic. 0: Not mirrored. 1-3: Mirror probe 0-2. | | | SRC_PORT | 32:27 | 6 bits | Physical source port number. May be set by CPU to non-CPU port number to masquerade another port. | | | DO_NOT_REW | 26 | 1 bit | Controlled by CPU or ANA_CL:PORT:QOS_CFG.KEEP_ENA and prevents the rewriter from making any changes of frames sent to front ports when set. | Table 2 • Internal Frame Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |----------------|--------------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MISC | PIPELINE_ACT | 25:23 | 3 bits | Pipeline action specifies if a frame is injected, extracted, or discarded. 0: None 1: INJ 2: INJ_MASQ 3: Reserved 4: XTR 5: XTR_UPMEP 6: LBK_ASM 7: LBK_QS | | | PIPELINE_PT | 22:18 | 5 bits | Pipeline point specifies the location where a frame is injected, extracted, or discarded. 0: None 1: ANA_VRAP 2: ANA_PORT_VOE 3: ANA_CL 4: ANA_CLM 5: ANA_IPT_PROT 6: ANA_OU_MIP 7: ANA_OU_SW 8: ANA_OU_PROT 9: ANA_OU_VOE 10: ANA_MID_PROT 11: ANA_IN_VOE 12: ANA_IN_SW 14: ANA_IN_SW 14: ANA_IN_MIP 15: ANA_ULAN 16: ANA_DONE 17: REW_IN_MIP 18: REW_IN_SW 19: RE_IN_VOE 20: REW_OU_VOE 21: REW_OU_SW 22: REW_OU_MIP 23: REW_SAT 24: REW_PORT_VOE 25: REW_VRAP | | | CPU_MASK | 17:10 | 8 bits | CPU extraction queue mask. | | TAGGING | POP_CNT | 9:8 | 2 bits | Controlled by CPU or ANA_CL:PORT:VLAN_CTRL.VLAN_POP _CNT or CLM VLAN_POP_CNT_ENA and causes the rewriter to pop the signaled number of consecutive VLAN tags. If ENCAP.W16_POP_CNT >0 and TYPE_AFTER_POP = ETH POP_CNT applies to inner Ethernet layer. | Table 2 • Internal Frame Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |----------------|-------------|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | QOS | TRANSP_DSCP | 7 | 1 bit | Controlled by CPU or ANA_CL:PORT:QOS_CFG. DSCP_KEEP_ENA and prevents the rewriter from remapping DSCP values of frames sent to front ports when set. | | | UPDATE_DSCP | 6 | 1 bit | Controlled by CPU, ANA_CL:PORT:QOS_CFG DSCP_REWR_MODE_SEL, CLM DSCP_ENA or ANA_CL:MAP_TBL: SET_CTRL.DSCP_ENA and causes the rewriter to update the frame's DSCP value with IFH.QOS.DSCP for frames sent to front ports when set. | | | DSCP | 5:0 | 6 bits | DSCP value. | The IFH is only used to control the rewriter on front ports or send to CPU. It is not transmitted with the frame. For CPU ports, the information in the extraction IFH is for reference purposes only. ## 3.3.3 VStaX Header When frames are sent to or from the NPI port, or when connecting multiple switches together, an optional VStaX header is inserted into the frames. The VStaX header consists of a 10-byte payload and is preceded by 2 bytes for the Microsemi EtherType (0x8880). That is, a total of 12 bytes are inserted into the frame, as shown in the following illustration. Figure 8 • Frame With VStaX Header The layout of the 10-byte VStaX header is shown in the following illustration. In VStaX context, each switch in a stack is termed a unit. Figure 9 • VStaX Header Layout The following table describes each field in the VStaX header. Table 3 • VStaX Header Fields | Field Category | Field Name | Bit | Width | Description | |-------------------------------------------------|--------------------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reserved | RSV | 79 | 1 bit | Reserved field. Must be set to 1 when injecting frames and must be checked on extraction. | | MISC when | COSID | 78:76 | 3 bits | Class of service. | | ANA_AC:PS_COMMO<br>N.VSTAX2_MISC_ISD<br>X_ENA=1 | ISDX | 75:64 | 12 bits | Ingress service index. | | MISC when ANA_AC:PS_COMMO | RSV | 78:68 | 11 bits | Reserved field. Must be set to 0 when injecting frames from CPU and ignored on extraction. | | N.VSTAX2_MISC_ISD<br>X_ENA=0 | AC | 67:64 | 4 bits | GLAG aggregation code | | Reserved | RSV | 63:62 | 2 bits | Reserved field. Must be set to 0. | | QOS | CL_DP | 60:61 | 2 bits | Classified drop precedence level. | | | SP | 59 | 1 bit | Super priority. Identifies frames to be forwarded between CPUs of neighboring units, using egress and ingress super priority queues in the assembler and disassembler. | | | CL_QOS (IPRIO) | 58:56 | 3 bits | Classified quality of service value (internal priority). | | | INGR_DROP_MOD<br>E | 55 | 1 bit | Congestion management information. 0: Ingress front port is in flow control mode. 1: Ingress front port is in drop mode. | | Reserved | RSV | 54 | 1 bit | Reserved field. Must be set to 0. | | General | RSV | 53 | 1 bit | Reserved field. Must be set to 0. | | | TTL | 52:48 | 5 bits | Time to live. | | | LRN_MODE | 47 | 1 bit | O: Normal learning. SMAC and VID of the frame is subject to learning. 1: Skip learning. Do not learn SMAC and VID of the frame. | | | FWD_MODE | 46:44 | 3 bits | Forward mode. Encoding: 0x0: FWD_LLOOKUP: Forward using local lookup in every unit. 0x1: FWD_LOGICAL: Forward to logical front port at specific UPS. 0x2: FWD_PHYSICAL: Forward to physical front port at specific UPS. 0x3: FWD_MULTICAST: Forward to ports part of multicast group. 0x4: FWD_GMIRROR: Forward to global mirror port. 0x5: FWD_GCPU_UPS: Forward to GCPU of specific UPS. 0x6: FWD_GCPU_ALL: Forward to all GCPUs. 0x7: Reserved. | | Reserved | RSV | 43 | 1 bit | Reserved field. Must be set to 0. | Table 3 • VStaX Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |----------------------------------------------------------------------|----------------|-------|---------|---------------------------------------------------------------------------------------------------------------------| | VSTAX.DST when<br>VSTAX.FWD_MODE is<br>FWD_LLOOKUP or<br>FWD_GMIRROR | REW_CMD | 42:32 | 11 bits | VCAP IS2 action REW_CMD. | | VSTAX.DST when VSTAX.FWD_MODE is FWD_LOGICAL | DST_PORT_TYPE | 42 | 1 bit | Destination port type. Encoding: 0: Front port 1: Internal port | | | DST_UPSID | 41:37 | 5 bits | Destination unit port set ID. | | | DST_PN | 36:32 | 5 bits | Logical destination port at unit identified by dst_upsid. | | VSTAX.DST when | RSV | 42 | 1 bit | Reserved field. Must be set to 0. | | VSTAX.FWD_MODE is FWD_PHYSICAL | DST_UPSID | 41:37 | 5 bits | Destination unit port set ID. | | - 111 e 10/12 | DST_PN | 36:32 | 5 bits | Physical destination port at unit identified by dst_upsid. | | VSTAX.DST when | RSV | 42 | 1 bit | Reserved field. Must be set to 0. | | VSTAX.FWD_MODE is FWD_MULTICAST | MC_IDX | 41:32 | 10 bits | Forward to ports part of this multicast group index. | | VSTAX.DST when | RSV | 42 | 1 bit | Reserved field. Must be set to 0. | | VSTAX.FWD_MODE is FWD_GCPU_UPS | DST_UPSID | 41:37 | 5 bits | Destination unit port set ID. | | | RSV | 36 | 1 bit | Reserved field. Must be set to 0. | | | DST_PN | 35:32 | 4 bits | CPU destination port at unit identified by dst_upsid. | | VSTAX.DST when | RSV | 42 | 1 bit | Reserved field. Must be set to 0. | | VSTAX.FWD_MODE is FWD_GCPU_ALL | TTL_KEEP | 41 | 1 bit | Special TTL handling used for neighbor discovery. | | | RSV | 40:36 | 5 bits | Reserved field. Must be set to 0. | | | DST_PN | 35:32 | 4 bits | CPU destination port at unit identified by dst_upsid. | | TAG | CL_PCP | 31:29 | 3 bits | Classified priority code point value. | | | CL_DEI | 28 | 1 bit | Classified drop eligible indicator value. | | | CL_VID | 27:16 | 12 bits | Classified VID. | | | WAS_TAGGED | 15 | 1 bit | If set, frame was VLAN-tagged at reception. | | | TAG_TYPE | 14 | 1 bit | Tag type. 0: C-tag (EtherType 0x8100). 1: S-tag (EtherType 0x88A8). | | | INGR_PORT_TYPE | 13:12 | 2 bits | Ingress ports type for private VLANs/Asymmetric VLANs. 00: Promiscuous port. 01: Community port. 10: Isolated port. | Table 3 • VStaX Header Fields (continued) | Field Category | Field Name | Bit | Width | Description | |----------------|---------------|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | SRC | SRC_ADDR_MODE | 10 | 1 bit | O: src_ind_port: Individual port. Source consists of src_upsid and src_upspn. 1: src_glag: Source consists of src_glag. | | | SRC_PORT_TYPE | 11 | 1 bit | Only applicable if src_addr_mode==src_ind_port. Reserved and must be set to 0 if src_addr_mode==src_glag. 0: port_type_upspn. 1: port_type_intpn. | | | SRC_UPSID | 9:5 | 5 bits | If src_addr_mode = src_ind_port: ID of stack unit port set, where the frame was initially received. | | | SRC_UPSPN | 4:0 | 5 bits | If src_addr_mode = src_ind_port and src_port_type = port_type_upspn: Logical port number of the port (on source ups), where the frame was initially received. | | | SRC_INTPN | 3:0 | 4 bits | If src_addr_mode = src_ind_port and src_port_type = port_type_intpn: Internal port number. | | | SRC_GLAGID | 0 | 5 bits | If src_addr_mode = src_glag: ID of the GLAG. | # 3.4 Port Numbering and Mappings The switch core contains an internal port numbering domain where ports are numbered from 0 through 14. A port connects to a port module, which connects to an interface macro, which connects to I/O pins on the device. The port modules are DEV2G5. The interface macros are SERDES1G, SERDES6G, or a copper transceiver. Some ports are internal to the device and do not connect to port modules or interface macros. For example, internal ports are used for frame injection and extraction to the CPU queues. The following table shows the default port numbering and how the ports map to port modules and interface macros. Table 4 • Default Port Numbering and Port Mappings | | | Maximum | | |-------------|----------------|------------|-----------------------| | Port Number | Port Module | Port Speed | Interface Macro | | 0 | DEV2G5_0 | 1 Gbps | SERDES1G_0 or CUPHY_0 | | 1 | DEV2G5_1 | 1 Gbps | SERDES1G_1 or CUPHY_1 | | 2 | DEV2G5_2 | 1 Gbps | SERDES1G_2 | | 3 | DEV2G5_3 | 1 Gbps | SERDES1G_3 | | 4 (NPI) | DEV2G5_4 | 1 Gbps | SERDES1G_4 | | 5 | DEV2G5_5 | 2.5 Gbps | SERDES6G_0 | | 6 | DEV2G5_6 | 2.5 Gbps | SERDES6G_1 | | 11 (CPU0) | No port module | No macro | No macro | | 12 (CPU1) | No port module | No macro | No macro | | 13 (VD0) | No port module | No macro | No macro | | | | | | Table 4 • Default Port Numbering and Port Mappings (continued) | Port Number | Port Module | Maximum<br>Port Speed | Interface Macro | |-------------|----------------|-----------------------|-----------------| | 14 (VD1) | No port module | No macro | No macro | Ports 0 and 1 are dual-media ports and support either a SerDes interface or a copper transceiver. Ports 11 through 14 are internal ports defined as follows: - Port 11 and port 12: CPU port 0 and 1 (CPU0, CPU1) are used for injection and extraction of frames. - Port 13: Virtual device 0 (VD0) is used for multicast routing. - Port 14: Virtual device 1 (VD1) is used for AFI frame injections. The internal ports do not have associated port modules and interface macros. The following table shows the fixed mapping from interface macros to the device I/O pins. Table 5 • Interface Macro to I/O Pin Mapping | SERDES Macros | I/O Pin Names | |--------------------------|-----------------------------------------------------------------------| | CUPHY_0 to CUPHY_1 | P0_D[3:0]N, P0_D[3:0]P through<br>P1_D[3:0]N, P1_D[3:0]P | | SERDES1G_0 to SERDES1G_4 | S0_RXN, S0_RXP, S0_TXN, S0_TXP through S4_RXN, S4_RXP, S4_TXN, S4_TXP | | SERDES6G_0 to SERDES6G_1 | S5_RXN, S5_RXP, S5_TXN, S5_TXP through S6_RXN, S6_RXP, S6_TXN, S6_TXP | # 3.4.1 Supported SerDes Interfaces The device supports a range of SerDes interfaces. The following table lists the SerDes interfaces supported by the SerDes ports, including standards, data rates, connectors, medium, and coding for each interface. Table 6 • Supported SerDes Interfaces | Port Interface | Specification | Port<br>Speed | Data Rate | Connector | Medium | Coding | SERDES1G | SERDES6G | |----------------|------------------------------|---------------|------------|-----------|-------------------|--------|----------|----------| | 100BASE-FX | IEEE 802.3, Clause 24 | 100M | 125 Mbps | SFP | PCB | 4B5B | Х | Х | | SGMII | Cisco | 1G | 1.25 Gbps | | PCB | 8B10B | Х | Х | | SFP | SFP-MSA | 1G | 1.25 Gbps | SFP | PCB | 8B10B | Х | Х | | 1000BASE-KX | IEEE802.3, Clause 70 | 1G | 1.25 Gbps | | PCB,<br>backplane | 8B10B | х | Х | | 2.5G | Proprietary (aligned to SFP) | 2.5G | 3.125 Gbps | | PCB | 8B10B | | Х | #### 3.4.2 Dual-Media Mode Ports 0 and 1 are dual-media ports and support either a 1G copper transceiver or a 1G SERDES interface. The dual-media mode is configurable per port through DEVCPU GCB::PHY CFG.PHY ENA. # 3.4.3 Logical Port Numbers The analyzer and the rewriter uses in many places a logical port number. For instance, when link aggregation is enabled, all ports within a link aggregation group must be configured to use the physical port number of the port with the lowest port number within the group as logical port group ID. The mapping to a logical port number is configured in ANA\_CL:PORT:PORT\_ID\_CFG.LPORT\_NUM and REW::PORT\_CTRL.ES0\_LPORT\_NUM. # 3.5 SERDES1G The SERDES1G is a high-speed SerDes interface that can operate at 1.25 Gbps (SGMII/SerDes, 1000BASE-KX). In addition, 100 Mbps (100BASE-FX) is supported by oversampling. The SERDES1G supports the configuration of several parameters for increased performance in the specific application environment. The features include: - Baudrate support 1.25 Gbps - Programmable loop bandwidth and phase regulation behavior for clock and data recovery unit (CDR) - Input buffer (IB) and output buffer (OB) configurations supporting: - IB Signal Detect/Loss of Signal (LOS) options - IB equalization (including corner frequency configuration) - OB selectable de-emphasis - OB amplitude drive levels - OB slew rate control # 3.6 SERDES6G The SERDES6G is a high-speed SerDes interface, which can operate at the following data rates. - 1.25 Gbps (SGMII/SerDes 1000BASE-KX) - 2.5 Gbps - 100 Mbps (100BASE-FX) is supported by oversampling. The SERDES6G supports the configuration of several parameters for increased performance in the specific application environment. Features include: - Configurable baud rate support from 1.25 Gbps to 2.5 Gbps. - Programmable loop bandwidth and phase regulation behavior for clock and data recovery unit (CDR) - Phase-synchronization of transmitter when used in multilane aggregates for low skew between lanes - Input buffer (IB) and output buffer (OB) configurations supporting: - IB signal detect and loss of signal (LOS) options - IB adaptive equalization - OB programmable de-emphasis, 3 taps - OB amplitude drive levels - OB slew rate control - · Loopbacks for system diagnostics # 3.7 Copper Transceivers This section describes the high-level functionality and operation of two built-in copper transceivers. The integration is kept as close to multichip PHY and switch designs as possible. This allows a fast path for software already running in a similar distributed design while still benefiting from the cost savings provided by the integration. # 3.7.1 Register Access The registers of the integrated transceivers are not placed in the memory map of the switch, but are attached instead to the built-in MII management controller 0 of the device. As a result, PHY registers are accessed indirectly through the switch registers. For more information, see MII Management Controller, page 353. In addition to providing the IEEE 802.3 specified 16 MII Standard Set registers, the PHYs contain an extended set of registers that provide additional functionality. The devices support the following types of registers: IEEE Clause 22 device registers with addresses from 0 to 31 - Two pages of extended registers with addresses from 16E1 through 30E1 and 16E2 through 30E2 - · General-purpose registers with addresses from 0G to 30G - IEEE Clause 45 device registers accessible through the Clause 22 registers 13 and 14 to support IEEE 802.3az Energy Efficient Ethernet registers The memory mapping is controlled through PHY\_MEMORY\_PAGE\_ACCESS::PAGE\_ACCESS\_CFG. The following illustration shows the relationship between the device registers and their address spaces. Figure 10 • Register Space Layout #### 3.7.1.1 Broadcast Write The PHYs can be configured to accept MII PHY register write operations, regardless of the destination address of these writes. This is enabled in PHY\_CTRL\_STAT\_EXT::BROADCAST\_WRITE\_ENA. This enabling allows similar configurations to be sent quickly to multiple PHYs without having to do repeated MII PHY write operations. This feature applies only to writes; MII PHY register read operations are still interpreted with "correct" address. #### 3.7.1.2 Register Reset The PHY can be reset through software, enabled in PHY\_CTRL::SOFTWARE\_RESET\_ENA. Enabling this field initiates a software reset of the PHY. Fields that are not described as sticky are returned to their default values. Fields that are described as sticky are only returned to defaults if sticky-reset is disabled through PHY\_CTRL\_STAT\_EXT::STICKY\_RESET\_ENA. Otherwise, they retain their values from prior to the software reset. A hardware reset always brings all PHY registers back to their default values. ## 3.7.2 Cat5 Twisted Pair Media Interface The twisted pair interfaces are compliant with IEEE 802.3-2008 and IEEE 802.3az for Energy Efficient Ethernet. #### 3.7.2.1 Voltage-Mode Line Driver Unlike many other gigabit PHYs, this PHY uses a patented voltage-mode line driver that allows it to fully integrate the series termination resistors (required to connect the PHY's Cat5 interface to an external 1:1 transformer). Also, the interface does not require placement of an external voltage on the center tap of the magnetic. The following illustration shows the connections. Figure 11 • Cat5 Media Interface # 3.7.2.2 Cat5 Auto-Negotiation and Parallel Detection The integrated transceivers support twisted pair auto-negotiation as defined by clause 28 of the IEEE 802.3-2008. The auto-negotiation process evaluates the advertised capabilities of the local PHY and its link partner to determine the best possible operating mode. In particular, auto-negotiation can determine speed, duplex configuration, and master or slave operating modes for 1000BASE-TX. Auto-negotiation also allows the device to communicate with the link partner (through the optional "next pages") to set attributes that may not otherwise be defined by the IEEE standard. If the Cat5 link partner does not support auto-negotiation, the device automatically use parallel detection to select the appropriate link speed. Auto-negotiation can be disabled by clearing PHY\_CTRL.AUTONEG\_ENA. If auto-negotiation is disabled, the state of the SPEED\_SEL\_MSB\_CFG, SPEED\_SEL\_LSB\_CFG, and DUPLEX\_MODE\_CFG fields in the PHY\_CTRL register determine the device's operating speed and duplex mode. Note that while 10BASE-T and 100BASE-T do not require auto-negotiation, 1000BASE-T does require it (defined by clause 40). # 3.7.2.3 1000BASE-T Forced Mode Support The integrated transceivers provides support for a 1000BASE-T forced test mode. In this mode, the PHY can be forced into 1000BASE-T mode and does not require manual setting of master/slave at the two ends of the link. This mode is only for test purposes. Do not use in normal operation. To configure a PHY in this mode, set PHY\_EEE\_CTRL.FORCE\_1000BT\_ENA = 1, with PHY\_CTRL.SPEED\_SEL\_LSB\_CFG = 1 and PHY\_CTRL.SPEED\_SEL\_LSB\_CFG = 0. #### 3.7.2.4 Automatic Crossover and Polarity Detection For trouble-free configuration and management of Ethernet links, the integrated transceivers include a robust automatic crossover detection feature for all three speeds on the twisted-pair interface (10BASE-T, 100BASE-T, and 1000BASE-T). Known as HP Auto-MDIX, the function is fully compliant with clause 40 of the IEEE 802.3-2002. Additionally, the device detects and corrects polarity errors on all MDI pairs—a useful capability that exceeds the requirements of the standard. Both HP Auto-MDIX detection and polarity correction are enabled in the device by default. Default settings can be changed using the POL\_INV\_DIS and PAIR\_SWAP\_DIS fields in the PHY\_BYPASS\_CTRL register. Status bits for each of these functions are located in the PHY\_AUX\_CTRL\_STAT register. The integrated transceivers can be configured to perform HP Auto-MDIX, even when auto-negotiation is disabled (PHY\_CTRL.AUTONEG\_ENA = 0) and the link is forced into 10/100 speeds. To enable the HP Auto-MDIX feature, set PHY\_BYPASS\_CTRL.FORCED\_SPEED\_AUTO\_MDIX\_DIS to 0. The HP Auto-MDIX algorithm successfully detects, corrects, and operates with any of the MDI wiring pair combinations listed in the following table. Table 7 • Supported MDI Pair Combinations | 1, 2 | 3, 6 | 4, 5 | 7, 8 | Mode | |------|------|------|------|---------------------------------------------| | Α | В | С | D | Normal MDI | | В | А | D | С | Normal MDI-X | | A | В | D | С | Normal MDI with pair swap on C and D pair | | В | Α | С | D | Normal MDI-X with pair swap on C and D pair | #### 3.7.2.5 Manual MDI/MDI-X Setting As an alternative to HP Auto-MDIX detection, the PHY can be forced to be MDI or MDI X using PHY\_EXT\_MODE\_CTRL.FORCE\_MDI\_CROSSOVER\_ENA. Setting this field to 10 forces MDI, and setting 11 forces MDI-X. Leaving the bits 00 enables the MDI/MDI-X setting to be based on FORCED\_SPEED\_AUTO\_MDIX\_DIS and PAIR\_SWAP\_DIS in the register PHY\_BYPASS\_CTRL. ## 3.7.2.6 Link Speed Downshift For operation in cabling environments that are incompatible with 1000BASE-T, the device provides an automatic link speed "downshift" option. When enabled, the device automatically changes its 1000BASE-T auto-negotiation advertisement to the next slower speed after a set number of failed attempts at 1000BASE-T. No reset is required to exit this state if a subsequent link partner with 1000BASE-T support is connected. This is useful in setting up in networks using older cable installations that may include only pairs A and B and not pairs C and D. Link speed downshifting is configured and monitored using SPEED\_DOWNSHIFT\_STAT, SPEED\_DOWNSHIFT\_CFG, and SPEED\_DOWNSHIFT\_ENA in the register PHY\_CTRL\_EXT3. ## 3.7.2.7 Energy Efficient Ethernet The integrated transceivers support IEEE 802.3az Energy Efficient Ethernet (EEE). This standard provides a method for reducing power consumption on an Ethernet link during times of low use. Figure 12 • Low Power Idle Operation Using LPI, the usage model for the link is to transmit data as fast as possible and then return to a low power idle state. Energy is saved on the link by cycling between active and low power idle states. Power is reduced during LPI by turning off unused circuits and, using this method, energy use scales with bandwidth utilization. The transceivers use LPI to optimize power dissipation in 100BASE-TX and 1000BASE-T operation. In addition, IEEE 802.3az defines a 10BASE-Te mode that reduces transmit signal amplitude from 5 V to approximately 3.3 V, peak-to-peak. This mode reduces power consumption in 10 Mbps link speed and can fully interoperate with legacy 10BASE-T compliant PHYs over 100 m Cat5 cable or better. To configure the transceivers in 10BASE-Te mode, set PHY\_EEE\_CTRL.EEE\_LPI\_RX\_100BTX\_DIS to 1 for each port. Additional Energy Efficient Ethernet features are controlled through Clause 45 registers as defined in Clause 45 registers to Support Energy Efficient Ethernet #### 3.7.3 Wake-On-LAN and SecureOn The device supports Wake-on-LAN, an Ethernet networking standard to awaken hosts by using a "magic packet" that is decoded to ascertain the source, and then assert an interrupt pin or an LED. The device also supports SecureOn to secure Wake-on-LAN against unauthorized access. The following illustration shows an overview of the Wake-on-LAN functionality. Figure 13 • Wake-On-LAN Functionality Wake-on-LAN detection is available in 10BASE-T, 100BASE-TX, and 1000BASE-T modes., It is enabled by setting the interrupt mask register PHY\_INT\_MASK. WOL\_INT\_ENA and its status is read in the interrupt status register PHY\_INT\_STAT. WOL\_INT\_PEND. Wake-on-LAN and SecureOn are configured for each port using the PHY\_WOL\_MDINT\_CTRL register. The MAC address for each port is saved in its local register space (PHY\_WOL\_MAC\_ADDRx). ## 3.7.4 Ethernet Inline Powered Devices The integrated transceivers can detect legacy inline powered devices in Ethernet network applications. The inline powered detection capability can be part of a system that allows for IP-phone and other devices, such as wireless access points, to receive power directly from their Ethernet cable, similar to office digital phones receiving power from a Private Branch Exchange (PBX) office switch over the telephone cabling. This can eliminate the need of an external power supply for an IP-phone. It also enables the inline powered device to remain active during a power outage (assuming the Ethernet switch is connected to an uninterrupted power supply, battery, back-up power generator, or some other uninterruptable power source). The following illustration shows an example of this type of application. Figure 14 • Inline Powered Ethernet Switch The following procedure describes the process that an Ethernet switch must perform to process inline power requests made by a link partner (LP); that is, in turn, capable of receiving inline power. - Enables the inline powered device detection mode on each transceiver using its serial management interface. Set PHY CTRL EXT4.INLINE POW DET ENA to 1. - Ensures that the Auto-Negotiation Enable bit (register 0.12) is also set to 1. In the application, the device sends a special Fast Link Pulse (FLP) signal to the LP. Reading PHY\_CTRL\_EXT4.INLINE\_POW\_DET\_STAT returns 00 during the search for devices that require Power-over-Ethernet (PoE). - 3. The transceiver monitors its inputs for the FLP signal looped back by the LP. An LP capable of receiving PoE loops back the FLP pulses when the LP is in a powered down state. This is reported when PHY\_CTRL\_EXT4.INLINE\_POW\_DET\_STAT reads back 01. If an LP device does not loop back the FLP after a specific time, PHY\_CTRL\_EXT4.INLINE\_POW\_DET\_STAT automatically resets to 10. - 4. If the transceiver reports that the LP needs PoE, the Ethernet switch must enable inline power on this port, externally of the PHY. - The PHY automatically disables inline powered device detection if PHY\_CTRL\_EXT4.INLINE\_POW\_DET\_STAT automatically resets to 10, and then automatically changes to its normal auto-negotiation process. A link is then auto-negotiated and established when the link status bit is set (PHY\_STAT.LINK\_STAT is set to 1). - 6. In the event of a link failure (indicated when PHY\_STAT.LINK\_STAT reads 0), the inline power must be disabled to the inline powered device external to the PHY. The transceiver disables its normal auto-negotiation process and re-enables its inline powered device detection mode. # 3.7.5 IEEE 802.3af PoE Support The integrated transceivers are also compatible with switch designs intended for use in systems that supply power to Data Terminal Equipment (DTE) by means of the MDI or twisted pair cable, as described in clause 33 of the IEEE 802.3af. # 3.7.6 ActiPHY™ Power Management In addition to the IEEE-specified power-down control bit (PHY\_CTRL.POWER\_DOWN\_ENA), the device also includes an ActiPHY power management mode for each PHY. The ActiPHY mode enables support for power-sensitive applications. It uses a signal detect function that monitors the media interface for the presence of a link to determine when to automatically power-down the PHY. The PHY "wakes up" at a programmable interval and attempts to wake-up the link partner PHY by sending a burst of FLP over copper media. The ActiPHY power management mode in the integrated transceivers is enabled on a per-port basis during normal operation at any time by setting PHY AUX CTRL STAT.ACTIPHY ENA to 1. Three operating states are possible when ActiPHY mode is enabled: - Low power state - LP wake-up state - Normal operating state (link up state) The PHY switches between the low power state and the LP wake-up state at a programmable rate (the default is two seconds) until signal energy is detected on the media interface pins. When signal energy is detected, the PHY enters the normal operating state. If the PHY is in its normal operating state and the link fails, the PHY returns to the low power state after the expiration of the link status time-out timer. After reset, the PHY enters the low power state. When auto-negotiation is enabled in the PHY, the ActiPHY state machine operates as described. If auto-negotiation is disabled and the link is forced to use 10BT or 100BTX modes while the PHY is in its low power state, the PHY continues to transition between the low power and LP wake-up states until signal energy is detected on the media pins. At that time, the PHY transitions to the normal operating state and stays in that state even when the link is dropped. If auto-negotiation is disabled while the PHY is in the normal operation state, the PHY stays in that state when the link is dropped and does not transition back to the low power state. The following illustration shows the relationship between ActiPHY states and timers. Figure 15 • ActiPHY State Diagram #### 3.7.6.1 Low Power State All major digital blocks are powered down in the lower power state. In this state, the PHY monitors the media interface pins for signal energy. The PHY comes out of low power state and transitions to the normal operating state when signal energy is detected on the media. This happens when the PHY is connected to one of the following: Auto-negotiation capable link partner Another PHY in enhanced ActiPHY LP wake-up state In the absence of signal energy on the media pins, the PHY transitions from the low power state to the LP wake-up state periodically based on the programmable sleep timer (PHY\_CTRL\_EXT3.ACTIPHY\_SLEEP\_TIMER). The actual sleep time duration is random, from –80 ms to 60 ms, to avoid two linked PHYs in ActiPHY mode entering a lock-up state during operation. After sending signal energy on the relevant media, the PHY returns to the low power state. ## 3.7.6.2 Link Partner Wake-up State In the link partner wake-up state, the PHY attempts to wake up the link partner. Up to three complete FLP bursts are sent on alternating pairs A and B of the Cat5 media for a duration based on the wake-up timer, which is set using register bits 20E1.12:11. After sending signal energy on the relevant media, the PHY returns to the low power state. ## 3.7.6.3 Normal Operating State In normal operation, the PHY establishes a link with a link partner. When the media is unplugged or the link partner is powered down, the PHY waits for the duration of the programmable link status time-out timer, which is set using ACTIPHY\_LINK\_TIMER\_MSB\_CFG and ACTIPHY\_LINK\_TIMER\_LSB\_CFG in the PHY AUX CTRL STAT register. It then enters the low power state. # 3.7.7 Testing Features The integrated transceivers include several testing features designed to facilitate performing system-level debugging. #### 3.7.7.1 Ethernet Packet Generator (EPG) The Ethernet Packet Generator (EPG) can be used at each of the 10/100/1000BASE-T speed settings for copper Cat5 media to isolate problems between the MAC and the PHY, or between a local PHY and its remote link partner. Enabling the EPG feature effectively disables all MAC interface transmit pins and selects the EPG as the source for all data transmitted onto the twisted pair interface. **Important** The EPG is intended for use with laboratory or in-system testing equipment only. Do not use the EPG testing feature when the PHY is connected to a live network. To use the EPG feature, set PHY 1000BT EPG2.EPG ENA to 1. When PHY\_1000BT\_EPG2.EPG\_RUN\_ENA is set to 1, the PHY begins transmitting Ethernet packets based on the settings in the PHY\_1000BT\_EPG1 and PHY\_1000BT\_EPG2 registers. These registers set: - · Source and destination addresses for each packet - · Packet size - Inter-packet gap - FCS state - · Transmit duration - Payload pattern If PHY\_1000BT\_EPG1.TRANSMIT\_DURATION\_CFG is set to 0, PHY\_1000BT\_EPG1.EPG\_RUN\_ENA is cleared automatically after 30,000,000 packets are transmitted. #### 3.7.7.2 CRC Counters Two separate CRC counters are available in the PHY: a 14-bit good CRC counter available through PHY\_CRC\_GOOD\_CNT.CRC\_GOOD\_PKT\_CNT and a separate 8-bit bad CRC counter in PHY\_CTRL\_EXT4.CRC\_1000BT\_CNT. ## 3.7.7.3 Far-End Loopback The far-end loopback testing feature is enabled by setting PHY\_CTRL\_EXT1.FAR\_END\_LOOPBACK\_ENA to 1. When enabled, it forces incoming data from a link partner on the current media interface, into the MAC interface of the PHY, to be re-transmitted back to the link partner on the media interface as shown in the following illustration. The incoming data also appears on the receive data pins of the MAC interface. Data present on the transmit data pins of the MAC interface is ignored when using this testing feature. Figure 16 • Far-End Loopback Diagram ## 3.7.7.4 Near-End Loopback When the near-end loopback testing feature is enabled (by setting PHY\_CTRL.LOOPBACK\_ENA to 1), data on the transmit data pins (TXD) is looped back in the PCS block, onto the device receive data pins (RXD), as shown in the following illustration. When using this testing feature, no data is transmitted over the network. Figure 17 • Near-End Loopback Diagram ## 3.7.7.5 Connector Loopback The connector loopback testing feature allows the twisted pair interface to be looped back externally. When using the connector loopback feature, the PHY must be connected to a loopback connector or a loopback cable. Pair A must be connected to pair B, and pair C to pair D, as shown in the following illustration. The connector loopback feature functions at all available interface speeds. Figure 18 • Connector Loopback Diagram When using the connector loopback testing feature, the device auto-negotiation, speed, and duplex configuration is set using device registers 0, 4, and 9. For 1000BASE-T connector loopback, the following additional writes are required, executed in the following steps: - Enable the 1000BASE-T connector loopback. Set PHY\_CTRL\_EXT2.CON\_LOOPBACK\_1000BT\_ENA to 1. - 2. Disable pair swap correction. Set PHY\_CTRL\_EXT2.CON\_LOOPBACK\_1000BT\_ENA to 1. # 3.7.8 VeriPHY™ Cable Diagnostics The integrated transceivers include a comprehensive suite of cable diagnostic functions that are available through the on-board processor. These functions enable cable operating conditions and status to be accessed and checked. The VeriPHY suite has the ability to identify the cable length and operating conditions and to isolate common faults that can occur on the Cat5 twisted pair cabling. For the functional details of the VeriPHY suite and the operating instructions, see the *ENT-AN0125*, *PHY*, *Integrated PHY-Switch VeriPHY - Cable Diagnostics Feature* Application Note. # 3.8 DEV1G and DEV2G5 Port Modules The DEV1G and DEV2G5 port modules are essentially the same with identical configurations. The only difference is the bandwidth of the bus connecting the port module to the assembler. A DEV2G5 port module can forward data at 2.5 Gbps while the DEV1G port module can forward data at 1 Gbps. The bandwidth of the port module is configured in the SERDES macro connecting to the port module. #### 3.8.1 MAC This section describes the high level functions and configuration options of the Media Access controller (MAC) used in the DEV1G and DEV2G5 port modules. The DEV1G MAC supports 10/100/1000 Mbps in full-duplex mode and 10/100 Mbps in half-duplex mode. For the DEV2G5 MAC, the supported speeds and duplex modes depend on the following associated SERDES macro: - SERDES1G: 10/100/1000 Mbps in full-duplex mode and 10/100 Mbps in half-duplex mode. - SERDES6G: 10/100/1000/2500 Mbps in full-duplex mode and 10/100 Mbps in half-duplex mode. - SERDES10G: 10/100/1000/2500 Mbps in full-duplex mode and 10/100 Mbps in half-duplex mode. The following table lists the registers associated with configuring the MAC. Table 8 • DEV1G and DEV2G5 MAC Configuration Registers Overview | Register | Description | Replication | |-----------------|--------------------------------------------------------------|-----------------| | MAC_ENA_CFG | Enabling of Rx and Tx data paths | Per port module | | MAC_MODE_CFG | Port mode configuration | Per port module | | MAC_MAXLEN_CFG | Maximum length configuration | Per port module | | MAC_TAGS_CFG | VLAN/service tag configuration | Per port module | | MAC_TAGS_CFG2 | VLAN/service tag configuration 2 | Per port module | | MAC_ADV_CHK_CFG | Configuration to enable dropping of Type/Length error frames | Per port module | | MAC_IFG_CFG | Inter-frame gap configuration | Per port module | | MAC_HDX_CFG | Half-duplex configuration | Per port module | | MAC_STICKY | Sticky bit recordings | Per port module | #### 3.8.1.1 Clock and Reset There is a number of resets in the port module. All of the resets can be set and cleared simultaneously. By default, all blocks are in the reset state. With reference to DEV\_RST\_CTRL register, the resets are as listed in the following table. Table 9 • DEV1G and DEV2G5 Reset | Register.Field | Description | |-------------------------|-----------------------| | DEV_RST_CTRL.MAC_RX_RST | Reset MAC receiver | | DEV_RST_CTRL.MAC_TX_RST | Reset MAC transmitter | | DEV_RST_CTRL.PCS_RX_RST | Reset PCS receiver | | DEV_RST_CTRL.PCS_TX_RST | Reset PCS transmitter | When changing the MAC configuration, the port must go through a reset cycle. This is done by writing register DEV RST CTRL twice. On the first write, the reset bits are set. On the second write, the reset bits are cleared. The non-reset field DEV\_RST\_CTRL.SPEED\_SEL must keep its new value for both writes. ## 3.8.1.2 Interrupts The following table lists the eight interrupt sources defined for DEV1G and DEV2G5 port modules. For more information about general interrupt handling, see Interrupt Controller, page 367. Table 10 • DEV1G and DEV2G5 Interrupt Sources Register Overview | Register.Field | Description | |------------------------------------|----------------------------------------| | DEV1G_INTR.FEF_FOUND_INTR_STICKY | Far-end-fault indication found | | DEV1G_INTR.TX_LPI_INTR_STICKY | Low power idle transmit interrupt | | DEV1G_INTR.RX_LPI_INTR_STICKY | Low power idle receive interrupt | | DEV1G_INTR.AN_PAGE_RX_INTR_STICKY | New page event received by ANEG | | DEV1G_INTR.AN_LINK_UP_INTR_STICKY | ANEG - Link status has changed to up | | DEV1G_INTR.AN_LINK_DWN_INTR_STICKY | ANEG - Link status has changed to down | | DEV1G_INTR.LINK_UP_INTR_STICKY | Link status is up | | DEV1G_INTR. LINK_DWN_INTR_STICKY | Link status is down | # 3.8.1.3 Port Mode Configuration The MAC provides a number of handles for configuring the port mode. With reference to the MAC\_MODE\_CFG, MAC\_IFG\_CFG, and MAC\_ENA\_CFG registers, the handles are as listed in the following table. Table 11 • DEV1G and DEV2G5 Port Mode Configuration Registers Overview | Register.Field | Description | |------------------------|-----------------------------------------| | MAC_MODE_CFG.FDX_ENA | Enables full-duplex mode | | MAC_ENA_CFG.RX_ENA | Enables MAC receiver module | | MAC_ENA_CFG.TX_ENA | Enables MAC transmitter module | | MAC_IFG_CFG.TX_IFG | Adjusts inter frame gap in Tx direction | | DEV_RST_CTRL.SPEED_SEL | Configures port speed and data rate | Clearing MAC\_ENA\_CFG.RX\_ENA stops the reception of frames and further frames are discarded. An ongoing frame reception is interrupted. Clearing MAC\_ENA\_CFG.TX\_ENA stops the dequeueing of frames from the egress queues, which means that frames are held back in the egress queues. An ongoing frame transmission is completed. TX inter-frame gap (MAC\_IFG\_CFG.TX\_IFG) must be set according to selected speed and mode to achieve 12 bytes IFG. # 3.8.2 Half-Duplex Mode The following special configuration options are available for half-duplex (HDX) mode. - Seed for back-off randomizer. MAC\_HDX\_CFG.SEED seeds the randomizer used by the back-off algorithm. Use MAC\_HDX\_CFG.SEED\_LOAD to load a new seed value. - Retransmission of frame after excessive collision. MAC\_HDX\_CFG.RETRY\_AFTER\_EXC\_COL\_ENA determines whether the MAC retransmits frames after an excessive collision has occurred. If set, a frame is not dropped after excessive collisions, but the back-off sequence is restarted. This is a violation of IEEE 802.3, but is useful in non-dropping half-duplex flow control operation. - Late collision timing. MAC\_HDX\_CFG.LATE\_COL\_POS adjusts the border between a collision and a late collision in steps of 1 byte. According to IEEE 802.3, section 21.3, this border is permitted to be on data byte 56 (counting frame data from 1); that is, a frame experiencing a collision on data byte 55 is always retransmitted, but it is never retransmitted when the collision is on byte 57. For each higher LATE\_COL\_POS value, the border is moved 1 byte higher. - Rx-to-Tx inter-frame gap. The sum of MAC\_IFG\_CFG.RX\_IFG1 and MAC\_IFG\_CFG.RX\_IFG2 establishes the time for the Rx-to-Tx inter-frame gap. RX\_IFG1 is the first part of half-duplex Rx-to Tx inter-frame gap. Within RX\_IFG1, this timing is restarted if carrier sense (CRS) has multiple high low transitions (due to noise). RX\_IFG2 is the second part of half-duplex Rx-to-Tx inter-frame gap. Within RX\_IFG2, transitions on CRS are ignored. ## 3.8.2.1 Type/Length Check The MAC supports frame lengths of up to 14,000 bytes. The maximum frame accepted by the MAC is configurable and defined in MAC\_MAXLEN\_CFG.MAX\_LEN. The MAC allows 1/2/3 tagged frames to be 4/8/12 bytes longer respectively, than the specified maximum length, with MAC\_TAGS\_CFG.VLAN\_LEN\_AWR\_ENA. The MAC must be configured to look for VLAN tags (MAC\_TAGS\_CFG.VLAN\_AWR\_ENA). By default, EtherType 0x8100 and 0x88A8 are identified as VLAN tags. In addition, three custom EtherTypes can be configured by MAC\_TAGS\_CFG.TAG\_ID, MAC\_TAGS\_CFG2.TAG\_ID2, and MAC\_TAGS\_CFG2.TAG\_ID3. If a received frame exceeds the maximum length, the frame is truncated and marked as aborted. The MAC can drop frames with in-range and out-of-range length errors by enabling MAC\_ADV\_CHK\_CFG.LEN\_DROP\_ENA. # 3.8.3 Physical Coding Sublayer (PCS) This section provides information about the Physical Coding Sublayer (PCS) block, where the autonegotiation process establishes mode of operation for a link. The PCS supports an SGMII mode and two SerDes modes, 1000BASE-X and 100BASE-FX. The following table lists the registers associated with the PCS. Table 12 • DEV1G and DEV2G5 PCS Configuration Registers Overview | Register | Description | Replication | |----------------------|----------------------------------------------------------------|-------------| | PCS1G_CFG | PCS configuration | Per PCS | | PCS1G_MODE_CFG | PCS mode configuration | Per PCS | | PCS1G_SD_CFG | Signal Detect configuration | Per PCS | | PCS1G_ANEG_CFG | Auto-negotiation configuration register | Per PCS | | PCS1G_ANEG_NP_CFG | Auto-negotiation next page configuration | Per PCS | | PCS1G_LB_CFG | Loopback configuration | Per PCS | | PCS1G_ANEG_STATUS | Status signaling of PCS auto-negotiation process | Per PCS | | PCS1G_ANEG_NP_STATUS | Status signaling of the PCS auto-negotiation next page process | Per PCS | | PCS1G_LINK_STATUS | Link status | Per PCS | | PCS1G_LINK_DOWN_CNT | Link down counter | Per PCS | | PCS1G_STICKY | Sticky bit register | Per PCS | The PCS is enabled in PCS1G\_CFG.PCS\_ENA and PCS1G\_MODE\_CFG.SGMII\_MODE\_ENA selects between the SGMII and SerDes mode. For information about enabling 100BASE-FX, see 100BASE-FX. The PCS supports the IEEE 802.3, Clause 66 unidirectional mode, where the transmission of data is independent of the state of the receive link (PCS1G\_MODE\_CFG.UNIDIR\_MODE\_ENA). #### 3.8.3.1 Auto-Negotiation Auto-negotiation is enabled with PCS1G\_ANEG\_CFG.ANEG\_ENA. To restart the auto-negotiation process, PCS1G\_ANEG\_CFG.ANEG\_RESTART\_ONE\_SHOT must be set. In SGMII mode (PCS1G\_MODE\_CFG.SGMII\_MODE\_ENA = 1), matching the duplex mode with the link partner must be ignored (PCS1G\_ANEG\_CFG.SW\_RESOLVE\_ENA). Otherwise the link is kept down when the auto-negotiation process fails. The advertised word for the auto-negotiation process (base page) is configured in PCS1G\_ANEG\_CFG.ADV\_ABILITY. The next page information is configured in PCS1G\_ANEG\_NP\_CFG.NP\_TX. When the auto-negotiation state machine has exchanged base page abilities, the PCS1G\_ANEG\_STATUS.PAGE\_RX\_STICKY is asserted indicating that the link partner's abilities were received (PCS1G\_ANEG\_STATUS.LP\_ADV\_ABILITY). If next page information need to be exchanged (only available in SerDes model, that is, PCS1G\_MODE\_CFG.SGMII\_MODE\_ENA = 0), PAGE\_RX\_STICKY must be cleared, next page abilities must be written to PCS1G\_ANEG\_NP\_CFG.NP\_TX, and PCS1G\_ANEG\_NP\_CFG.NP\_LOADED\_ONE\_SHOT must be set. When the auto-negotiation state machine has exchanged the next page abilities, the PCS1G\_ANEG\_STATUS.PAGE\_RX\_STICKY is asserted again indicating that the link partner's next page abilities were received (PCS1G\_ANEG\_STATUS.LP\_NP\_RX). Additional exchanges of next page information are possible using the same procedure. Next page engagement is coded in bit 15 of Base Page of Next page information. After the last next page has been received, the auto-negotiation state machine enters the IDLE\_DETECT state, and the PCS1G\_ANEG\_STATUS.PR bit is set indicating that ability information exchange (base page and possible next pages) has finished and software can now resolve priority. Appropriate actions, such as Rx or Tx reset or auto-negotiation restart, can then be taken based on the negotiated abilities. The LINK\_OK state is reached one link timer period later. When the auto-negotiation process reached the LINK\_OK state, PCS1G\_ANEG\_STATUS.ANEG\_COMPLETE is asserted. #### 3.8.3.2 Link Surveillance The current link status can be observed through PCS1G\_LINK\_STATUS.LINK\_STATUS. The LINK\_STATUS is defined as either the PCS synchronization state or as bit 15 of PCS1G\_ANEG\_STATUS.LP\_ADV\_ABILITY, which carries information about the link status in SGMII mode. Link down is defined as the auto-negotiation state machine being in neither the AN\_DISABLE\_LINK\_OK state nor the LINK\_OK state for one link timer period. If a link down event occurred, PCS1G\_STICKY.LINK\_DOWN\_STICKY is set and PCS1G\_LINK\_DOWN\_CNT is incremented. In SGMII mode, the link timer period is 1.6 ms, whereas in SerDes mode, the link timer period is 10 ms. The PCS synchronization state can be observed through PCS1G\_LINK\_STATUS.SYNC\_STATUS. Synchronization is lost when the PCS is not able to recover and decode data received from the attached serial link. #### 3.8.3.3 Signal Detect The PCS can be enabled to react to loss of signal through signal detect (PCS1G\_SD\_CFG.SD\_ENA). Upon loss of signal, the PCS Rx state machine is restarted, and frame reception stops. If signal detect is disabled, no action is taken upon loss of signal. The polarity of signal detect is configurable in PCS1G\_SD\_CFG.SD\_POL. The source of signal detect is selected in PCS1G\_SD\_CFG.SD\_SEL to either the SerDes PMA or the PMD receiver. If the SerDes PMA is used as source, the SerDes macro provides the signal detect. If the PMD receiver is used as source, signal detect is sampled externally through one of the GPIO pins on the device. For more information about the configuration of the GPIOs and signal detect, see Parallel Signal Detect, page 357. PCS1G LINK STATUS.SIGNAL DETECT contains the current value of the signal detect input. #### 3.8.3.4 Tx Loopback For debug purposes, the Tx data path in the PCS can be looped back into the Rx data path. This is enabled through PCS1G\_LB\_CFG.TBI\_HOST\_LB\_ENA. #### 3.8.3.5 Test Patterns The following table lists the DEV1G and DEV2G5 registers associated with configuring test patterns. Table 13 • DEV1G and DEV2G5 PCS Test Pattern Configuration Registers | Register | Description | Replication | |-----------------------|----------------------------|-------------| | PCS1G_TSTPAT_MODE_CFG | Test pattern configuration | Per PCS | | PCS1G_TSTPAT_STATUS | Test pattern status | Per PCS | PCS1G\_TSTPAT\_MODE\_CFG.JTP\_SEL overwrites normal operation of the PCS and enables generation of jitter test patterns for debug. The jitter test patterns are defined in IEEE 802.3, Annex 36A. The following patterns are supported. - · High frequency test pattern - · Low frequency test pattern - · Mixed frequency test pattern - Continuous random test pattern with long frames - · Continuous random test pattern with short frames The PCS1G\_TSTPAT\_MODE\_STATUS register holds information about error and lock conditions while running the jitter test patterns. #### 3.8.3.6 Low Power Idle The following table lists the registers associated with Energy Efficient Ethernet (EEE) configuration and status in PCS. Table 14 • DEV1G and DEV2G5 PCS EEE Configuration Registers Overview | Register | Description | Replication | |--------------------------|-------------------------------------------------|-------------| | PCS1G_LPI_CFG | Configuration of the PCS low power idle process | Per PCS | | PCS1G_LPI_WAKE_ERROR_CNT | Wake error counter | Per PCS | | PCS1G_LPI_STATUS | Low power idle status | Per PCS | The PCS supports Energy Efficient Ethernet (EEE) as defined by IEEE 802.3az. The PCS converts low power idle (LPI) encoding between the MAC and the serial interface transparently. In addition, the PCS provides control signals to stop data transmission in the SerDes macro. During low power idles, the serial transmitter in the SerDes macro can be powered down, only interrupted periodically while transmitting refresh information, which allows the receiver to notice that the link is still up but in power-down mode. For more information about powering down the serial transmitter in the SerDes macro, see SERDES1G, page 30 or SERDES6G, page 30. It is not necessary to enable the PCS for EEE, because it is controlled indirectly by the shared queue system. It is possible, however, to manually force the PCS into the low power idle mode through PCS1G\_LPI\_CFG.TX\_ASSERT\_LPIDLE. During LPI mode, the PCS constantly encodes low power idle with periodical refreshes. For more information about EEE, see Energy Efficient Ethernet, page 296. The current low power idle state can be observed through PCS1G\_LPI\_STATUS for both receiver and transmitter: - RX LPI MODE: Set if the receiver is in low power idle mode. - RX\_QUIET: Set if the receiver is in the quiet state of the low power idle mode. If cleared while RX\_LPI\_MODE is set, the receiver is in the refresh state of the low power idle mode. The same is observable for the transmitter through TX LPI MODE and TX QUIET. If an LPI symbol is received, the RX\_LPI\_EVENT\_STICKY bit is set, and if an LPI symbol is transmitted, the TX\_LPI\_EVENT\_STICKY bit is set. These events are sticky. The PCS1G\_LPI\_WAKE\_ERROR\_CNT wake-up error counter increments when the receiver detects a signal and the PCS is not synchronized. This can happen when the transmitter fails to observe the wake-up time or if the receiver is not able to synchronize in time. #### 3.8.3.7 100BASE-FX The following table lists the registers associated with 100BASE-FX. Table 15 • DEV1G and DEV2G5 100BASE-FX Configuration Registers Overview | Register | Description | Replication | |------------------|------------------------------------------|-------------| | PCS_FX100_CFG | Configuration of the PCS 100BASE-FX mode | Per PCS | | PCS_FX100_STATUS | Status of the PCS 100BASE-FX mode | Per PCS | The PCS supports a 100BASE-FX mode in addition to the SGMII and 1000BASE-X SerDes modes. The 100BASE-X mode uses 4-bit/5-bit coding as specified in IEEE 802.3, Clause 24 for fiber connections. The 100BASE-FX mode is enabled through PCS\_FX100\_CFG.PCS\_ENA, which masks out all PCS1G related registers. The following options are available. - Far-End Fault facility: In 100BASE-FX, the PCS supports the optional Far-End Fault facility. Both Far-End Fault Generation (PCS\_FX100\_CFG.FEFGEN\_ENA) and Far-End Fault Detection (PCS\_FX100\_CFG.FEFCHK\_ENA) are supported. A Far-End Fault incident is recorded in PCS\_FX100\_STATUS.FEF\_FOUND. - Signal Detect: 100BASE-FX has a similar signal detect scheme as of the SGMII and SERDES modes. For 100BASE-FX, PCS\_FX100\_CFG.SD\_ENA enables signal detect, and PCS\_FX100\_CFG.SD\_SEL selects the input source. The current status of the signal detect input can be observed through PCS\_FX100\_STATUS.SIGNAL\_DETECT. For more information about signal detect, see Signal Detect, page 42. - Link Surveillance: The PCS synchronization status can be observed through PCS\_FX100\_STATUS.SYNC\_STATUS. When synchronization is lost the link breaks and PCS\_FX100\_STATUS.SYNC\_LOST\_STICKY is set. The PCS continuously tries to recover the link. - Unidirectional mode: 100BASE-FX has a similar unidirectional mode as for the SGMII and SerDes modes, enabled through PCS\_FX100\_CFG.UNIDIR\_MODE\_ENA. #### 3.8.4 Port Statistics Port statistics for DEV1G and DEV2G5 port modules are collected in the assembler and is accessed through registers in the assembler. # 3.9 Assembler The assembler (ASM) block is responsible for collecting words from the smaller taxi bus and assembling them into cells. It is also responsible for the loopback path between the rewriter and the analyzer. For the first cell of a frame, which is the SOF cell, the assembler adds room for a 28-byte internal frame header (IFH). On a stacking port, the stacking tag is extracted from the frame data and placed in the respective part of the IFH. The assembler receives a calendar sequence from the queue system defining in the sequence the ports should be served on the outgoing cell bus. The assembler also detects PAUSE frames and forwards the extracted PAUSE information to the disassembler. PFC pause information extracted from PFC PAUSE frames are forwarded to the queue system. Finally, the assembler collects the port statistics for all lower speed ports, which are the DEV1G and DEV2G5 ports. Statistics for the high-speed DEV10G ports are handled locally in the port module. # 3.9.1 Setting Up a Port in the Assembler The following table lists the port configuration registers within the assembler. Ethernet ports and CPU ports are configured using the same registers. Some of the fields are only relevant for setting up a CPU port (internal or external) and they will be covered in a later section. Table 16 • Port Configuration Register Overview | Target::Register.Field | Description | Replication | |---------------------------------|--------------------------------------------------|-------------| | ASM::PORT_CFG.NO_PREAMBLE_ENA | Preamble configuration of incoming frames. | Per port | | ASM::PORT_CFG.SKIP_PREAMBLE_ENA | Preamble configuration of incoming frames. | Per port | | ASM::PORT_CFG.PAD_ENA | Enable padding. | Per port | | ASM::PORT_CFG.INJ_DISCARD_CFG | Configures discard behavior for injected frames. | Per port | | ASM::PORT_CFG.INJ_FORMAT_CFG | Configure format of injected frames. | Per port | | ASM::PORT_CFG.VSTAX2_AWR_ENA | Enable VStaX stacking header awareness. | Per port | By default, an Ethernet port does not need configuration in the assembler as long as special settings are not required. However, the following exceptions may apply: If the port is used as a stacking port, set ASM::PORT\_CFG.VSTAX2\_AWR\_ENA, which enables detection of the VStaX stacking header. If a VStaX stacking header is found, the assembler will remove the header from the frame and put it into the internal frame header. Frames received from the port modules are preamble prepended by default. If a port module is configured for preamble shrink mode, the ASM::PORT\_CFG.NO\_PREAMBLE\_ENA must be set to 1, because the port module does not prepend a preamble in this mode. When ASM::PORT\_CFG.PAD\_ENA is set, frames that are smaller than 64 bytes are padded to reach the minimum frame size. The assembler has a built-in frame fragment detection mechanism for incoming frames that were started but never received their EOF (because the port module was taken down, for example). These frames are normally finalized by creating an EOF abort marked cell. If a frame has been discarded, it is noted in ASM::PORT\_STICKY.FRM\_AGING\_STICKY. The following table lists the port status register. Table 17 • Port Status Register Overview | Target::Register.Field | Description | Replication | |----------------------------------------|--------------------------------------|-------------| | ASM::PORT_STICKY.IFH_PREFIX_ERR_STICKY | Injection format mismatch sticky bit | Per port | | ASM::PORT_STICKY.FRM_AGING_STICKY | Frame aging sticky bit | Per port | # 3.9.2 Setting Up a Port for Frame Injection Any front port and the internal CPU ports (ports 11-12) can be configured for frame injection. Frames that are to be injected must have an IFH prepended the frame data. Optionally, the frame can further be prepended an SMAC, a DMAC, and a VLAN tag. This results in the following three prefix formats for injection frames: - Injection with long prefix - · Injection with short prefix - Injection with no prefix The injection format is selected in ASM::PORT\_CFG.INJ\_FORMAT\_CFG. The prefix formats are shown in the following illustration. Figure 19 • Frame Injection Formats For the long prefix, the incoming frame is matching against a programmable VLAN tag. The VLAN tag is common for all ports. Only the VID and TPID fields of the VLAN tag are compared. The following table lists the injection VLAN configuration register. Table 18 • Injection VLAN Register Overview | Target::Register.Field | Description | Replication | |--------------------------------|--------------------|-------------| | ASM::INJ_VLAN_CFG.INJ_VID_CFG | Injection tag VID | 1 | | ASM::INJ_VLAN_CFG.INJ_TPID_CFG | Injection tag TPID | 1 | When a port is setup to receive frames with either a short prefix or a long prefix, the incoming frames are checked against the selected prefix. If the prefix does not match, an error indication is set in ASM::PORT\_STICKY.IFH\_PREFIX\_ERR\_STICKY. Depending on the setting of ASM::PORT\_CFG.INJ\_DISCARD\_CFG, the frames are processed in one of the three following modes. - None. Both compliant and non-compliant frames are forwarded. Compliant frames are forwarded based on the IFH, and non-compliant frames are forwarded as regular frames. - Drop non-compliant. Compliant frames are forwarded based on the IFH, and non-compliant frames are discarded. - Drop compliant. Compliant frame are discarded, and non-compliant frames are forwarded as normal frames. If a CPU port is used for frame injection, ASM::PORT\_CFG.NO\_PREAMBLE\_ENA must be set to 1 so that the assembler does not expect frame data to be prepended with a preamble. If a front port is used for frame injection, ASM::PORT\_CFG.SKIP\_PREAMBLE\_ENA must be set to 1 to discard the preamble data before processing of the prepended injection header. # 3.9.3 Setting Up MAC Control Sublayer PAUSE Frame Detection The following table lists the PAUSE frame detection configuration registers in the assembler. Table 19 • PAUSE Frame Detection Configuration Register Overview | Target::Register.Field | Description | Replication | |--------------------------------------|----------------------------------------------------------|-------------| | ASM::PAUSE_CFG.ABORT_PAUSE_ENA | Stop forwarding of PAUSE frames | Per port | | ASM::PAUSE_CFG.ABORT_CTRL_ENA | Stop forwarding of MAC control frames | Per port | | ASM::MAC_ADDR_HIGH_CFG.MAC_ADDR_HIGH | Bits 47-24 of DMAC address checked in MAC_Control frames | Per port | | ASM::MAC_ADDR_LOW_CFG.MAC_ADDR_LOW | Bits 23-0 of DMAC address checked in MAC_Control frames | Per port | The assembler is responsible for detecting PAUSE frames and forwarding the PAUSE value to the disassembler. Because PAUSE frames belong to the MAC control sublayer, they should in general be filtered and not forwarded to a higher layer; that is, forwarded on the cell bus so they reach the analyzer. The filtering is done by abort marking the frame. The PAUSE frame and other MAC control frames can be forwarded to the analyzer. For PAUSE frame forwarding, ASM::PAUSE\_CFG.ABORT\_PAUSE\_ENA must be set to 0. For other MAC control frame forwarding, ASM::PAUSE\_CFG.ABORT\_CTRL\_ENA must be set to 0. When PAUSE frames are received, the DMAC address is checked. The DMAC address must be either the 48-bit multicast address 01-80-C2-00-00-01 as mentioned by IEEE802.3 Annex 31B.1 or the MAC address of the port, which is configured in ASM::MAC\_ADDR\_HIGH\_CFG.MAC\_ADDR\_HIGH and ASM::MAC\_ADDR\_LOW\_CFG.MAC\_ADDR\_LOW. Note: The values configured in ASM::MAC\_ADDR\_HIGH\_CFG.MAC\_ADDR\_HIGH and ASM::MAC\_ADDR\_LOW\_CFG.MAC\_ADDR\_LOW must match the value configured in DSM::MAC\_ADDR\_BASE\_HIGH\_CFG.MAC\_ADDR\_HIGH and DSM::MAC\_ADDR\_BASE\_LOW\_CFG.MAC\_ADDR\_LOW. The number of received PAUSE frames is tracked as part of the port statistics. For more information, see Setting Up Assembler Port Statistics, page 47. # 3.9.4 Setting Up PFC The PFC module of the assembler identifies PFC PAUSE frames by checking if the DMAC matches the reserved multicast address 01-80-c2-00-00-01, the Type/Length field matches a MAC control frame (0x8808), and the opcode is indicating a PFC frame (0x0101). Upon receiving a PFC PAUSE frame, the assembler extracts and stores the timer information for all enabled priorities in the assembler PFC timers. The PFC module generates a stop signal towards the queue system based on the current timer values. Detection of PFC frames is enabled by setting ASM::PFC\_CFG.RX\_PFC\_ENA to 1 for the respective (port,priority). When enabling PFC the current link speed for the port must be configured in ASM::PFC\_CFG.FC\_LINK\_SPEED for timing information to be evaluated correctly. The PFC configuration registers are shown in the following table. Table 20 • PFC Configuration Register Overview | Target::Register.Field | Description | Replication | |----------------------------|--------------------------|-------------| | ASM::PFC_CFG.RX_PFC_ENA | Enable PFC per priority | Per port | | ASM::PFC_CFG.FC_LINK_SPEED | Configure the link speed | Per port | # 3.9.5 Setting Up Assembler Port Statistics The assembler collects port statistics for all DEV1Gs and DEV2G5s. Statistics are also collected from the disassembler and the assembler. Port statistics for DEV10Gs are not collected in the assembler and must be looked up in each DEV10G separately. The following table lists the port statistics configuration register in the assembler. Table 21 • Port Statistics Configuration Register Overview | Target::Register.Field | Description | Replication | |---------------------------------|-----------------------------------------------|-------------| | ASM::STAT_CFG.STAT_CNT_CLR_SHOT | Statistics counter initialization. | 1 | | ASM::PORT_CFG.CSC_STAT_DIS | Disables collection of statistics in the ASM. | Per port | Port statistics inside the ASM are stored in RAMs. Before they can be used, they must be initialized to 0 by setting ASM::STAT\_CFG.STAT\_CNT\_CLR\_SHOT to 1. The statistic counters start counting as soon as the hardware has reset ASM::STAT CFG.STAT CNT CLR SHOT to 0. For information about the lists of port statistics registers available per port, see ASM:DEV\_STATISTICS register group in the Register List. For the 10G capable ports, set ASM::PORT\_CFG.CSC\_STAT\_DIS to 1 when the port is set up for speeds faster than 2.5G, because the collection of statistics are handled locally in the DEV10G. For lower speeds, the port uses a DEV2G5. All statistic counters have a width of 32 bits, except for the five byte-counters; RX\_IN\_BYTES\_CNT, RX\_OK\_BYTES\_CNT, RX\_DUT\_BYTES\_CNT, and TX\_OK\_BYTES\_CNT. Those have an additional 4-bit MSB counter. When reading from counters with more than 32 bits, the non-MSB part has to be read first in order to latch the MSB part into a shadow register, where the value can be read afterward. For writing, the MSB part must be written first. # 3.9.6 Setting Up the Loopback Path Cells to be looped back by the assembler are received on a separate loopback cell bus interface from the rewriter. The assembler merges the loopback data with data received from the ports onto the outgoing cell bus towards the analyzer. Loopback data belongs to one of the three following types. - Virtual device 0 (VD0) - Virtual device 1 (VD1) - Front port loopback (LBK) Each of the three loopback traffic types has its own FIFO. VD0 is accessed at register replication 0, VD1 at register replication 1, and LBK at register replication 2. The following table lists the loopback configuration registers. Table 22 • Loopback FIFO Configuration Register Overview | Target::Register.Field | Description | Replication | |------------------------------|------------------------------------------------------|-------------| | ASM::LBK_FIFO_CFG.FIFO_FLUSH | Flush all data in the FIFO. | Per FIFO | | ASM::VD_FC_WM.VD_FC_WM | Watermark for flow control towards the queue system. | Per VD FIFO | A FIFO can be flushed using the ASM::LBK\_FIFO\_CFG.FIFO\_FLUSH register. The register field clears itself when the flush is completed. Cells in the FIFO can be discarded due to aging. If a frame is discarded due to aging, a per port sticky bit is set in ASM::LBK\_AGING\_STICKY. The following table lists the loopback FIFO sticky bit registers. Table 23 • Loopback FIFO Sticky-Bit Registers Overview | Target::Register.Field | Description | Replication | |--------------------------------------------|-------------------------------------------------------------------|-------------| | ASM::LBK_AGING_STICKY.LBK_AGING_<br>STICKY | Set if a frame has been discarded due to aging. Per port bitmask. | 1 | | ASM::LBK_OVFLW_STICKY.LBK_OVFLW _STICKY | Set if a frame have been discarded due to overflow. | 1 | For VD0 and VD1, the loopback block pushes back towards the queue system to avoid FIFO overflows. The watermark for configuring the FIFO level at which push back is active can be set in ASM::VD\_FC\_WM.VD\_FC\_WM. The watermark can be configured individually for VD0 and VD1. No flow control handling exists for the LBK FIFO. In case of overflow, all new cells received from the rewriter are discarded, and a bit in the ASM::LBK\_OVFLW\_STICKY.LBK\_OVFLW\_STICKY sticky-bit register is set. # 3.10 Versatile Content-Aware Processor (VCAP) The Versatile Content-Aware Processor (VCAP™) is a content-aware packet processor that allows wire-speed packet inspection for rich implementation of, for example, advanced VLAN and QoS classification and manipulations, IP source guarding, and security features for wireline and wireless applications. This is achieved by programming rules into the VCAP. When a VCAP is enabled, every frame passing though the switch is analyzed and multiple keys are created based on the contents of the packet. The frame is examined to determine the frame type (for example, IPv4 TCP frame), so that the frame information is extracted according to the frame type, port-specific configuration, and classification results from the basic classification. Keys are applied to the VCAP and when there is a match between a key and a rule in the VCAP, the rule is then applied to the packet from which the key was extracted. A rule consists of an entry, an action, and a counter. Keys are matched against the entry of a rule. When a rule is matched, the action is returned by the VCAP, and the rule's counter is incremented. One and only one rule will match a key. If a key matches more than one rule, the rule at the highest address is selected. This means that a rule at high address takes priority over rules at lower addresses. When a key does not match a rule, a default rule is triggered. A default rule's action is programmable just like regular rules. Some VCAPs have more than one default rule; which default rule to use is determined at the same time as the key is created and applied to the VCAP. This section provides information about entries and actions in general terms. When discussing an entry or an action, it is considered a vector of bits that is provided by software. For information about building classification matching (CLM) keys, see VCAP CLM Keys and Actions, page 65. For information about building ingress stage 2 (IS2) keys, see VCAP IS2 Keys and Actions, page 145. For information about building longest prefix matching (LPM) keys, see VCAP LPM: Keys and Action, page 126. For information about building egress stage 0 (ES0) keys, see VCAP\_ES0 Lookup, page 243. The following sections describe how to program rules into the VCAPs of the device. First, a general description of configuration and VCAP operations is provided, including a description of wide VCAP rules. Second, detailed information about individual VCAPs is provided. Finally, a few practical examples illustrate how everything fits together when programming rules into VCAPs. # 3.10.1 Configuring VCAP Registers are available in two targets: VCAP\_ES0 and VCAP\_SUPER. Use VCAP\_ES0 to configure the VCAP ES0 target and the VCAP SUPER target for all other VCAPs. The following table lists the registers associated with VCAP ES0 and VCAP SUPER. Table 24 • VCAP\_ES0 and VCAP\_SUPER Registers | Description | |---------------------------------------------------------------| | Initiates of read/write/move/initialization operations | | Configures move/initialization operations | | Resource allocation, core index (does not apply to ES0) | | Resource allocation, mapping of cores (does not apply to ES0) | | Cache: Entry data | | Cache: Entry mask | | Cache: Action | | Cache: Sticky-counter | | Cache: Rule enable (only applies to ES0) | | | A rule in the VCAP consists of an entry, action, and counter showing if the entry was hit. Rules are accessed indirectly though a cache. The cache corresponds to one address in VCAP memory. Software access the cache using the VCAP configuration registers VCAP\_ENTRY\_DAT, VCAP\_MASK\_DAT, VCAP\_ACTION\_DAT, and VCAP\_CNT\_DAT. The following illustration shows an example cache register mapping for a VCAP with 36-bit entry data/mask, 70-bit action, and a 1-bit sticky counter. Cache registers are replicated to accommodate fields that are wider than 32 bits. For example, if the entry size is 36 bits, bits [31:0] are accessed using VCAP\_ENTRY\_DAT[0][31:0], and bits [35:32] are accessed using VCAP\_ENTRY\_DAT[1][3:0]. Figure 20 • VCAP Cache Layout Example Entries have both entry data and entry mask fields. This allows a don't-care of any bit position in the key when matching a key against entries. Table 25 • Entry Bit Encoding | VCAP_ENTRY_DAT[n]/V | | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CAP_MASK_DAT[n] | Description | | 0/0 | Bit $n$ is encoded for the match-0 operation. When a key is applied to the VCAP, this bit in the entry will match a 0 at position $n$ in the key. | | 0/1 | Bit $n$ is encoded for match-any operation. When a key is applied to the VCAP, this bit in the entry will match both 0 and 1 at position $n$ in the key. This encoding is sometimes referred to as don't care. | | 1/0 | Bit <i>n</i> is encoded for match-1 operation. When a key is applied to the VCAP, this bit in the entry will match a 1 at position <i>n</i> in the key. | | 1/1 | Bit $n$ is encoded for match-off operation. The entry will never match any keys. This encoding is not available in the VCAP ES0. Instead, it is treated as match-any. | When programming a rule that does not use all the available bits in the cache, remaining (undefined) entry bits must be set to match-0, and action bits must be set to zeros. To disable a rule, one or more bits in the entry is set to match-off. VCAP ES0 does not allow match-off encoding. Rules are instead enabled and disabled by the VCAP\_RULE\_ENA.RULE\_ENA cache field. The counter for a rule is incremented when the entry of the rule is matched by a key. Counters that are 1-bit wide do not wrap, but instead saturate at 1. ## 3.10.1.1 Writing, Reading, and Initializing Rules All access to and from VCAP memory goes through the cache. To write a rule in the VCAP memory at address a: Entry data, entry action, and counter is first written to the cache registers and then transferred into VCAP memory by triggering a write operation on the cache by setting VCAP\_UPDATE\_CTRL.UPDATE\_CMD = 0, VCAP\_UPDATE\_CTRL.UPDATE\_ADDR = a, and VCAP\_UPDATE\_CTRL.UPDATE\_SHOT = 1. The UPDATE\_SHOT field is cleared by hardware when the rule has put into VCAP memory. To read a rule from address a in the VCAP memory: Trigger a read operation on the cache by setting VCAP\_UPDATE\_CTRL.UPDATE\_CMD = 1, VCAP\_UPDATE\_CTRL.UPDATE\_ADDR = a, and VCAP\_UPDATA\_CTRL.UPDATE\_SHOT = 1. The UPDATE\_SHOT field is cleared by hardware when a copy of the rule is available for reading via cache registers. Active rules must not be overwritten by other rules (except when writing disabled rules). Software must make sure that addresses are initialized before they are written. It is possible to write the contents of the cache can be written to a range of addresses inside VCAP memory. This is used during initialization of VCAP memory. To write the contents of the cache to addresses a through b in VCAP memory, where a < b: Trigger an initialization-operation by setting VCAP\_MV\_CFG.MV\_NUM\_POS = b-a. And VCAP\_UPDATE\_CTRL.UPDATE\_CMD = 4, VCAP\_UPDATE\_CTRL.UPDATE\_ADDR = a, and VCAP\_UPDATE\_CTRL.UPDATA\_SHOT = 1. When the UPDATE\_SHOT field is cleared, the addresses have been overwritten with the contents of the cache. The cache can be cleared by writing VCAP\_UPDATE\_CTRL.CLEAR\_CACHE = 1. This immediately sets the contents of the entry to disabled, action and counter is set to all-zeros. VCAP\_UPDATE\_CTRL.CLEAR\_CACHE can be set at the same time as triggering an write or initialization operation, the cache will be cleared before writing to the VCAP memory. It is possible to selectively disable access to entry, action, and/or counter during operations by setting VCAP\_UPDATE\_CTRL.UPDATE\_ENTRY\_DIS, VCAP\_UPDATE\_CTRL.UPDATE\_ACTION\_DIS, or VCAP\_UPDATE\_CTRL.UPDATE\_CNT\_DIS. These fields allow specialized operations such as clearing counter values by performing initialization or write operations with disabled entry and action updating. ## 3.10.1.2 Moving a Block of Rules The VCAP supports move operation for efficient and safe moving of rules inside VCAP memory. Moving may be required to make room for new rules, because rules are prioritized by address. To move n addresses from address a to address b in VCAP memory: Trigger a move operation by setting VCAP\_MV\_CFG.MV\_NUM\_POS = (a>b ? a-b : b-a), VCAP\_MV\_CFG.MV\_SIZE = (n-1). And setting VCAP\_UPDATE\_CTRL.UPDATE\_CMD = (a>b ? 2 : 3), VCAP\_UPDATE\_CTRL.UPDATE\_ADDR = a, and VCAP\_UPDATE\_CTRL.UPDATE\_SHOT = 1. When the UPDATE\_SHOT field is cleared, the contents of the addresses have been moved inside VCAP memory. The cache is overwritten during the move-operation. Rules must not be moved to a region that contains active rules. Software must make sure that destination addresses are initialized before performing a move operation. After moving rules the move operation leaves VCAP memory in initialized state, so overlapping source and destination regions is not a problem during move operations. #### 3.10.1.3 Sharing Resources The device implements a shared pool of six blocks that can be distributed freely among the CLM, IS2, and LPM VCAPs. Each block in the pool has 1,024 addresses with entries, actions, and counters. Blocks are located back-to-back in the VCAP memory space. Block 0 is assigned addresses 0 through 1,023; block 1 is assigned addresses 1,024 though 2,047; and so on. Prioritizing of rules based on address still applies when multiple blocks are assigned to the same VCAP. To simplify software development, all blocks assigned to the same VCAP should be allocated as one consecutive region of addresses in memory. After a block of VCAP resources is allocated to a VCAP, it cannot be reallocated. Resource assignment must be done during startup before the VCAPs are enabled. After reset, all VCAP resources default to unallocated power-down mode. To allocate a block from the shared pool, write block index to VCAP\_CORE\_IDX.CORE\_IDX, then map it to a specific interface by writing VCAP\_CORE\_MAP.CORE\_MAP. For more information, see the register description for encoding of owners. # 3.10.1.4 Bringing Up VCAP The contents of the VCAP are unknown after reset. Software must initialize all addresses of the VCAP to disabled entry and all-zeros in action and counter before enabling lookups. The default rules of the VCAPs must also be initialized. After lookup is enabled for the VCAPs, default rules are triggered and applied to frames. Some VCAPs implement resource sharing. As a result, software must allocate resources as part of VCAP bring up. For more information about default addresses rules and resource allocation, see Individual VCAPs, page 53. #### 3.10.2 Wide VCAP Entries and Actions Some VCAPs support entries and actions that are wider than a single address in the VCAP memory. The size of an entry or action is described as Xn, where n is the number of addresses that is taken up in memory. When programming an X2 or larger entry or action, addresses are written one by one until the entire entry or action is written to VCAP memory. A rule consists of one entry and one action. The size of the rule is described as Xn where n is the largest of entry or action widths. For example, a rule consisting of an X2 entry and an X4 action is considered to be an X4 rule. The entry and action must start at the same address, so that address offset 0 for both entry and action is located at the same address inside the VCAP memory. When programming a rule where the action is wider than the entry, entry addresses exceeding the size of the entry must be disabled. When the entry is wider than the action, action addresses exceeding the size of the action must be set to zeros. The starting address of an Xn rule must be divisible by n. This means that X1 rules may be placed at any address, X2 rules may only placed at even addresses, X4 rules may only be placed at addresses divisible by 4, and so on. During move-operations this puts a restriction on the distance that rules are moved. In other words, when performing move-operation on a region of VCAP memory that contains rules of X2 or larger size, the rules must still be at legal addresses after the move. When a rule is matched by a key, the counter at address offset 0 is incremented. When writing an X2 or larger rule, software must start with the highest address and end with the lowest address. This is needed so that rules are not triggered prematurely during writing. When disabling rules, software must start by disabling the lowest address. This is automatically handled when using the initialization operation for disabling rules. #### 3.10.2.1 Type-Group Fields A special type-group field is required to differentiate rules when a VCAP supports different sized entries or actions. The type-group is not part of the entry/action description. Software has to manually lookup and insert type-group field into entry/action data when writing rules to VCAP memory. The type-group field is placed at the low bits of the entry and/or action. The value and width of the type-group field differs between VCAPs and depends on the entry/action size of and the address offset into the rule. For more information about type-group fields for individual VCAPs, see Individual VCAPs, page 53. The following illustration shows an example of inserting a 2-bit entry type-group field and a 3-bit action type-group field for a VCAP with 36-bit entry data/mask and a 64-bit action. After inserting of type-group, there is room for 34 additional entry/mask bits and 61 action bits in the cache. Figure 21 • VCAP Cache Type-Group Example When programming the entry's type-group field, the mask bits must be set to zeros, so that the type-group bits consist of match-1 or match-0, or both. Use the following procedure for each address that is part of an entry. - Use the entry's current address offset and size to find the appropriate type-group field and associated field-width by using the entry type-group table for the VCAP. Skip step 2 if entry typegroup is not applicable for the VCAP. - Insert the entry type-group field into the cache for a type-group field width of n. Write the value of the type-group field to bit-positions [n-1:0] in VCAP\_ENTRY\_DAT and write zeros to bit-positions [n-1:0] in VCAP\_MASK\_DAT. In this way, type-group field value 1 becomes match-1 and 0 becomes match0 - 3. Fill the remainder of VCAP\_ENTRY\_DAT and VCAP\_MASK\_DAT with appropriate entry data. There will be room for (entry width type-group width) additional bits of entry data. Use the following procedure for each address is that is part of an action. - Use the action's current address offset and size to find the appropriate type-group field and associated field-width by using the action type-group table for the VCAP. Skip step 2 if action typegroup is not applicable for the VCAP. - 2. Insert the action type-group field into the cache. For a type-group field width of *n*. Write the value of the type-group field to bit positions [*n*-1:0] in VCAP\_ACTION\_DAT. - 3. Fill the remainder of VCAP\_ACTION\_DAT with appropriate action data. There will be room for (action width type-group width) additional bits of action data. Counters never use type-group encoding. #### 3.10.3 Individual VCAPs This section provides detailed information about the individual VCAPs; VCAP CLM, VCAP IS2, VCAP LPM, and VCAP ES0. The CLM, IS2, and LPM VCAPs share resources. For more information, see Sharing Resources, page 51. #### 3.10.3.1 VCAP CLM The following table lists the parameters that apply to the VCAP CLM. Table 26 • VCAP CLM Parameters | Parameter | Description | |----------------------------|------------------------------------------------| | Number of VCAP addresses | 1,024 per block that is allocated to this VCAP | | Width of entry | 36 bits per address | | Width of action | 70 bits per address | | Counter type | 1 bit saturating counter | | Supported entry sizes | X1, X2, X4, X8, and X16 | | Supported action sizes | X1, X2, X4 | | Associated register target | VCAP_SUPER | The type-group field must be inserted into entries when programming rules, because the VCAP CLM supports more than one entry size. Table 27 • VCAP CLM Entry Type-Group Fields | Address Offset | Size | Entry Type Group | Description | |-------------------------------|------|------------------|---------------------------------------------------------------------------------------------| | 0 | X1 | 0b1 | Software must insert 1 bit with the value 1 into first address of all X1 entries. | | 0 | X2 | 0b10 | Software must insert 2 bit with the value 2 into first address of all X2 entries. | | 0 | X4 | 0b100 | Software must insert 3 bit with the value 4 into first address of all X4 entries. | | 0 | X8 | 0b1000 | Software must insert 4 bit with the value 8 into first address of all X8 entries. | | 0 | X16 | 0b10000 | Software must insert 5 bit with the value 16 into first address of all X16 entries. | | 1, 3, 5, 7, 9, 11, 13, and 15 | | 0b0 | Software must insert 1 bit with the value 0 into uneven addresses of all entries. | | 2, 6, 10, and 14 | | 0b00 | Software must insert 2 bit with the value 0 into addresses 2, 6, 10, and 14 of all entries. | | 4 and 12 | | 0b000 | Software must insert 3 bit with the value 0 into addresses 4 and 12 of all entries. | | 8 | | 0b0000 | Software must insert 4 bit with the value 0 into addresses 8 of all entries. | The type-group field must be inserted into actions when programming rules, because the VCAP CLM supports more than one action size. Table 28 • VCAP CLM Action Type-Group Fields | Address Offset | Size | Action Type Group | Description | |----------------|------|-------------------|-----------------------------------------------------------------------------------| | 0 | X1 | 0b1 | Software must insert 1 bit with the value 1 into first address of all X1 actions. | | 0 | X2 | 0b10 | Software must insert 2 bit with the value 2 into first address of all X2 actions. | Table 28 • VCAP CLM Action Type-Group Fields (continued) | Address Offset | Size | Action Type Group | Description | |----------------|------|-------------------|-----------------------------------------------------------------------------------| | 0 | X4 | 0b100 | Software must insert 3 bit with the value 4 into first address of all X4 actions. | | 1 and 3 | | 0b0 | Software must insert 1 bit with the value 0 into uneven addresses of all actions. | | 2 | | 0b00 | Software must insert 2 bit with the value 0 into address 2 of all actions. | It is possible to calculate the distribution of entry and action bits in the VCAP CLM based on entry and action widths, together with the type-group field-widths. Table 29 • VCAP CLM Entry/Action Bit Distribution | Address offset | X1 | X2 | X4 | X8 | X16 | |----------------|------------------|------------------------|---------------------------|------------|------------| | 0 | e[34:0], a[68:0] | e[33:0], a[67:0] | e[32:0],<br>a[66:0] | e[31:0] | e[30:0] | | 1 | | e[68:34],<br>a[136:68] | e[67:33],<br>a[135:67] | e[66:32] | e[65:31] | | 2 | | | e[101:68],<br>a[203:136] | e[100:67] | e[99:66] | | 3 | | | e[136:102],<br>a[272:204] | e[135:101] | e[134:100] | | 4 | | | | e[168:136] | e[167:135] | | 5 | | | | e[203:169] | e[202:168] | | 6 | | | | e[237:204] | e[236:203] | | 7 | | | | e[272:238] | e[271:237] | | 8 | | | | | e[303:272] | | 9 | | | | | e[338:304] | | 10 | | | | | e[372:339] | | 11 | | | | | e[407:373] | | 12 | | | | | e[440:408] | | 13 | | | | | e[475:441] | | 14 | | | | | e[509:476] | | 15 | | | | | e[544:510] | The VCAP CLM implements default rules. When submitting a key to the VCAP CLM, the analyzer simultaneously decides which default rule to hit if the key does not match any entries in the VCAP. If no resources (blocks) are assigned to VCAP CLM, there can be no matches. As a result, default rules will be hit. Table 30 • VCAP CLM Default Rule Addresses | VCAP | Number of<br>Default Rules | Address | |------|----------------------------|-------------------------------------------------------------------------------| | CLM0 | 30 | Starting address of CLM0 default rule number $n$ is (6,144 + $n \times 16$ ). | | CLM1 | 30 | Starting address of CLM1 default rule number $n$ is $(6,624 + n \times 16)$ . | | CLM2 | 30 | Starting address of CLM2 default rule number $n$ is (7,104 + $n \times 16$ ). | #### 3.10.3.2 VCAP IS2 The following table lists the parameters that apply to the VCAP IS2. Table 31 • VCAP IS2 Parameters | Parameter | Description | |----------------------------|------------------------------------------------| | Number of VCAP addresses | 1,024 per block that is allocated to this VCAP | | Width of entry | 36 bits per address | | Width of action | 70 bits per address | | Counter-type | 1-bit saturating counter | | Supported entry sizes | X4, X8, X16 | | Supported action sizes | X4 | | Associated register target | VCAP_SUPER | The type-group field must be inserted into entries when programming rules, because the VCAP IS2 supports more than one entry size. Table 32 • VCAP IS2 Entry Type-Group Fields | Address Offset | Size | Entry<br>Type-Group | Description | |---------------------------------------------|------|---------------------|-------------------------------------------------------------------------------------------------------------| | 0 | X4 | 0b1 | Software must insert 1 bit with the value 1 into first address of all X4 entries. | | 0 | X8 | 0b10 | Software must insert 2 bit with the value 2 into first address of all X8 entries. | | 0 | X16 | 0b100 | Software must insert 3 bit with the value 4 into first address of all X16 entries. | | 1, 2, 3, 5, 6, 7, 9, 10, 11, 13, 14, and 15 | | | Software must not insert type-group into addresses 1, 2, 3, 5, 6, 7, 9, 10, 11, 13, 14, and 15 for entries. | | 4 and 12 | | 0b0 | Software must insert 1 bit with the value 0 into addresses 4 and 12 of all entries. | | 8 | | 0b00 | Software must insert 2 bits with the value 0 into address 8. | Because only one action size is supported by the VCAP IS2, no type-group is inserted into actions when programming rules. It is possible to calculate the distribution of entry and action bits in the VCAP IS2 based on entry and action widths together with the entry type-group field width. Table 33 • VCAP IS2 Entry/Action Bit Distribution | Address Offset | X4 | X8 | X16 | |----------------|---------------------------|------------|------------| | 0 | e[34:0], a[69:0] | e[33:0] | e[32:0] | | 1 | e[70:35],<br>a[139:70] | e[69:34] | e[68:33] | | 2 | e[106:71],<br>a[209:140] | e[105:70] | e[104:69] | | 3 | e[142:107],<br>a[279:210] | e[141:106] | e[140:105] | | 4 | | e[176:142] | e[175:141] | Table 33 • VCAP IS2 Entry/Action Bit Distribution (continued) | Address Offset | X4 | X8 | X16 | |----------------|----|------------|------------| | 5 | | e[212:177] | e[211:176] | | 6 | | e[248:213] | e[247:212] | | 7 | | e[284:249] | e[283:248] | | 8 | | | e[317:284] | | 9 | | | e[353:318] | | 10 | | | e[389:354] | | 11 | | | e[425:390] | | 12 | | | e[460:426] | | 13 | | | e[496:461] | | 14 | | | e[532:497] | | 15 | | | e[568:533] | The VCAP IS2 has 16 default rules. The address of default rule number n is (7584 + 16 × n). When submitting a key to the VCAP IS2, the analyzer simultaneously determines which default rule to hit if the key does not match any entries. If no resources (blocks) were assigned to VCAP IS2, there can be no matches and default rules will be hit. ### 3.10.3.3 VCAP LPM The following table lists the parameters that apply to the VCAP LPM. Table 34 • VCAP LPM Parameters | Parameter | Description | |----------------------------|------------------------------------------------| | Number of VCAP addresses | 1,024 per block that is allocated to this VCAP | | Width of entry | 36 bit per address | | Width of action | 70 bit per address | | Counter-type | 1 bit saturating counter | | Supported entry sizes | X1, X2, X4, X8 | | Supported action sizes | X1 | | Associated register target | VCAP_SUPER | The type-group field must be inserted into entries when programming rules, because the VCAP LPM supports more than one entry size. Table 35 • VCAP LPM Entry Type-Group Fields | Address Offset | Size | Entry Type Group | Description | |----------------|------|------------------|-----------------------------------------------------------------------------------| | 0 | X1 | 0b1 | Software must insert 1 bit with the value 1 into first address of all X1 entries. | | 0 | X2 | 0b10 | Software must insert 2 bit with the value 2 into first address of all X2 entries. | | 0 | X4 | 0b100 | Software must insert 3 bit with the value 4 into first address of all X4 entries. | | 0 | X8 | 0b1000 | Software must insert 4 bit with the value 8 into first address of all X8 entries. | Table 35 • VCAP LPM Entry Type-Group Fields (continued) | Address Offset | Size | Entry Type Group | Description | |----------------|------|------------------|------------------------------------------------------------------------------------| | 1, 3, 5, and 7 | | 0b0 | Software must insert 1 bit with the value 0 into uneven addresses of all entries. | | 2 and 6 | | 0b00 | Software must insert 2 bit with the value 0 into addresses 2 and 6 of all entries. | | 4 | | 0b000 | Software must insert 3 bit with the value 0 into addresses 4 of all entries. | Because only one action size is supported by the VCAP LPM, no type-group is inserted into actions when programming rules. It is possible to calculate the distribution of entry and action bits in the VCAP LPM based on entry and action widths together with the entry type-group field width. Table 36 • VCAP LPM Entry/Action Bit Distribution | Address Offset | X1 | X2 | X4 | X8 | |----------------|------------------|----------|------------|------------| | 0 | e[34:0], a[69:0] | e[33:0] | e[32:0] | e[31:0] | | 1 | | e[68:34] | e[67:33] | e[66:32] | | 2 | | | e[101:68] | e[100:67] | | 3 | | | e[136:102] | e[135:101] | | 4 | | | | e[168:136] | | 5 | | | | e[203:169] | | 6 | | | | e[237:204] | | 7 | | | | e[272:238] | The VCAP LPM does not implement default rules. If the key does not match any entries, or if no resources (blocks) are assigned to the VCAP LPM, routing lookups are treated as misses. #### 3.10.3.4 VCAP ES0 VCAP ES0 has 512 addresses available. The following parameters apply to the VCAP ES0. Table 37 • VCAP ES0 Parameters | Parameter | Description | |----------------------------|---------------------------| | Number of VCAP addresses | 512. | | Width of entry | 30 bits per address. | | Width of action | 285 bits per address. | | Counter-type | 1-bit saturating counter. | | Supported entry sizes | X1. | | Supported action sizes | X1. | | Associated register target | VCAP_ES0. | The type-group field is not used when programming entries and actions, because VCAP ES0 supports only one entry size and one action size. The following table shows the distribution of entry and action bits in the VCAP ES0. Table 38 • VCAP ES0 Entry/Action Bit Distribution | Address Offset | X1 | |----------------|-------------------| | 0 | e[29:0], a[284:0] | The VCAP ES0 has 11 default rules. The address of default rule number n is (512 + n). When submitting a key to the VCAP ES0, the rewriter simultaneously decides which default rule to hit if the key does not match any entries in the VCAP. ### 3.10.4 VCAP Programming Examples This section provides examples of programming VCAP CLM and VCAP ES0. ### 3.10.4.1 Writing a Wide CLM Rule This example shows how to write a CLM X4 rule, consisting of an X2 TRI\_VID entry and an X4 FULL action, to the CLM1 VCAP. In this example, the second and third blocks of VCAP resources have already been mapped to CLM1. When the second and third resource blocks are mapped to CLM1, it then owns VCAP address range 1024-3071. An X4 rule must be placed on an address inside memory owned by CLM1 and starting addresses must be divisible by four, because it is an X4 rule. In this example, the X4 rule is written to addresses 1412-1415. Software is expected to track memory usage so that it only writes to VCAP memory that does not already contain active rules. Deleting of rules is done by initializing the associated addresses. The X2 TRI\_VID entry is 69 bits wide. The X4 FULL action is 250 bits wide. For information about how to build a FULL action, see VCAP CLM Actions, page 87. For information about how to build a TRI\_VID entry, see VCAP CLM X2 Key Details, page 69. Each address holds 36 bits of entry data/mask, but some of them are used for type-group fields. For more information about TRI\_VID's entry type-group field and entry bit-ranges for address offset 0 and 1, Table 27, page 54 and Table 29, page 55. The results are shown in the following table. Table 39 • CLM X2 Entry Type-Group and Distribution Summary | Address | Type-Group Field | Entry Data/Mask Range | |---------|------------------|-----------------------| | 1412 | 0b10 | [33:0] | | 1413 | 0b0 | [68:34] | **Note:** The TRI\_VID entry completely fills available entry space. If it had been less than 69 bits wide, then MSBs at address offset 1 would have been treated as Match-0. Each address holds 70 bits of action, but some of them are used for type-group fields. For more information the FULL's action type-group field and the action bit ranges for all four address offsets, see Table 28, page 54 and Table 29, page 55. The results are shown in the following table. Table 40 • CLM X4 Action Type-Group and Distribution Summary | Address | Type-Group Field | Action Data/Mask Range | |---------|------------------|------------------------| | 1412 | 0b100 | [66:0] | | 1413 | 0b0 | [135:67] | | 1414 | 0b00 | [203:136] | | 1415 | 0b0 | [249:204] | The FULL action is only 250 bits wide, so bits [272:250] of address offset 3 must be treated as zeros. Software must write the highest address offset first and work down to the lowest address offset. #### 3.10.4.1.1 Writing Address Offset 3 of X4 Rule Software is not allowed to modify the cache while VCAP operation is ongoing. Always check if VCAP\_UPDATE\_CTRL.UPDATE\_SHOT is cleared before starting to modify the cache. If a previous operation is still ongoing, wait for the UPDATE SHOT to clear. When a new rule is started, first clear cache's entry, action, and counter by setting VCAP\_UPDATE\_CTRL.CLEAR\_CACHE = 1. The TRI\_VID entry is an X2 entry and not part of address offset 3. The entry at this address must be set to Match-off. This has already been achieved by clearing of the cache. The FULL action is not so wide that it needs a third VCAP\_ACTION\_DAT replication so this must be set to zero. This has already been achieved by clearing of the cache. Write action to cache: VCAP\_ACTION\_DAT[1][31:0] = zero-extend(action[249:235]), VCAP\_ACTION\_DAT[0][31:1] = action[234:204], and VCAP\_ACTION\_DAT[0][0] = 0, because type-group field for the X4 CLM action at address offset 3 is 0b0. Write cache to VCAP memory by setting VCAP\_UPDATE\_CTRL = (4|(1415<<3)). ### 3.10.4.1.2 Writing Address Offset 2 of X4 Rule Wait for VCAP\_UPDATE\_CTRL.UPDATE\_SHOT to clear. The TRI\_VID entry is an X2 entry and is not part of address offset 2, the entry at this address must be set to Match-off. This has already been achieved by clearing of the cache during write of address offset 3. Write action to cache: VCAP\_ACTION\_DAT[2][31:0] = zero-extend(action[203:198]), VCAP\_ACTION\_DAT[1][31:0] = action[197:166], VCAP\_ACTION\_DAT[0][31:2] = action[165:136], and VCAP\_ACTION\_DAT[0][1:0] = 0, because type-group field for the X4 CLM action at address offset 2 is 0b00. Write cache to VCAP memory by setting VCAP\_UPDATE\_CTRL = (4|(1414<<3)). #### 3.10.4.1.3 Writing Address Offset 1 of X4 Rule Wait for VCAP UPDATE CTRL.UPDATE SHOT to clear. Write entry data to cache: VCAP\_ENTRY\_DAT[1][31:0] = zero-extend(entry data[68:65]), VCAP\_ENTRY\_DAT[0][31:1] = entry data[64:34], and VCAP\_ENTRY\_DAT[0][0] = 0, because type-group field for the X2 CLM entry at address offset 1 is 0b0. Write entry mask to cache: VCAP\_MASK\_DAT[1][31:0] = zero-extend(entry mask[68:65]), VCAP\_MASK\_DAT[0][31:1] = entry mask[64:34], and VCAP\_MASK\_DAT[0][0] = 0, because type-group field must not be don't-cared. Write action to cache: VCAP\_ACTION\_DAT[2][31:0] = zero-extend(action[135:130]), VCAP\_ACTION\_DAT[1][31:0] = action[129:98], VCAP\_ACTION\_DAT[0][31:1] = action[97:67], and VCAP\_ACTION\_DAT[0][0] = 0, because type-group field for the X4 CLM action at address offset 1 is 0b0. Write cache to VCAP memory by setting VCAP\_UPDATE\_CTRL = (4|(1413<<3)). #### 3.10.4.1.4 Writing Address Offset 0 of X4 Rule Wait for VCAP\_UPDATE\_CTRL.UPDATE\_SHOT to clear. Write entry data to cache: VCAP\_ENTRY\_DAT[1][31:0] = zero-extend(entry data[33:30]), VCAP\_ENTRY\_DAT[0][31:2] = entry data[29:0], and VCAP\_ENTRY\_DAT[0][1:0] = 2, because type-group field for the X2 CLM entry at address offset 0 is 0b10. Write entry mask to cache: VCAP\_MASK\_DAT[1][31:0] = zero-extend(entry mask[33:30]), VCAP\_MASK\_DAT[0][31:2] = entry mask[29:0], and VCAP\_MASK\_DAT[0][1:0] = 0, because type-group field must not be don't-cared. Write action to cache: VCAP\_ACTION\_DAT[2][31:0] = zero-extend(action[66:61]), VCAP\_ACTION\_DAT[1][31:0] = action[60:29], VCAP\_ACTION\_DAT[0][31:3] = action[28:0], and VCAP\_ACTION\_DAT[0][2:0] = 4, because type-group field for the X4 CLM action at address offset 0 is 0b100. Write cache to VCAP memory by setting VCAP UPDATE CTRL = (4|(1412<<3)). Once VCAP\_UPDATE\_CTRL.UPDATE\_SHOT is cleared, then the rule has been completely written to memory and will be able to match TRI\_VID keys applied to the CLM1 VCAP. ### 3.10.4.2 Writing an ES0 Rule This example shows how to write an ES0 rule, consisting of ISDX entry and ES0 action, to the VCAP ES0. The ES0 is not part of any resource sharing so it owns the entire address range 0-511. In this example, the rule is written to address 215. Software is expected to track memory usage so that it only writes to VCAP memory which does not already contain active rules. The ISDX entry is 30 bits wide and the action is 285 bits wide. For information about how to build a ISDX entry and ES0 action, see VCAP\_ES0 Lookup, page 243. ### 3.10.4.2.1 Writing a Rule to ES0 Software is not allowed to modify the cache while VCAP operation is ongoing. Always check if VCAP\_UPDATE\_CTRL.UPDATE\_SHOT is cleared before starting to modify the cache. If a previous operation is still ongoing, then wait for the UPDATE\_SHOT to clear. When a new rule is started, first clear cache's entry, action, and counter by setting VCAP UPDATE CTRL.CLEAR CACHE = 1. Write entry data to cache: VCAP\_ENTRY\_DAT[0][31:0] = zero-extend(entry data[29:0]). Write entry mask to cache: VCAP MASK DAT[0][31:0] = zero-extend(entry mask[29:0]). Write action to cache: VCAP\_ACTION\_DAT[8][31:0] = zero-extend(action[284:256]), VCAP\_ACTION\_DAT[7][31:0] = action[255:224], VCAP\_ACTION\_DAT[6][31:0] = action[223:192], VCAP\_ACTION\_DAT[5][31:0] = action[191:160], VCAP\_ACTION\_DAT[4][31:0] = action[159:128], VCAP\_ACTION\_DAT[3][31:0] = action[127:96], VCAP\_ACTION\_DAT[2][31:0] = action[95:64], VCAP\_ACTION\_DAT[1][31:0] = action[63:32], and VCAP\_ACTION\_DAT[0][31:0] = action[31:0]. Enable the rule by setting VCAP RULE ENA = 1. Write cache to VCAP memory by setting VCAP\_UPDATE\_CTRL = (4|(215<<3)). After VCAP\_UPDATE\_CTRL.UPDATE\_SHOT is cleared, the rule is completely written to memory and will be able to match ISDX keys applied to the VCAP ES0. ## 3.11 Pipeline Points This section describes the use of pipeline points in the processing flow through the switch core. A pipeline point defines a specific position in the processing flow where frames can be injected, extracted, discarded, or looped. These actions are special, because they define either a starting point (inject) or an ending point (extract, discard, loop) in the processing flow. A starting point identifies the point in the processing flow where the processing of the frame begins. Similarly, an ending point identifies the point in the processing flow where the processing of the frame ends. Frames subject to one of the actions injection, extraction, discarding, or looping, are assigned the associated pipeline point as well as a pipeline action defining what caused the pipeline point to be triggered. All frames are physically passed through all blocks of the processing flow, but each frame's pipeline point control determines whether it is actively processed in a given block or passed transparently to the next block; this includes which counters and policers are active. The logical processing flow for a frame is shown in the following illustration. As an example of how the pipeline points affect the processing flow, consider a frame being discarded by the VLAN acceptance filter in the basic classification. The frame is assigned the ANA\_CL pipeline point, and it is therefore not service classified and hence not service policed nor counted in the service statistics. The processing flow illustrates the different functional blocks that exist for UNI, E-NNI, and NNI ports. Not all blocks are at the same time applicable to a frame, for instance, a frame can only be processed by at most one Protect Select/Kill block. However, other frames may use the other blocks. The lower part of the illustration shows typical MIP and MEP placements for a UNI or E-NNI flow and for a NNI flow. Figure 22 • Processing Flow # 3.11.1 Pipeline Definitions The IFH fields IFH.MISC.PIPELINE\_PT and IFH.MISC.PIPELINE\_ACT carry the frame's pipeline information (point and action). By default, no pipeline points are triggered and both fields are set to 0. This implies that there are no restrictions on the processing of the frame. The following table defines the available pipeline points in the analyzer and the rewriter. Table 41 • Pipeline Definitions | Pipeline Point | Block/Mechanism that uses<br>Pipeline Point | Application | |----------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | ANA_VRAP | VRAP | VRAP extraction point. | | ANA_PORT_VOE | Port VOE | Port VOE extraction/discard point. | | ANA_CL | Basic classifier | Filter discard point/CPU injection point with software configured IFH. | | ANA_CLM | VCAP CLM/service classification | CPU injection point with software configured IFH including service classification. Extraction point related to services. | | ANA_IPT_PROT | IPT protection point | Protection discard point for e.g. LAG protection (where protection discard is done before Down MEPs) controlled by port VOE. | | ANA_OU_MIP | Outer OAM half-MIP located in analyzer | Extraction/copy/injection point for analyzer half-MIP for: • UNI-N: Subscriber MIP • E-NNI: EVC MIP | | ANA_OU_SW | Outer software MEP with extraction controlled by VCAP IS2 | SW MEP located between the VOEs and the port for: • Extraction point for SW Down-MEP • Injection point for SW Up-MEP | | ANA_OU_PROT | Outer protection point controlled by IPT | Protection discard point controlled by IPT for NNI protection | | ANA_OU_VOE | Outer OAM VOE located in analyzer/VOP | Outer VOE pipeline point for: • UNI: EVC OAM injection • E-NNI: OVC OAM Injection • NNI: Path OAM Extraction | | ANA_MID_PROT | Middle protection point located<br>between outer and inner VOE<br>controlled by IPT | Protection discard point for path protection controlled by path MEP. | | ANA_IN_VOE | Inner OAM VOE located in analyzer/VOP | Inner VOE pipeline point for: • UNI: OVC OAM injection • NNI: EVC/OVC OAM segment extraction | | ANA_IN_PROT | Inner protection point located after inner VOE controlled by IPT | Protection discard point. Frames are discarded after the VOEs used for discarding which exit an inactive EVC Segment | | ANA_IN_SW | Inner software MEP with extraction controlled by VCAP IS2 | SW MEP located between the VOEs and shared queue system for: • Extraction point for SW Down-MEP • Injection point for SW Up-MEP | | ANA_IN_MIP | Inner OAM half-MIP located in analyzer | Extraction/copy/injection point for analyzer half MIP for NNI: EVC/OVC MIP. | | ANA_VLAN | Pipeline point associated with VLAN handling and forwarding | Pipeline point for VLAN discard. | | ANA_DONE | Pipeline point after analyzer | Injection point where analyzer is bypassed. Used for injection directly into rewriter. | | REW_IN_MIP | Inner OAM half-MIP located in rewriter | Extraction/copy/injection point for rewriter half MIP function for NNI: EVC/OVC MIP. | Table 41 • Pipeline Definitions (continued) | | Block/Mechanism that uses | | |----------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | Pipeline Point | Pipeline Point | Application | | REW_IN_SW | Inner software MEP located in rewriter controlled by VCAP_ES0 | SW MEP located between the shared queue system and the VOEs for: • Injection point for SW Down-MEP • Extraction point for SW Up-MEP | | REW_IN_VOE | Inner OAM VOE located in rewriter/VOP | Inner VOE pipeline point for: • UNI: OVC OAM extraction • NNI: EVC/OVC OAM segment injection | | REW_OU_VOE | Outer OAM VOE in rewriter/VOP | Outer VOE pipeline point for: • UNI: EVC OAM extraction • E-NNI: OVC OAM extraction • NNI: Path OAM injection | | REW_OU_SW | Outer software MEP located in rewriter controlled by VCAP_ES0 | SW MEP located between the VOEs and the port for: Injection point for SW Down-MEP Extraction point for SW Up-MEP | | REW_OU_MIP | Outer OAM half-MIP located in rewriter | Extraction/copy/injection point for rewriter half MIP function for: • UNI-N: Subscriber MIP • E-NNI: EVC MIP | | REW_SAT | Service activation testing | SAT loop point. | | REW_PORT_VOE | Port VOE in rewriter VOP | Port VOE injection point. | | REW_VRAP | VRAP injection point | VRAP injection point. | The following table defines the pipeline actions associated with the pipeline point. Table 42 • Pipeline Actions | Pipeline Action | Description | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | INJ | Set when CPU-injecting a frame into the processing flow at the associated pipeline point. The processing starts at the associated pipeline point. | | INJ_MASQ | Set when CPU-injecting a frame masqueraded into the processing flow at the associated pipeline point. The processing starts at the associated pipeline point. | | XTR | Assigned to frames being redirected to the CPU. The processing ends at the associated pipeline point. Frames copied to the CPU are not assigned a pipeline point as the processing continues. | | XTR_UPMEP | Assigned to frames being extracted to the CPU by an Up MEP (VOE). The processing ends at the associated pipeline point. Frames copied to the CPU are not assigned a pipeline point as the processing continues. | | XTR_LATE_REW | Assigned to MPLS OAM frames by VCAP CLM to instruct the rewriter to terminate the processing of the frame. The processing ends at the associated pipeline point. | | LBK_ASM | Assigned by Up MEPs (VOE) requiring the frame to be looped. This action implies that the processing in the rewriter is ended at the associated pipeline point and that the processing in the analyzer after looping the frame starts at the corresponding analyzer pipeline point. | | LBK_QS | Assigned by Down MEPs (VOE) requiring the frame to be looped. This action implies that the processing in the analyzer is ended at the associated pipeline point and that the processing in the rewriter after looping the frame starts at the corresponding rewriter pipeline point. | **Note:** A frame cannot be assigned both a starting point and an ending point at the same side of the queue system. For instance, a frame cannot be injected in the analyzer at ANA\_CLM and then extracted at ANA\_IN\_SW. However, a frame can be injected in the analyzer and then extracted in the rewriter. ## 3.12 Analyzer The following sections provides information about the functional aspects of the analyzer (ANA). The analyzer evokes different actions based on the contents of the frame fields. The analyzer is organized into the following blocks. - VCAP CLM: VCAP Classification matching—keys and actions - ANA\_CL: Analyzer classifier - ANA L3: VLAN and MSTP - VCAP LPM: VCAP longest prefix matching—keys and actions - ANA\_L3: IP routing - VCAP IS2: VCAP Ingress Stage 2—keys and actions - ANA ACL: Access Control Lists - ANA\_L2: Analyzer Layer 2 forwarding and learning - ANA AC: Analyzer Actions—forwarding, policing, statistics ### 3.12.1 Initializing the Analyzer Before the analyzer can be configured, the RAM-based configuration registers must be initialized by setting ANA\_AC:RAM\_CTRL:RAM\_INIT.RAM\_ENA and ANA\_AC:RAM\_CTRL:RAM\_INIT.RAM\_INIT to 1. The ANA\_AC:RAM\_CTRL:RAM\_INIT.RAM\_INIT register is reset by hardware when initialization is complete. For information about initializing VCAP CLM, VCAP IS2, and VCAP LPM, see Bringing Up VCAP, page 52. # 3.13 VCAP CLM Keys and Actions The VCAP CLM is part of the analyzer and enables frame classification using VCAP functionality. This section provides an overview of all available VCAP CLM keys, followed by information about each key and action. For information about how to select which key to use and how the VCAP CLM interacts with other parts of the analyzer classifier, see VCAP CLM Processing, page 110. VCAP CLM supports a number of different keys that can be used for different purposes. The keys are of type X1, X2, X4, X8, or X16, depending on the number of words each key uses. The keys are grouped after size as shown in the following table. Table 43 • VCAP CLM Keys and Sizes | Key Name | Key Size | Number of Words | Key Type | |-----------------|----------|-----------------|----------| | SGL_MLBS | 35 bits | 1 word | X1 type | | TRI_VID | 69 bits | 2 words | X2 type | | DBL_MLBS | 68 bits | | | | TRI_VID_IDX | 69 bits | | | | MLL | 136 bits | 4 words | X4 type | | TRI_MLBS | 129 bits | | | | PURE_5TUPLE_IP4 | 137 bits | | | | CUSTOM_4 | 136 bits | | | Table 43 • VCAP CLM Keys and Sizes (continued) | Key Name | Key Size | Number of Words | Key Type | |-------------------|----------|-----------------|----------| | LL_FULL | 272 bits | 8 words | X8 type | | NORMAL | 266 bits | | | | NORMAL_5TUPLE_IP4 | 255 bits | | | | CUSTOM_2 | 272 bits | | | | NORMAL_7TUPLE | 536 bits | 16 words | X16 type | | CUSTOM_1 | 527 bits | | | # 3.13.1 Keys Overview The following table lists all VCAP CLM keys and fields and provides a quick overview of which fields are available in which keys. When programming an entry in VCAP CLM, the associated key fields listed must be programmed in the listed order with the first field in the table starting at bit 0 in the entry. Table 44 • VCAP CLM Key Overview | | | | SGL_MLBS | TRI VID | _<br>rri_vid_idx | DBL_MLBS | | I_MLBS | PURE_5TUPLE_IP4 | CUSTOM_4 | FULL | NORMAL | NORMAL_STUPLE_IP4 | CUSTOM_2 | NORMAL_7TUPLE | custom_1 | |-------------------|-------------------------------------|------|----------|---------|------------------|----------|----|--------|-----------------|----------|----------|--------|-------------------|----------|---------------|----------| | Field Name | Short Description | Size | SG | H | <u>⊢</u> | <u>=</u> | ML | A. | 3 | <u>ರ</u> | <u> </u> | ž | ž | ರ | ž | <u>ರ</u> | | X2_TYPE | X2 type (each entry uses 2 words) | 2 | | Х | Х | Х | | | | | | | | | | | | X4_TYPE | X4 type (each entry uses 4 words) | 2 | | | | | Х | Χ | Х | Х | | | | | | | | X8_TYPE | X8 type (each entry uses 8 words) | 2 | | | | | | | | | Х | Х | Х | Х | | | | X16_TYPE | X16 type (each entry uses 16 words) | 1 | | | | | | | | | | | | | Х | Х | | FIRST | Set for first lookup | 1 | Х | Х | Х | Х | | Х | Х | Х | Х | Х | Х | Х | Х | Х | | IGR_PORT | Ingress port number | 6 | | Х | | | Х | | | | Х | | | | | | | G_IDX_IS_SERVICE | Set if G_IDX is set to ISDX | 1 | | | Χ | | | | Х | Х | | Х | Х | Х | Х | Х | | G_IDX | Generic index | 12 | Χ | | Х | Х | | Х | Х | Х | | Х | Х | Х | Х | Х | | IGR_PORT_MASK_SEL | Mode selector for IGR_PORT_MASK | 2 | | | | | | | | | | Х | Х | | Х | | | IGR_PORT_MASK | Ingress port mask | 53 | | | | | | | | | | Х | Х | | Х | | | L2_MC | Multicast DMAC address | 1 | | | | | | | | | | Х | Х | | Х | | | L2_BC | Broadcast DMAC address | 1 | | | | | | | | | | Х | Х | | Х | | | TPID0 | TPID identifier from first tag | 3 | | Х | Х | | Х | | | | Х | Х | Х | | Х | | | PCP0 | PCP from first tag | 3 | | Х | | | | | | | Х | Х | Х | | Х | | | DEI0 | DEI from first tag | 1 | | Х | | | | | | | Х | Х | Х | | Х | | | VID0 | VID from first tag | 12 | | Х | Х | | Х | | | | Х | Х | Х | | Х | | | TPID1 | TPID identifier from second tag | 3 | | Х | Х | | Х | | | | Х | Х | Х | | Х | | | PCP1 | PCP from second tag | 3 | | Х | | | | | | | х | Х | х | | х | | | DEI1 | DEI from second tag | 1 | | Х | | | | | | | Х | Х | Х | | Х | | Table 44 • VCAP CLM Key Overview (continued) | Field Name | Short Description | Size | SGL MLBS | TRI VID | TRI VID IDX | DBL_MLBS | MLL | TRI_MLBS | PURE_5TUPLE_IP4 | CUSTOM_4 | LL_FULL | NORMAL | NORMAL_STUPLE_IP4 | ٩ | NORMAL_7TUPLE<br>CUSTOM_1 | |-------------|---------------------------------------------|------|----------|---------|-------------|----------|-----|----------|-----------------|----------|---------|--------|-------------------|---|---------------------------| | VID1 | VID from second tag | 12 | | Х | Х | | Х | | | | Х | Х | Х | 2 | x | | TPID2 | Tag protocol identifier from third tag | 3 | | Х | Х | | | | | | Х | Х | Х | 2 | x | | PCP2 | PCP from third tag | 3 | | Х | | | | | | | Х | Х | Х | 2 | x | | DEI2 | DEI from third tag | 1 | | Х | | | | | | | Х | Х | Х | 2 | x | | VID2 | VID from third tag | 12 | | Х | Х | | | | | | Х | Х | Х | 2 | x | | DST_ENTRY | Set if destination entry | 1 | | | | | | | | | | Х | | | | | L2_DMAC | Destination MAC address | 48 | | | | | Х | | | | Х | | | 2 | x | | L2_SMAC | Source MAC address | 48 | | | | | Х | | | | Х | Х | | 2 | x | | ETYPE_MPLS | EtherType identifier | 2 | | | | | Х | | | | | | | | | | ETYPE_FULL | EtherType identifier | 3 | | Х | | | | | | | | | | | | | IP_MC | Multicast DIP address | 1 | | | | | | | | | | Х | Х | | x | | ETYPE_LEN | ETYPE encoded frame | 1 | | | | | | | | | х | Х | | | x | | ETYPE | EtherType, overloaded for other frame types | 16 | | | | | | | | | х | х | | 2 | X | | IP_SNAP | IP or SNAP frame | 1 | | | | | | | | | Х | Х | | 2 | x | | IP4 | IPv4 frame | 1 | | | | | | | | | Х | Х | Х | | x | | LBL0 | Label from MPLS Label Stack entry 0 | 20 | Х | | | Х | | Х | | | | | | | | | TC0 | TC bits from MPLS Label Stack entry 0 | 3 | | | | Х | | Х | | | | | | | | | SBIT0 | S-bit from MPLS Label Stack entry 0 | 1 | Х | | | Х | | Х | | | | | | | | | TTL0_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 0 | 1 | х | | | х | | х | | | | | | | | | LBL1 | Label from entry 1 | 20 | | | | Х | | Х | | | | | | | | | TC1 | TC bits from entry 1 | 3 | | | | Х | | Х | | | | | | | | | SBIT1 | S-bit from entry 1 | 1 | | | | Х | | Х | | | | | | | | | TTL1_EXPIRY | Set if TTL<=1 for entry 1 | 1 | | | | Х | | Х | | | | | | | | | LBL2 | Label from entry 2 | 20 | | | | | | Х | | | | | | | | | TC2 | TC bits from entry 2 | 3 | | | | | | Х | | | | | | | | | SBIT2 | S-bit from entry 2 | 1 | | | | | | Х | | | | | | | | | TTL2_EXPIRY | Set if TTL<=1 for entry 2 | 1 | | | | | | Х | | | | | | | | | RSV_LBL_VAL | Reserved label value | 4 | | | | | | Х | | | | | | | | | CW_ACH | CW/ACH after label with S-bit set | 32 | | | | | | Х | | | | | | | | | RSV_LBL_POS | Reserved label position | 3 | | | | Х | | Х | | | | | | | | | L3_FRAGMENT | Fragmented IPv4 frame | 1 | | | | | | | Х | | Х | Х | Х | 2 | X | | | | | | | | | | | | | | | | | | Table 44 • VCAP CLM Key Overview (continued) | Field Name | Short Description | Size | SGL_MLBS TRI_VID TRI_VID_IDX DRI_MIRS | PURE_STUPLE_IP4 | CUSTOM_4 | LL_FULL | NORMAL | NORMAL_5TUPLE_IP4 | CUSTOM_2<br>NORMAL 7TUPLE | CUSTOM_1 | |-------------------|-----------------------------------------------|------|---------------------------------------|-----------------|----------|---------|--------|-------------------|---------------------------|----------| | L3_FRAG_OFS_GT0 | Frame is not the first fragment | 1 | | Х | | Х | Х | Х | х | | | L3_OPTIONS | IPv4 frame with options | 1 | | Х | | Χ | Х | Х | Х | | | L3_DSCP | Frame's DSCP value | 6 | | Х | | Х | Х | Х | х | | | L3_IP4_DIP | Destination IP address | 32 | | Х | | Χ | | Х | | | | L3_IP4_SIP | SIP address, overloaded for other frame types | 32 | | Х | | Х | х | Х | | | | L3_IP6_DIP | Destination IP address | 128 | | | | | | | х | | | L3_IP6_SIP | Source IP address | 128 | | | | | | | Х | | | L3_IP_PROTO | IP protocol / next header | 8 | | Х | | | | Х | | | | TCP_UDP | TCP/UDP frame | 1 | | | | Х | Х | Х | х | | | TCP | TCP frame | 1 | | | | Χ | Х | Х | х | | | L4_SPORT | TCP/UDP source port | 16 | | | | Χ | Х | | Х | | | L4_RNG | Range checker mask | 8 | | Х | | | Х | Х | х | | | IP_PAYLOAD_5TUPLE | Payload bytes after IP header | 32 | | Х | | | | Х | | | | OAM_Y1731 | Set if frame's EtherType = 0x8902 | 1 | Х | | | | | | | | | OAM_MEL_FLAGS | Encoding of MD level/MEG level (MEL) | 7 | Х | | | | | | | | | CUSTOM1 | 64 bytes payload | 512 | | | | | | | | Х | | CUSTOM2 | 32 bytes payload | 256 | | | | | | | Х | | | CUSTOM4 | 15 bytes payload | 120 | | | Х | | | | | | # 3.13.2 VCAP CLM X1 Key Details The SGL\_MLBS key is the only X1 key, so it does not have a type field. The following table lists details about the fields applicable to the SGL\_MLBS key. Table 45 • VCAP CLM X1 Key Details | | | | MLBS | |------------|----------------------------------------------------------------------------------------------------------------|------|------| | Field Name | Description | Size | SGI | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | х | Table 45 • VCAP CLM X1 Key Details (continued) | Field Name | Description | Size | SGL_MLBS | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------| | G_IDX | Generic index used to bind together entries across VCAP CLM lookups. | 12 | X | | | G_IDX is calculated based on fields in VCAP CLM action from previous VCAP CLM lookup: NXT_IDX_CTRL. NXT_IDX. Default value is configurable in ANA_CL::CLM_MISC_CTRL.CLM_GIDX_DEF_SEL. | | | | | Can be zero, logical port number, or masqueraded port number. | | | | LBL0 | MPLS Label Stack entry 0 - Label (Top Label) | 20 | Х | | SBIT0 | MPLS Label Stack entry 0 - S-bit (Top Label) | 1 | Х | | TTL0_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 0 | 1 | Х | | | | | | # 3.13.3 VCAP CLM X2 Key Details The X2 keys include an X2\_TYPE field, which is used to tell the difference between the keys. It takes a unique value for each key. The following table lists details about the fields applicable to these keys. Table 46 • VCAP CLM X2 Key Details | Field Name | Description | Size | TRI VID | DBL_MLBS | TRI_VID_IDX | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|----------|-------------| | X2_TYPE | X2 type: 0: TRI_VID 1: DBL_MLBS 2: Reserved 3: TRI_VID_IDX | 2 | X | x | | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | Х | Х | Х | | IGR_PORT | Logical ingress port number retrieved from ANA_CL::PORT_ID_CFG.LPORT_NUM. | 6 | Х | | | | G_IDX | Generic index used to bind together entries across VCAP CLM lookups. G_IDX is calculated based on fields in VCAP CLM action from previous VCAP CLM lookup: NXT_IDX_CTRL. NXT_IDX. Default value is configurable in ANA_CL::CLM_MISC_CTRL.CLM_GIDX_DEF_SEL. Can be zero, logical port number, or masqueraded port number. | 12 | | x | х | Table 46 • VCAP CLM X2 Key Details (continued) | Field Name | Description | Size | TRI_VID | DBL_MLBS | TRI_VID_IDX | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|----------|-------------| | TPID0 | Tag protocol identifier of the frame's first tag (outer tag): 0: Untagged. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | Х | ) | x | | PCP0 | By default PCP from frame but it is selectable per lookup in VCAP CLM whether to use the current classified PCP instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 3 | х | | | | DEI0 | By default DEI from frame but it is selectable per lookup in VCAP CLM whether to use the current classified DEI instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 1 | Х | | | | VID0 | By default VID from frame but it is selectable per lookup in VCAP CLM whether to use the current classified VID instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). For untagged frames, VID0 is set to 0. | 12 | х | ) | x | | TPID1 | Tag protocol identifier of the frame's second tag (tag after outer tag): 0: No second tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | X | ) | x | | PCP1 | Frame's PCP from second tag. | 3 | Х | | | | DEI1 | Frame's DEI from second tag. | 1 | Х | | | | VID1 | Frame's VID from second tag. | 12 | Х | | | Table 46 • VCAP CLM X2 Key Details (continued) | Field Name | Description | Size | TRI_VID | UBL_MLBS<br>TRI_VID_IDX | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-------------------------| | TPID2 | Tag protocol identifier of the frame's third tag: 0: No third tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. Overloading for TRI_VID: For OAM Y.1731 frames (ETYPE_FULL = 5) without a third tag (TPID2 = 0), VID2[6:0] is set to OAM MEL flags: Encoding of MD level/MEG level (MEL). One bit for each level where lowest level encoded as zero. The following keys can be generated: MEL = 0: 0b0000000. MEL = 1: 0b0000001. MEL = 2: 0b0000011. MEL = 3: 0b0000111. MEL = 4: 0b0001111. MEL = 5: 0b0111111. MEL = 6: 0b0111111. Together with the mask, the following types of rules can be created: Exact match. Fx. MEL = 2: 0b0000011. Below. Fx. MEL < = 4: 0b000XXXX. Above. Fx. MEL < = 5: 0bXX11111. Between. Fx. 3 < MEL < = 5: 0b00XX111, where "X" means don't care. | 3 | x | x | | PCP2 | Frame's PCP from third tag. | 3 | Х | | | DEI2 | Frame's DEI from third tag. | 1 | Х | | | VID2 | Frame's VID from third tag. | 12 | Х | | | ETYPE_FULL | EtherType identifier: 0: IPv4frame (EtherType = 0x0800). 1: IPv6 frame (EtherType = 0x86DD). 2: Downstream assigned label (EtherType = 0x8847). 3: Upstream assigned label (EtherType = 0x8848). 4: LCC/SNAP (EtherType < 0x0600). 5: OAM Y.1731 (EtherType = 0x8902). 6: (R)ARP (EtherType = 0x0806 or 0x8035). 7: Other. | 3 | X | | | LBL0 | MPLS Label Stack entry 0 - Label (Top Label). | 20 | Х | | | TC0 | MPLS Label Stack entry 0 - TC bits (Top Label). | 3 | х | [ | | SBIT0 | MPLS Label Stack entry 0 - S-bit (Top Label). | 1 | х | [ | | TTL0_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 0. | 1 | Х | [ | | LBL1 | MPLS Label Stack entry 1 - Label. | 20 | Х | | | TC1 | MPLS Label Stack entry 1 - TC bits. | 3 | Х | [ | | SBIT1 | MPLS Label Stack entry 1 - S-bit. | 1 | Х | <u> </u> | | • | | | | | Table 46 • VCAP CLM X2 Key Details (continued) | Field Name | Description | Size | TRI_VID<br>DBL_MLBS<br>TRI_VID_IDX | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------| | TTL1_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 1. | 1 | Х | | RSV_LBL_POS | Reserved label position: 0: Reserved label at position 0 seen or skipped. 1: Reserved label at position 1 seen or skipped. 2: Reserved label at position 2 seen or skipped. 3: Reserved label at position 3 seen. 4: Reserved. 5: No reserved label seen. Label at top of stack is position 0, followed by 1, 2, and 3. In order for a reserved label to be skipped, either ANA_CL::MPLS_RSV_LBL_CFG[< abel>].RSVD_LBL_SKIP_ENA or ANA_CL::MPLS_MISC_CFG.CLM_RSVD_LBL_SKIP_ENA clm idx>] must be set. | 3 | Х | | OAM_Y1731 | Set if frame's EtherType = 0x8902. | 1 | Х | | OAM_MEL_FLAGS | Encoding of MD level/MEG level (MEL). One bit for each level where lowest level encoded as zero. The following keys can be generated: MEL=0: 0x0000000 MEL=1: 0x0000001 MEL=2: 0x0000011 MEL=3: 0x0000111 MEL=4: 0x0001111 MEL=5: 0x0011111 MEL=6: 0x0111111 MEL=7: 0x1111111 Together with the mask, the following kinds of rules may be created: - Exact match. Fx. MEL=2: 0x0000011 - Below. Fx. MEL<=4: 0x000XXXX - Above. Fx. MEL>=5: 0xXX11111 - Between. Fx. 3<= MEL<=5: 0x00XX111, where 'X' means don't care. Overloading: For non-Y1731 OAM frames (OAM_Y1731 = 0), OAM_MEL_FLAGS encodes an EtherType identifier: 0: IPv4frame (EtherType = 0x0800) 1: IPv6 frame (EtherType = 0x86DD) 2: Downstream assigned label (EtherType = 0x8847) 3: Upstream assigned label (EtherType = 0x8848) 4: LCC/SNAP (EtherType < 0x0600) 5: (R)ARP (EtherType = 0x0806 or 0x8035) 6: Reserved 7: Other | 7 | x | # 3.13.4 VCAP CLM X4 Key Details The X4 keys include an X4\_TYPE field, which is used to tell difference between the keys. It takes a unique value for each key. The following table lists details about the fields applicable to these keys. Table 47 • VCAP CLM X4 Key Details | Field Name | Description | Size | MLL | 'RI_MLBS | PURE_STUPLE_IP4 | CUSTOM_4 | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|----------|-----------------|----------| | X4_TYPE | X4 type: 0: MLL. 1: TRI_MLBS. 2: PURE_5TUPLE_IP4. 3: CUSTOM_4. | 2 | _ | X | | _ | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | | х | Х | х | | IGR_PORT | Logical ingress port number retrieved from ANA_CL::PORT_ID_CFG.LPORT_NUM. | 6 | Х | | | | | G_IDX_IS_SERVICE | Set if the VCAP CLM action from the previous VCAP CLM lookup specified ISDX to be used as G_IDX. | 1 | | | Х | Х | | G_IDX | Generic index used to bind together entries across VCAP CLM lookups. G_IDX is calculated based on fields in VCAP CLM action from previous VCAP CLM lookup: NXT_IDX_CTRL. NXT_IDX. Default value is configurable in ANA_CL::CLM_MISC_CTRL.CLM_GIDX_DEF_SEL. Can be zero, logical port number, or masqueraded port number. | 12 | | X | X | X | | TPID0 | Tag protocol identifier of the frame's first tag (outer tag): 0: Untagged. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | X | | | | | VID0 | By default VID from frame but it is selectable per lookup in VCAP CLM whether to use the current classified VID instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). For untagged frames, VID0 is set to 0. | 12 | х | | | | | TPID1 | Tag protocol identifier of the frame's second tag (tag after outer tag): 0: No second tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | x | | | | | VID1 | Frame's VID from second tag. | 12 | Х | | | | | L2_DMAC | Destination MAC address. | 48 | Х | | | | Table 47 • VCAP CLM X4 Key Details (continued) | Field Name | Description | Size | MLL | TRI_MLBS<br>PURE_5TUPLE_IP4<br>CUSTOM_4 | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----------------------------------------| | L2_SMAC | Source MAC address. | 48 | X | <u> </u> | | ETYPE_MPLS | EtherType identifier: 0: Non-MPLS. 1: Downstream Assigned Label (EtherType = 0x8847). 2: Upstream Assigned Label (EtherType = 0x8848). | 2 | х | | | LBL0 | MPLS Label Stack entry 0 - Label (Top Label). | 20 | | х | | TC0 | MPLS Label Stack entry 0 - TC bits (Top Label). | 3 | | Х | | SBIT0 | MPLS Label Stack entry 0 - S-bit (Top Label). | 1 | | Х | | TTL0_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 0. | 1 | | Х | | LBL1 | MPLS Label Stack entry 1 - Label. | 20 | | Х | | TC1 | MPLS Label Stack entry 1 - TC bits. | 3 | | х | | SBIT1 | MPLS Label Stack entry 1 - S-bit. | 1 | | Х | | TTL1_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 1. | 1 | | х | | LBL2 | MPLS Label Stack entry 2 - Label. | 20 | | Х | | TC2 | MPLS Label Stack entry 2 - TC bits. | 3 | | Х | | SBIT2 | MPLS Label Stack entry 2 - S-bit. | 1 | | х | | TTL2_EXPIRY | Set if TTL<=1 for MPLS Label Stack entry 2. | 1 | | Х | | RSV_LBL_VAL | Reserved label value. Only valid if RSV_LBL_POS > 0. | 4 | | Х | | CW_ACH | The 32 bits following the label with S-bit set. | 32 | | Х | | RSV_LBL_POS | Reserved label position: 0: Reserved label at position 0 seen or skipped. 1: Reserved label at position 1 seen or skipped. 2: Reserved label at position 2 seen or skipped. 3: Reserved label at position 3 seen. 4: Reserved. 5: No reserved label seen. | 3 | | X | | | Label at top of stack is position 0, followed by 1, 2, and 3. | | | | | | In order for a reserved label to be skipped, either ANA_CL::MPLS_RSV_LBL_CFG[ <label>].RSVD_LBL_SKIP_ENA or ANA_CL::MPLS_MISC_CFG.CLM_RSVD_LBL_SKIP_ENA[<clm idx="">] must be set.</clm></label> | | | | | L3_FRAGMENT | Set if IPv4 frame is fragmented (More Fragments flag = 1 or Fragments Offset > 0). | 1 | | х | | L3_FRAG_OFS_GT0 | Set if IPv4 frame is fragmented but not the first fragment (Fragments Offset > 0) | 1 | | х | | L3_OPTIONS | Set if IPv4 frame contains options (IP len > 5). IP options are not parsed. | 1 | | Х | Table 47 • VCAP CLM X4 Key Details (continued) | Field Name | Description | Size | MLL<br>TRI_MLBS<br>PURE_5TUPLE_IP4<br>CUSTOM_4 | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------------------| | L3_DSCP | By default DSCP from frame. Per match, selectable to be current classified DSCP (ANA_CL::ADV_CL_CFG.USE_CL_DSCP_ENA). | 6 | х | | L3_IP4_DIP | IPv4 frames: Destination IPv4 address. IPv6 frames: Destination IPv6 address, bits 31:0. | 32 | Х | | L3_IP4_SIP | Overloaded field for different frame types: LLC frames (ETYPE_LEN = 0 and IP_SNAP = 0): L3_IP4_SIP = [CTRL, PAYLOAD[0:2]] | 32 | х | | | SNAP frames (ETYPE_LEN = 0 and IP_SNAP=1):<br>L3_IP4_SIP = [PID[2:0], PAYLOAD[0]] | | | | | IPv4 frames (ETYPE_LEN=1, IP_SNAP=1, and IP4=1):<br>L3_IP4_SIP = source IPv4 address | | | | | IPv6 frames (ETYPE_LEN=1, IP_SNAP=1, IP4=0):<br>L3_IP4_SIP = source IPv6 address, bits 31:0 | | | | | Other frames (ETYPE_LEN=1, IP_SNAP=0):<br>L3_IP4_SIP = PAYLOAD[0:3]. | | | | L3_IP_PROTO | IPv4 frames (IP4=1): IP protocol. IPv6 frames (IP4=0): Next header. | 8 | Х | | L4_RNG | Range mask. Range types: SPORT, DPORT, SPORT or DPORT, VID, DSCP, custom. Input into range checkers is taken from frame except DSCP value which is the remapped DSCP value from basic classification. | 8 | х | | IP_PAYLOAD_5TUPLE | Payload bytes after IP header. IPv4 options are not parsed so payload is always taken 20 bytes after the start of the IPv4 header. | 32 | Х | | CUSTOM4 | 15 bytes payload starting from current frame pointer position, as controlled by VCAP CLM actions. Note that if frame_type==ETH, then payload is retrieved from a position following the Ethernet layer, for example, after DMAC, SMAC, 0-3 VLAN tags and EtherType. | 120 | Х | # 3.13.5 VCAP CLM X8 Key Details The X8 keys include an X8\_TYPE field, which is used to tell difference between the keys. It takes a unique value for each key. The following table lists details about the fields applicable to these keys. Table 48 • VCAP CLM X8 Key Details | Field Name | Description | Size | LL FULL | NORMAL | NORMAL 5TUPLE IP4 | CUSTOM_2 | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|--------|-------------------|----------| | X8_TYPE | X8 type: 0: LL_FULL. 1: NORMAL. 2: NORMAL_5TUPLE_IP4. 3: CUSTOM_2. | 2 | Х | Х | Х | х | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | Х | Х | Х | Х | | IGR_PORT | Logical ingress port number retrieved from ANA_CL::PORT_ID_CFG.LPORT_NUM. | 6 | Х | | | | | G_IDX_IS_SERVICE | Set if the VCAP CLM action from the previous VCAP CLM lookup specified ISDX to be used as G_IDX. | 1 | | Х | Х | Х | | G_IDX | Generic index used to bind together entries across VCAP CLM lookups. G_IDX is calculated based on fields in VCAP CLM action from previous VCAP CLM lookup: NXT_IDX_CTRL. NXT_IDX. Default value is configurable in ANA_CL::CLM_MISC_CTRL.CLM_GIDX_DEF_SEL. Can be zero, logical port number, or masqueraded port number. | 12 | | X | X | х | Table 48 • VCAP CLM X8 Key Details (continued) | Field Name | Description | Size | LL_FULL<br>NORMAL | NORMAL_5TUPLE_IP4<br>CUSTOM_2 | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------|-------------------------------| | IGR_PORT_MASK_SEL | Mode selector for IGR_PORT_MASK. 0: Default setting. 1: Set for frames received from a loopback device, i.e. LBK_DEV*. 2: Set for masqueraded frames if ANA_CL::CLM_MISC_CTRL.MASQ_IGR_MASK_ENA == 1. A masqueraded frame is identified by the following criteria: (ifh.fwd.dst_mode == inject && ifh.src_port!= physical_src_port) (misc.pipeline_act == inj_masq) 3: Set for the following frame types: 3.a: CPU injected frames and ANA_CL::CLM_MISC_CTRL.CPU_IGR_MASK_ENA == 1. 3.b: Frames received from VD0 or VD1 and ANA_CL::CLM_MISC_CTRL.VD_IGR_MASK_ENA == 1. 3.c: Frame received on a loopback device and ANA_CL::CLM_MISC_CTRL.LBK_IGR_MASK_SEL3_ENA == 1. If a frame fulfills multiple of above criteria, then higher value of | 2 | X | | | IGR_PORT_MASK | Ingress port mask. IGR_PORT_MASK_SEL == 0: Each bit in the mask correspond to physical ingress port. IGR_PORT_MASK_SEL == 1: Each bit in the mask correspond to the physical port which the frame was looped on. IGR_PORT_MASK_SEL == 2: Each bit in the mask correspond to the masqueraded port. If IGR_PORT_MASK_SEL == 3: Bit 0: Physical src port == CPU0. Bit 1: Physical src port == CPU1. Bit 2: Physical src port == VD0. Bit 3: Physical src port == VD1. Bits 4:9: Src port (possibly masqueraded). Bits 44:48: ifh.misc.pipeline_pt. Bits 49:51: ifh.misc.pipeline_act. Bits 52: Reserved. | 53 | X | X | | L2_MC | Set if frame's destination MAC address is a multicast address (bit 40 = 1). | 1 | Х | Х | | L2_BC | Set if frame's destination MAC address is the broadcast address (FF-FF-FF-FF-FF). | 1 | Х | х | Table 48 • VCAP CLM X8 Key Details (continued) | Field Name | Description | Size | LL_FULL | NORMAL | NORMAL_5TUPLE_IP4<br>CUSTOM_2 | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|--------|-------------------------------| | TPID0 | Tag protocol identifier of the frame's first tag (outer tag): 0: Untagged. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | x | x | X | | PCP0 | By default PCP from frame but it is selectable per lookup in VCAP CLM whether to use the current classified PCP instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 3 | Х | Х | Х | | DEI0 | By default DEI from frame but it is selectable per lookup in VCAP CLM whether to use the current classified DEI instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 1 | Х | х | Х | | VID0 | By default VID from frame but it is selectable per lookup in VCAP CLM whether to use the current classified VID instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). For untagged frames, VID0 is set to 0. | 12 | х | х | х | | TPID1 | Tag protocol identifier of the frame's second tag (tag after outer tag): 0: No second tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | x | X | х | | PCP1 | Frame's PCP from second tag. | 3 | Х | Х | Х | | DEI1 | Frame's DEI from second tag. | 1 | Х | Х | Х | | VID1 | Frame's VID from second tag. | 12 | Х | Х | х | | TPID2 | Tag protocol identifier of the frame's third tag: 0: No third tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | X | X | Х | | PCP2 | Frame's PCP from third tag. | 3 | Х | Х | Х | | DEI2 | Frame's DEI from third tag. | 1 | Х | Х | Х | | VID2 | Frame's VID from third tag. | 12 | Х | Х | Х | Table 48 • VCAP CLM X8 Key Details (continued) | Field Name | Description | Size | LL FULL | NORMAL | NORMAL_5TUPLE_IP4<br>CUSTOM_2 | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|--------|-------------------------------| | DST_ENTRY | Selects whether the frame's destination or source information is used for fields L2_SMAC and L3_IP4_SIP. If set, L2_SMAC contains the frame's destination MAC address and L3_IP4_SIP contains the frame's destination IP address. The setting is controlled by ANA_CL::ADV_CL_CFG and VCPA_CLM_action.NXT_KEY_TYPE. | 1 | | x | | | L2_DMAC | Destination MAC address. | 48 | Х | | | | L2_SMAC | Source MAC address. Note that - optionally - L2_SMAC may contain the destination MAC address, see DST_ENTRY. | 48 | Х | х | | | IP_MC | IPv4 frames: Set if frame's destination IP address is an IPv4 multicast address (0xE /4). IPv6 frames: Set if frame's destination IP address is an IPv6 multicast address (0xFF /8). | 1 | | х | Х | | ETYPE_LEN | Frame type flag indicating that the frame is EtherType encoded. Set if frame has EtherType >= 0x600. | 1 | Х | Х | | | ETYPE | Overloaded field for different frame types: LLC frames (ETYPE_LEN=0 and IP_SNAP=0): ETYPE = [DSAP, SSAP] SNAP frames (ETYPE_LEN=0 and IP_SNAP=1): ETYPE = PID[4:3] from SNAP header TCP/UDP IPv4 or IPv6 frames (ETYPE_LEN=1, IP_SNAP=1, and TCP_UDP=1): ETYPE = TCP/UDP destination port Non-TCP/UDP IPv4 or IPv6 frames (ETYPE_LEN=1, IP_SNAP=1, and TCP_UDP=0): ETYPE = IP protocol Other frames (ETYPE_LEN=1 and IP_SNAP=0): ETYPE = Frame's EtherType. | 16 | x | x | | | IP_SNAP | Frame type flag indicating that the frame is either an IP frame or a SNAP frame. IP frames (ETYPE_LEN=1): Set if (EtherType= 0x0800 and IP version = 4) or (ETYPE = 0x86DD and IP version = 6) SNAP frames (ETYPE_LEN=0): Set if LLC header contains AA-AA-03. | 1 | x | X | | | IP4 | Frame type flag indicating the frame is an IPv4 frame. Set if frame is IPv4 frame (EtherType = 0x800 and IP version = 4). | 1 | х | Х | Х | Table 48 • VCAP CLM X8 Key Details (continued) | Field Name | Description | Size | L_FULL | NORMAL | NORMAL_STUPLE_IP4<br>CUSTOM_2 | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|--------|-------------------------------| | L3_FRAGMENT | Set if IPv4 frame is fragmented (More Fragments flag = 1 or Fragments Offset > 0). | 1 | × | X | | | L3_FRAG_OFS_GT0 | Set if IPv4 frame is fragmented but not the first fragment (Fragments Offset > 0). | 1 | Х | Х | x | | L3_OPTIONS | Set if IPv4 frame contains options (IP len > 5). IP options are not parsed. | 1 | Х | х | х | | L3_DSCP | By default DSCP from frame. Per match, selectable to be current classified DSCP (ANA_CL::ADV_CL_CFG.USE_CL_DSCP_ENA). | 6 | Х | х | х | | L3_IP4_DIP | IPv4 frames: Destination IPv4 address. IPv6 frames: Destination IPv6 address, bits 31:0. | 32 | Х | | х | | L3_IP4_SIP | Overloaded field for different frame types: LLC frames (ETYPE_LEN=0 and IP_SNAP=0): L3_IP4_SIP = [CTRL, PAYLOAD[0:2]] | 32 | х | х | Х | | | SNAP frames (ETYPE_LEN=0 and IP_SNAP=1):<br>L3_IP4_SIP = [PID[2:0], PAYLOAD[0]] | | | | | | | IPv4 frames (ETYPE_LEN=1, IP_SNAP=1, and IP4=1):<br>L3_IP4_SIP = source IPv4 address | | | | | | | IPv6 frames (ETYPE_LEN=1, IP_SNAP=1, IP4=0):<br>L3_IP4_SIP = source IPv6 address, bits 31:0 | | | | | | | Other frames (ETYPE_LEN=1, IP_SNAP=0):<br>L3_IP4_SIP = PAYLOAD[0:3] | | | | | | | Note that, optionally, L3_IP4_SIP may contain the destination IP address for IP frames. See DST_ENTRY. | | | | | | L3_IP_PROTO | IPv4 frames (IP4=1): IP protocol.<br>IPv6 frames (IP4=0): Next header. | 8 | | | х | | TCP_UDP | Frame type flag indicating the frame is a TCP or UDP frame. Set if frame is IPv4/IPv6 TCP or UDP frame (IP protocol/next header equals 6 or 17). Overloading: Set to 1 for OAM Y.1731 frames. | 1 | х | х | х | | TCP | Frame type flag indicating the frame is a TCP frame. Set if frame is IPv4 TCP frame (IP protocol = 6) or IPv6 TCP frames (Next header = 6). | 1 | Х | х | х | Table 48 • VCAP CLM X8 Key Details (continued) | Field Name | Description | Size | LL_FULL | | NORMAL_5TUPLE_IP4 | CUSTOM_2 | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|---|-------------------|----------| | L4_SPORT | TCP/UDP source port. Overloading: OAM Y.1731 frames: L4_SPORT = OAM MEL flags, see below. TCP_UDP is at the same time set to 1 to indicate the overloading. OAM MEL flags: Encoding of MD level/MEG level (MEL). One bit for each level where lowest level encoded as zero. The following keys can be generated: MEL=0: 0b0000000. MEL=1: 0b0000001. MEL=2: 0b0000011. MEL=3: 0b0000111. MEL=4: 0b0001111. MEL=5: 0b0111111. MEL=5: 0b0111111. Together with the mask, the following kinds of rules may be created: Exact match. Fx. MEL=2: 0b0000011. Below. Fx. MEL<=4: 0b000XXXX. Above. Fx. MEL>=5: 0bXX11111. Between. Fx. 3<= MEL<=5: 0b00XX111, where 'X' means don't care. | 16 | x | _ | | | | L4_RNG | Range mask. Range types: SPORT, DPORT, SPORT or DPORT, VID, DSCP, custom. Input into range checkers is taken from frame except DSCP value which is the remapped DSCP value from basic classification. | 8 | | x | Х | | | IP_PAYLOAD_5TUPLE | Payload bytes after IP header. IPv4 options are not parsed so payload is always taken 20 bytes after the start of the IPv4 header. | 32 | | | Х | | | CUSTOM2 | 32 bytes payload starting from current frame pointer position, as controlled by VCAP CLM actions. Note that if frame_type==ETH, then payload is retrieved from a position following the Ethernet layer; for example, after DMAC, SMAC, 0-3 VLAN tags and EtherType. | 256 | | | | x | # 3.13.6 VCAP CLM X16 Key Details The X16 keys include an X16\_TYPE field, which is used to tell difference between the keys. It takes a unique value for each key. The following table lists details about the fields applicable to these keys. Table 49 • VCAP CLM X16 Key Details | Field Name | Description | Size | NORMAL 7TUPLE | CUSTOM_1 | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|----------| | X16_TYPE | X16 type. 0: NORMAL_7TUPLE. 1: CUSTOM_1. | 1 | | x | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | х | Х | | G_IDX_IS_SERVICE | Set if the VCAP CLM action from the previous VCAP CLM lookup specified ISDX to be used as G_IDX. | 1 | Х | Х | | G_IDX | Generic index used to bind together entries across VCAP CLM lookups. G_IDX is calculated based on fields in VCAP CLM action from previous VCAP CLM lookup: NXT_IDX_CTRL. NXT_IDX. | 12 | Х | X | | | Default value is configurable in ANA_CL::CLM_MISC_CTRL.CLM_GIDX_DEF_SEL. It can be zero, logical port number, or masqueraded port number. | | | | | IGR_PORT_MASK_SEL | Mode selector for IGR_PORT_MASK. 0: Default setting. 1: Set for frames received from a loopback device, for example, LBK_DEV*. 2: Set for masqueraded frames if ANA_CL::CLM_MISC_CTRL.MASQ_IGR_MASK_ENA == 1. A masqueraded frame is identified by the following criteria: (ifh.fwd.dst_mode == inject && ifh.src_port != physical_src_port) (misc.pipeline_act == inj_masq) 3: Set for the following frame types: 3.a: CPU injected frames and ANA_CL::CLM_MISC_CTRL.CPU_IGR_MASK_ENA == 1 3.b: Frames received from VD0 or VD1 and ANA_CL::CLM_MISC_CTRL.VD_IGR_MASK_ENA == 1 3.c: Frame received on a loopback device and | 2 | x | | | | ANA_CL::CLM_MISC_CTRL.LBK_IGR_MASK_SEL3_ENA == 1. If a frame fulfills multiple of above criteria, then higher value of IGR_PORT_MASK_SEL takes precedence. | | | | Table 49 • VCAP CLM X16 Key Details (continued) | Field Name | Description | Size | NORMAL_7TUPLE<br>CUSTOM_1 | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------| | IGR_PORT_MASK | Ingress port mask. IGR PORT MASK SEL == 0: | 53 | x | | | Each bit in the mask correspond to physical ingress port. IGR_PORT_MASK_SEL == 1: Each bit in the mask correspond to the physical port which the frame was looped on. | | | | | IGR_PORT_MASK_SEL == 2: Each bit in the mask correspond to the masqueraded port. | | | | | If IGR_PORT_MASK_SEL == 3: Bit 0: Physical src port == CPU0. Bit 1: Physical src port == CPU1. Bit 2: Physical src port == VD0. Bit 3: Physical src port == VD1. Bits 4:9: Src port (possibly masqueraded). Bits 44:48: ifh.misc.pipeline_pt. Bits 49:51: ifh.misc.pipeline_act. Bits 52: Reserved. | | | | L2_MC | Set if frame's destination MAC address is a multicast address (bit 40 = 1). | 1 | х | | L2_BC | Set if frame's destination MAC address is the broadcast address (FF-FF-FF-FF-FF). | 1 | Х | | TPID0 | Tag protocol identifier of the frame's first tag (outer tag): 0: Untagged. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | х | | PCP0 | By default PCP from frame but it is selectable per lookup in VCAP CLM whether to use the current classified PCP instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 3 | х | | DEI0 | By default DEI from frame but it is selectable per lookup in VCAP CLM whether to use the current classified DEI instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). | 1 | х | | VID0 | By default VID from frame but it is selectable per lookup in VCAP CLM whether to use the current classified VID instead (ANA_CL::ADV_CL_CFG.USE_CL_TCI0_ENA). For untagged frames, VID0 is set to 0. | 12 | х | Table 49 • VCAP CLM X16 Key Details (continued) | Field Name | Description | Size | NORMAL_7TUPLE<br>CUSTOM_1 | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------| | TPID1 | Tag protocol identifier of the frame's second tag (tag after outer tag): 0: No second tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3. | 3 | х | | PCP1 | Frame's PCP from second tag. | 3 | Х | | DEI1 | Frame's DEI from second tag. | 1 | Х | | VID1 | Frame's VID from second tag. | 12 | Х | | TPID2 | Tag protocol identifier of the frame's third tag: 0: No third tag. 1: 0x8100. 4: 0x88A8. 5: Custom value 1. 6: Custom value 2. 7: Custom value 3 | 3 | Х | | PCP2 | Frame's PCP from third tag. | 3 | Х | | DEI2 | Frame's DEI from third tag. | 1 | Х | | VID2 | Frame's VID from third tag. | 12 | Х | | L2_DMAC | Destination MAC address. | 48 | Х | | L2_SMAC | Source MAC address. | 48 | Х | | IP_MC | IPv4 frames: Set if frame's destination IP address is an IPv4 multicast address (0xE /4). IPv6 frames: Set if frame's destination IP address is an IPv6 multicast address (0xFF /8). | 1 | Х | | ETYPE_LEN | Frame type flag indicating that the frame is EtherType encoded. Set if frame has EtherType >= 0x600. | 1 | х | ### Table 49 • VCAP CLM X16 Key Details (continued) | Field Name | Description | Size | NORMAL_7TUPLE<br>CUSTOM_1 | |-----------------|----------------------------------------------------------------------------------------------------------------------------|------|---------------------------| | ETYPE | Overloaded field for different frame types:<br>LLC frames (ETYPE_LEN = 0 and IP_SNAP = 0):<br>ETYPE = [DSAP, SSAP] | 16 | х | | | SNAP frames (ETYPE_LEN = 0 and IP_SNAP = 1):<br>ETYPE = PID[4:3] from SNAP header. | | | | | TCP/UDP IPv4 or IPv6 frames (ETYPE_LEN = 1, IP_SNAP = 1, and TCP_UDP = 1): ETYPE = TCP/UDP destination port. | | | | | Non-TCP/UDP IPv4 or IPv6 frames (ETYPE_LEN = 1, IP_SNAP = 1, and TCP_UDP = 0):<br>ETYPE = IP protocol. | | | | | Other frames (ETYPE_LEN = 1 and IP_SNAP = 0):<br>ETYPE = Frame's EtherType. | | | | IP_SNAP | Frame type flag indicating that the frame is either an IP frame or a SNAP frame. | 1 | х | | | IP frames (ETYPE_LEN = 1): Set if (EtherType= 0x0800 and IP version = 4) or (ETYPE = 0x86DD and IP version = 6). | | | | | SNAP frames (ETYPE_LEN = 0):<br>Set if LLC header contains AA-AA-03. | | | | IP4 | Frame type flag indicating the frame is an IPv4 frame. Set if frame is IPv4 frame (EtherType = 0x800 and IP version = 4). | 1 | х | | L3_FRAGMENT | Set if IPv4 frame is fragmented (More Fragments flag = 1 or Fragments Offset > 0). | 1 | Х | | L3_FRAG_OFS_GT0 | Set if IPv4 frame is fragmented but not the first fragment (Fragments Offset > 0) | 1 | Х | | L3_OPTIONS | Set if IPv4 frame contains options (IP len > 5). IP options are not parsed. | 1 | Х | | L3_DSCP | By default DSCP from frame. Per match, selectable to be current classified DSCP (ANA_CL::ADV_CL_CFG.USE_CL_DSCP_ENA). | 6 | х | | L3_IP6_DIP | Destination IP address.<br>IPv4 frames (IP4=1):<br>Bits 31:0: Destination IPv4 address. | 128 | Х | Table 49 • VCAP CLM X16 Key Details (continued) | Field Name | Description | Size | NORMAL_7TUPLE<br>CUSTOM_1 | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------| | L3_IP6_SIP | Overloaded field for different frame types: LLC frames (ETYPE_LEN=0 and IP_SNAP=0): L3_IP6_SIP = [CTRL, PAYLOAD[0:14]] SNAP frames (ETYPE_LEN=0 and IP_SNAP=1): L3_IP6_SIP = [PID[2:0], PAYLOAD[0:12]] IPv4 frames (ETYPE_LEN=1, IP_SNAP=1, and IP4=1): L3_IP6_SIP[31:0] = source IPv4 address IPv6 frames (ETYPE_LEN=1, IP_SNAP=1, IP4=0): L3_IP6_SIP = source IPv6 address Other frames (ETYPE_LEN=1, IP_SNAP=0): L3_IP6_SIP = PAYLOAD[0:15] | 128 | x | | TCP_UDP | Frame type flag indicating the frame is a TCP or UDP frame. Set if frame is IPv4/IPv6 TCP or UDP frame (IP protocol/next header equals 6 or 17). Overloading: Set to 1 for OAM Y.1731 frames. | 1 | X | | TCP | Frame type flag indicating the frame is a TCP frame. Set if frame is IPv4 TCP frame (IP protocol = 6) or IPv6 TCP frames (Next header = 6). | 1 | х | | L4_SPORT | TCP/UDP source port. Overloading: OAM Y.1731 frames: L4_SPORT = OAM MEL flags, see below. TCP_UDP is at the same time set to 1 to indicate the overloading. OAM MEL flags: Encoding of MD level/MEG level (MEL). One bit for each level where lowest level encoded as zero. The following keys can be generated: MEL=0: 0b0000000 MEL=1: 0b0000001 MEL=2: 0b0000011 MEL=3: 0b0000111 MEL=3: 0b0001111 MEL=5: 0b0011111 MEL=6: 0b0111111 Together with the mask, the following kinds of rules may be created: Exact match. Fx. MEL=2: 0b0000011 Below. Fx. MEL<=4: 0b000XXXX Above. Fx. MEL>=5: 0bXX11111 Between. Fx. 3<= MEL<=5: 0b00XX1111, where 'X' means don't care. | 16 | X | Table 49 • VCAP CLM X16 Key Details (continued) | Field Name | Description | Size | NORMAL_7TUPLE<br>CUSTOM_1 | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------| | L4_RNG | Range mask. Range types: SPORT, DPORT, SPORT or DPORT, VID, DSCP, custom. Input into range checkers is taken from frame, except DSCP value, which is the remapped DSCP value from basic classification. | 8 | Х | | CUSTOM1 | 64 bytes payload starting from current frame pointer position, as controlled by VCAP CLM actions. Note that if frame_type==ETH, payload is retrieved from a position following the Ethernet layer. For example, after DMAC, SMAC, 0-3 VLAN tags, and EtherType. | 512 | х | ### 3.13.7 VCAP CLM Actions VCAP CLM supports four different actions, which can be used for different purposes. The actions have different sizes and must be paired with the keys as listed in the following table. Table 50 • VCAP CLM Action Selection | Action Name | Size | Action Type | |----------------|---------------------|-------------| | MLBS_REDUCED | 1 word<br>69 bits | X1 type | | CLASSIFICATION | 2 words<br>124 bits | X2 type | | MLBS | 2 words<br>127 bits | X2 type | | FULL | 4 words<br>250 bits | X4 type | Any VCAP CLM action can be used with any of VCAP CLM keys. However, if the action's type is larger than the associated key's type (for instance FULL action of type X4 with TRI\_VID key of type X8), then the entry row in the VCAP cannot be fully utilized. The following table provides details for all VCAP CLM actions. When programming an action in VCAP CLM, the associated action fields listed must be programmed in the listed order with the first field in the table starting at bit 0 in the action. Table 51 • VCAP CLM Actions | Field Name | Description and Encoding | S<br>ALBS<br>MLBS_REDUCEI<br>CLASSIFICATION | |------------|--------------------------|---------------------------------------------| | X2_TYPE | X2 type. | 1 x x | | | 0: MLBS. | | | | 1: Classification. | | Table 51 • VCAP CLM Actions (continued) | Field Name | Description and Encoding | Size | ALBS | MLBS REDUCED | CLASSIFICATION | FULL | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------|------| | DSCP_ENA | If set, use DSCP_VAL as classified DSCP value. | 1 | | | | X | | DSCP_VAL | See DSCP_ENA. | 6 | | | | X | | COSID_ENA | If set, use COSID_VAL as classified COSID value. | 1 | Х | Х | Х | | | COSID_VAL | See COSID_ENA. | 3 | Х | Х | Х | | | QOS_ENA | If set, use QOS_VAL as classified QoS class. | 1 | | х | | | | QOS_VAL | See QOS_ENA. | 3 | | х | | | | DP_ENA | If set, use DP_VAL as classified drop precedence level. | 1 | | Х | | | | DP_VAL | See DP_ENA. | 2 | | Х | | | | DEI_ENA | If set, use DEI VAL as classified DEI value. | 1 | | | | X | | DEI_VAL | See DEI ENA. | 1 | | | | X | | PCP_ENA | If set, use PCP_VAL as classified PCP value. | 1 | | | | X | | PCP_VAL | See PCP_ENA. | 3 | | | | X | | MAP_LOOKUP_SEL | Selects which of the two QoS Mapping Table lookups that MAP_KEY and MAP_IDX are applied to. 0: No changes to the QoS Mapping Table lookup. That is, MAP_KEY and MAP_IDX are not used. 1: Update key type and index for QoS Mapping Table lookup #0. 2: Update key type and index for QoS Mapping Table lookup #1. 3: Reserved. MLBS_REDUCED: Use 8 bits from COSID_ENA (LSB), COSID_VAL, QOS_ENA, and QOS_VAL (MSB) as MAP_IDX. COSID and QOS class cannot be assigned at the same time. MAP_KEY is always 3 (TC). | 2 | | X | х | x | | MAP_KEY | Key type for QoS mapping table lookup. 0: DEI0, PCP0 (outer tag). 1: DEI1, PCP1 (middle tag). 2: DEI2, PCP2 (inner tag). 3: TC based on conf.mpls_sel_tc_only_ena it is either possible to always IFH.ENCAP.MPLS_TC or to only use TC it extracted by label stack. 4: PCP0 (outer tag). 5: Reserved. 6: DSCP if available, otherwise none (64 entries). 7: DSCP if available, otherwise DEI0, PCP0 (outer tag) if available using MAP_IDX+8, otherwise none (80 entries). | 3 | X | | X | X | | MAP_IDX | Index for QoS mapping table lookup. Index bits 10:3 into 2K mapping table. Bits 2:0 are always 0. | 8 | Х | | х | Х | Table 51 • VCAP CLM Actions (continued) | Field Name | Description and Encoding | Size | MLBS | MLBS_REDUCED | CLASSIFICATION | FULL | |----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------|------| | VID_ADD_REPLACE_SEL | Controls the classified VID. 0: New VID = old VID + VID_VAL. 1: New VID = VID_VAL. 2: New VID = VID from frame's second tag (middle tag) if available, otherwise VID_VAL. 3: New VID = VID from frame's third tag (inner tag) if available, otherwise VID_VAL. | 2 | x | | | Х | | VID_VAL | By default, add this value to the current classified VID. Note this is not the VID used as key into VCAP CLM. If the classified VID + VID_ADD_VAL exceeds the range of 12 bit then a wrap around is done. | 12 | х | | х | х | | VLAN_POP_CNT_ENA | If set, VLAN_POP_CNT is used. | 1 | | | Х | Х | | VLAN_POP_CNT | VLAN pop count: 0, 1, 2, or 3 tags. Post-processing of VLAN_POP_CNT: If VLAN_POP_CNT exceeds the actual number of tags in the frame, it is reduced to match the number of VLAN tags in the frame. | 2 | | | х | Х | | VLAN_WAS_TAGGED | Controls the WAS_TAGGED setting forwarded to the rewriter. 0: No changes to WAS_TAGGED. 1: Set WAS_TAGGED to 0. 2: Set WAS_TAGGED to 1. 3: Reserved. | 2 | | | X | X | | ISDX_ADD_REPLACE_SEL | Controls the classified ISDX. 0: New ISDX = old ISDX + ISDX_VAL. 1: New ISDX = ISDX_VAL. | 1 | Х | Х | Х | х | | ISDX_VAL | See ISDX_ADD_REPLACE_SEL. | 9 | Х | Х | Х | Х | | MASK_MODE | Controls how PORT_MASK is applied. 0: OR_DSTMASK: Or PORT_MASK with destination mask. 1: AND_VLANMASK: And PORT_MASK with VLAN mask. The actual ANDing with the VLAN mask is performed after the ANA_L3 block has determined the VLAN mask. 2: REPLACE_PGID: Replace PGID port mask from MAC table lookup by PORT_MASK. 3: REPLACE_ALL: Use PORT_MASK as final destination set replacing all other port masks. 4: REDIR_PGID: Redirect using PORT_MASK[7:0] as PGID table index. See PORT_MASK for extra configuration options. 5: OR_PGID_MASK: Or PORT_MASK with PGID port mask from MAC table lookup. 6: Reserved. 7: Not applicable. Note that for REDIR_PGID, REPLACE_ALL, and VSTAX, the port mask becomes "sticky" and cannot be modified by subsequent processing steps. The CPU port is untouched by MASK_MODE. | 3 | | | | х | Table 51 • VCAP CLM Actions (continued) | Field Name | Description and Encoding | Size | MLBS | MLBS REDUCED | CLASSIFICATION | FULL | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------|------| | PORT_MASK | Port mask. MASK_MODE=4 (REDIR_PGID): PORT_MASK[52]: SRC_PORT_MASK_ENA. If set, SRC_PORT_MASK is AND'ed with destination result. PORT_MASK[51]: AGGR_PORT_MASK_ENA. If set, AGGR_PORT_MASK is AND'ed with destination result. PORT_MASK[50]: VLAN_PORT_MASK_ENA. If set, VLAN_PORT_MASK is AND'ed with destination result. PORT_MASK[7:0]: PGID table index. | 53 | | | | x | | RT_SEL | Controls routing. 0: No change to routing. 1: Enable routing. 2: Disable routing. | 2 | | | | Х | | FWD_DIS | If set, forwarding of the frame to front ports is disabled. CPU extraction is still possible. | 1 | Х | х | Х | | | CPU_ENA | Copy frame to specified CPU extraction queue. | 1 | Х | Х | Х | Х | | CPU_Q | CPU extraction queue when frame is forwarded to CPU. | 3 | Х | Х | Х | х | | MIP_SEL | Controls the MIP selection. 0: No change in MIP selection. 1: Enable MIP. 2: Disable MIP. If enabled, the MIP_IDX is given by the IPT table. OAM_Y1731_SEL determines the number of VLAN tags required for processing a frame in the MIP. | 2 | | | X | X | | OAM_Y1731_SEL | Selects which frames are detected as OAM frames by MEP and MIP. 0: No change in detection. 1: Disable OAM. 2: Detect untagged OAM. 3: Detect single tagged OAM. 4: Detect double tagged OAM. 5: Detect triple tagged OAM. 6: Enable Y1731 OAM unconditionally. 7: Enable any tags and EtherType as OAM unconditionally. | 3 | x | | X | х | | RSVD_LBL_VAL | Use when MPLS_OAM_TYPE = 2, 4, or 5. Configures the reserved label used as OAM label for this MEP or MIP. Only the lower 4 bits of the label value is configured. Normally this field should be set to 13 (GAL label value). If MPLS_OAM_TYPE is set to 2, 4, or 5 and action record does not include RSVD_LBL_VAL, then a value of 13 (GAL label value) is used. | 4 | | | | Х | | TC_ENA | Use the label's TC as classified TC. | 1 | | Х | | | | TTL_ENA | Use the label's TTL as classified TTL | 1 | | Х | | | Table 51 • VCAP CLM Actions (continued) | Field Name | Description and Encoding | Size | MLBS | MLBS_REDUCED | CLASSIFICATION | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------| | TC_LABEL | Selects which label provides the classified TC. 0: Use TC from LSE #0 (if available). 1: Use TC from LSE #1 (if available). 2: Use TC from LSE #2 (if available). 3: Do not update TC. LSE #0 is top LSE, followed by LSE #1, and so on. | 2 | Х | | Х | | TTL_LABEL | Selects which label provides the classified TTL. 0: Use TTL from LSE #0 (if available). 1: Use TTL from LSE #1 (if available). 2: Use TTL from LSE #2 (if available). 3: Do not update TTL. LSE #0 is top LSE, followed by LSE #1, and so on. | 2 | Х | | х | | NUM_VLD_LABELS | Number of valid labels, without reserved labels. Position of "deepest" label to be processed. Numbering starts with 0 at top LSE. If reserved labels are "skipped", then these are not counted in NUM_VLD_LABELS. Valid range: 0-2. Use of NUM_VLD_LABELS is dependent on FWD_TYPE as follows: FWD_TYPE=0: NUM_VLD_LABELS is not used. FWD_TYPE=1: Position of PW label. FWD_TYPE=2: Position of label to be swapped. LSEs above the swap label are popped. FWD_TYPE=3: Position of deepest label, which is to be popped. | 2 | X | | x | | FWD_TYPE | Forwarding type. 0: NONE 1: TERMINATE_PW - Terminate pseudo wire. 2: LBL_SWAP - Swap label 3: LBL_POP - Pop Labels 3: CTRL_PDU FWD_TYPE: NONE | 4 | x | Х | x | | | FWD_TYPE: TERMINATE_PW Terminate pseudo wire. NXT_NORM_W16_OFFSET or NXT_NORM_W32_OFFSET must be set to move frame pointer to CW/ACH if present, and otherwise to the PDU that follows the MPLS label stack. NUM_VLD_LABELS must be set to the position of the PW label. NXT_TYPE_AFTER_OFFSET must be set to CW if PW uses CW, otherwise ETH. NXT_NORMALIZE must be set to 1 to have MPLS Link Layer, LSEs and CW stripped. MPLS_OAM_TYPE can be set to values 0-4 to disable/enable OAM PDU detection. | | | | | | Field Name | Description and Encoding | Size | MLBS<br>MLBS_REDUCED<br>CLASSIFICATION<br>FULL | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------------------| | | FWD_TYPE: LBL_SWAP Swap label at position NUM_VLD_LABELS. Any label above the swap label are popped. NXT_NORM_W16_OFFSET or NXT_NORM_W32_OFFSET must be set to move frame pointer to swap label. NUM_VLD_LABELS must be set to the position of the swap label. NXT_NORMALIZE must be set to 1 to have MPLS Link Layer and, possibly, labels stripped. NXT_TYPE_AFTER_OFFSET must be set to MPLS. OAM PDUs are not detected, though frames with reserved label values as well as frames with TTL expiry can be redirected to CPU. | | | | | FWD_TYPE: LBL_POP Pop labels. NXT_NORM_W16_OFFSET or NXT_NORM_W32_OFFSET must be set to move frame pointer past popped labels. NUM_VLD_LABELS must be set to the position of the deepest label to be popped. NXT_NORMALIZE must be set to 1. NXT_TYPE_AFTER_OFFSET should normally be set to MPLS. NXT_TYPE_AFTER_OFFSET may be set to CW when terminating LSP with IP frames for CPU processing. MPLS_OAM_TYPE can be set to 0, 5, or 6 to disable/enable OAM PDU detection. | | | | | FWD_TYPE: CTRL_PDU MPLS_OAM_TYPE controls PDU type (as encoded in IFH.ENCAP.PDU_TYPE): 0: NONE. 1: OAM_Y1731. 2: OAM_MPLS_TP. 3: PTP. 4: IP4_UDP_PTP. 5: IP6_UDP_PTP. 6: Reserved. 7: SAM_SEQ. | | | | | OAM_Y1731_SEL controls PDU_OFFSET: 0: No change to PDU offset. 1: ETH_PAYLOAD. 2: IP_PAYLOAD. 3: Non-normalized offset (PDU_OFFSET = difference between normalized and non-normalized payload). | | | | Field Name | Description and Encoding | Size | MLBS | MLBS_REDUCED | CLASSIFICATION<br>FULL | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|------------------------| | MPLS_OAM_TYPE | When either MIP or MEP OAM detection is enabled (MPLS_MIP_ENA or MPLS_MEP_ENA), MPLS_OAM_TYPE configures in which control channel to look for OAM. | 3 | | Х | Х | | | For FWD_TYPE = 1 (TERMINATE_PW), MPLS_OAM_TYPE configures which Control Channel Type is used for forwarding PW OAM: 1: Detect Vccv1 OAM 2: Detect Vccv2 OAM 3: Detect Vccv3 OAM 4: Detect Vccv4 OAM | | | | | | | For FWD_TYPE = 3 (LSP_POP), MPLS_OAM_TYPE configures which Control Channel Type is used for LSP OAM: 5: LSP OAM under GAL found at pos NUM_VLD_LABELS + 1 6: LSP OAM under GAL found at pos NUM_VLD_LABELS | | | | | | | For FWD_TYPE = 4 (CTRL_PDU), MPLS_OAM_TYPE configures directly the control type and PDU position (with OAM_Y1731_SEL and NXT_NORM_W16_OFFSET/NXT_NORM_W32_OFFSET) and bypasses post-processing: 1: OAM_Y1731 2: OAM_MPLS_TP 3: PTP 4: IP4_UDP_PTP 5: IP6_UDP_PTP 6: Reserved 7: SAM_SEQ | | | | | | MPLS_MEP_ENA | Enables detection of MPLS MEP. If enabled and if frame is not selected for MIP extraction, it is determined whether it is a valid frame OAM PDU according to the MPLS_OAM_TYPE. | 1 | Х | Х | х | | MPLS_MIP_ENA | Enables detection of MPLS MIP. If enabled, the iTTL will be checked for expiry. In case of iTTL expiry, the frame is checked if it is a valid OAM PDU according to the MPLS_OAM_TYPE. | 1 | Х | Х | х | | MPLS_OAM_FLAVOR | If OAM detection is enabled, this setting determines if the G-ACH/ACH selected by MPLS_OAM_TYPE is checked for Channel Type = 0x8902. This configuration applies only to MEP OAM detection. OAM MIP detection is extracted to SW based on from the configured Control Channel Type, regardless of the channel type, because all OAM MIP processing is done in software. 0: G8113_2 (BFD, and so on). 1: G8113_1 (BHH). | 1 | x | X | х | | MPLS_IP_CTRL_ENA | Enables IP directly under MPLS based on IP profiles. | 1 | Х | Х | Х | Table 51 • VCAP CLM Actions (continued) | Field Name | Description and Encoding | Size | MLBS | MLBS_REDUCED | CLASSIFICATION | FULL | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------|------| | CUSTOM_ACE_ENA | Controls S2 custom rule selection: Bit 0: Selects custom key to use (0: CUSTOM_1, 1: CUSTOM_2). Bit 1: Enables custom key for first lookup. Bit 2: Enables custom key for second lookup. | 3 | | | <u> </u> | X | | CUSTOM_ACE_OFFSET | Selects custom data extraction point: 0: Current position (after IFH.WORD16_POP_CNT). Only applicable to frame type ETH. 1: Link layer payload (after VLAN tags and EtherType for ETH, after control word for CW). 2: Link layer payload + 20 bytes. 3: Link layer payload + 40 bytes. | 2 | | | | х | | PAG_OVERRIDE_MASK | Bits set in this mask override the previous PAG result with the PAG_VAL value from this action. | 8 | Х | | Х | Х | | PAG_VAL | PAG is updated using the following bit mask operation: PAG = (PAG and ~PAG_OVERRIDE_MASK) (PAG_VAL and PAG_OVERRIDE_MASK). PAG can be used to tie VCAP CLM lookups with VCAP IS2 lookups. The PAG default value is configurable per port in ANA_CL:PORT:PORT_ID_CFG.PAG_VAL. | 8 | Х | | X | х | | RESERVED | Must be set to 0. | 7 | | | | Х | | LPORT_NUM | Use this value for LPORT and IFH.SRC_PORT when LPORT_ENA is set. | 6 | | | | Х | | MATCH_ID | Logical ID for the entry. If the frame is forwarded to the CPU, the MATCH_ID is extracted together with the frame. MATCH_ID is used together with MATCH_ID_MASK as follows: MATCH_ID = (MATCH_ID and ~MATCH_ID_MASK) (MATCH_ID and MATCH_ID_MASK). The result is placed in IFH.CL_RSLT. | 12 | | | | Х | | MATCH_ID_MASK | Bits set in this mask overrides the previous MATCH_ID with the MATCH_ID value from this action. | 12 | | | | Х | | PIPELINE_FORCE_ENA | If set, use PIPELINE_PT unconditionally. Overrule previous settings of pipeline point. Use the following pipeline actions: 0: No change to PIPELINE_PT or PIPELINE_ACT. 1: Change PIPELINE_PT and set PIPELINE_ACT=XTR 2: Change PIPELINE_PT and set PIPELINE_ACT=INJ (PIPELINE_ACT_SEL=0) or INJ_MASQ (PIPELINE_ACT_SEL=1) 3: Change PIPELINE_PT and set PIPELINE_ACT=LBK_QS (PIPELINE_ACT_SEL=0) or LBK_ASM (PIPELINE_ACT_SEL=1) | 2 | x | x | X | x | | Field Name | Description and Encoding | Size | MLBS | MLBS_REDUCED | CASSIFICATION | FULL | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|---------------|----------| | PIPELINE_PT_REDUCED | Pipeline point used if PIPELINE_FORCE_ENA is set: 0: ANA_CLM 1: ANA_OU_MIP 2: ANA_IN_MIP 3: ANA_PORT_VOE 4: ANA_OU_VOE 5: ANA_IN_VOE 6: REW_IN_VOE 7: REW_OU_VOE | 3 | | <u>2</u> | <u>o</u> | <u> </u> | | PIPELINE_PT | Pipeline point used if PIPELINE_FORCE_ENA is set: 0: NONE 1: ANA_VRAP 2: ANA_PORT_VOE 3: ANA_CL 4: ANA_CLM 5: ANA_IPT_PROT 6: ANA_OU_MIP 7: ANA_OU_SW 8: ANA_OU_PROT 9: ANA_OU_VOE 10: ANA_MID_PROT 11: ANA_IN_VOE 12: ANA_IN_PROT 13: ANA_IN_SW 14: ANA_IN_MIP 15: ANA_UNE | 5 | x | , | X | x | | Field Name | Description and Encoding | Sizo | MLBS | MLBS_REDUCED | LASSIFICATION | ULL | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|------------------|------------| | NXT_KEY_TYPE | Enforces specific key type for next VCAP CLM lookup. 0: No overruling of default key type selection. 1: MLL 2: SGL_MLBS 3: DBL_MLBS 4: TRI_MLBS 5: TRI_VID or TRI_VID_IDX depending on configuration per VCAP CLM lookup in ANA_CL::CLM_KEY_CFG.CLM_TRI_VID_SEL 6: LL_FULL 7: NORMAL (with normal SRC information) 8: NORMAL with DST information This is a modified version of NORMAL key type, where - the frame's DMAC is used in the L2_SMAC key field. - the frame's IPv4 DIP is used in the L3_IP4_SIP key field. 9: NORMAL_7TUPLE 10: NORMAL_7TUPLE 10: NORMAL_5TUPLE_IP4 11: PURE_5TUPLE_IP4 12: CUSTOM1 13: CUSTOM2 14: CUSTOM4 15: CLMS_DONE Complete - disable all remaining VCAP CLM lookups. | 4 | | X | <mark>ठ</mark> х | <u>ш</u> х | | NXT_NORM_W32_OFFSET | 4-byte value to be added to frame pointer. If any reserved MPLS labels were "skipped" during key generation before VCAP CLM lookup, then these are not counted in NXT_NORM_W32_OFFSET, because frame pointer is automatically moved past "skipped" labels. If both NXT_NORM_W32_OFFSET and NXT_OFFSET_FROM_TYPE are specified, then frame pointer is first modified based on NXT_OFFSET_FROM_TYPE and then moved further based on NXT_NORM_W32_OFFSET. | 2 | | х | | | | NXT_NORM_W16_OFFSET | 2-byte value to be added to frame pointer. If any reserved MPLS labels were skipped during key generation before VCAP CLM lookup, then these are not be counted in NXT_NORM_W16_OFFSET, because frame pointer is automatically moved past "skipped" labels. If both NXT_NORM_W16_OFFSET and NXT_OFFSET_FROM_TYPE are specified, then frame pointer is first modified based on NXT_OFFSET_FROM_TYPE and then moved further based on NXT_NORM_W16_OFFSET. | 5 | х | | x | x | | | | | MLBS | MLBS_REDUCED | CLASSIFICATION | | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|----------------|------| | Field Name | Description and Encoding | Size | M | ¥ | C | FULL | | NXT_OFFSET_FROM_TYPE | Move frame pointer depending on type of current protocol layer. 0: NONE. No frame pointer movement. 1: SKIP_ETH. Skip Ethernet layer. If frame type is ETH, then move frame pointer past DMAC, SMAC and 0-3 VLAN tags. 2: SKIP_IP_ETH - Skip IP layer and preceding Ethernet layer (if present). If frame type is ETH: Move frame pointer past DMAC, SMAC, 0-3 VLAN tags and IPv4/IPv6 header. If frame type is CW and IP version is 4 or 6: Move frame pointer past IPv4/IPv6 header. For IPv4 header frame pointer is also moved past any IPv4 header options. | 2 | х | | х | x | | NXT_TYPE_AFTER_OFFSET | 3: RSV. Reserved. Protocol layer (frame_type) at frame pointer position after update based on NXT_OFFSET_FROM_TYPE and NXT_NORM_W16_OFFSET or NXT_NORM_W32_OFFSET. Frame_type is only changed if one of the following conditions is true: a) Frame pointer is moved. b) Frame_type going into VCAP CLM was DATA and NXT_KEY_TYPE != 0. 0: ETH. Frame pointer points to start of DMAC. 1: CW (IP / MPLS PW CW / MPLS ACH). Frame pointer points to MPLS CW/ACH or IP version. 2: MPLS. Frame pointer points to MPLS label. 3: DATA. "Raw" data, such as unknown protocol type. | 2 | х | х | х | х | | NXT_NORMALIZE | Instruct rewriter to strip all frame data up to current position of frame pointer. The stripped data is not used for forwarding. When a VCAP CLM action is processed, frame pointer is updated before NXT_NORMALIZE is applied. Note The rewriter can strip a maximum of 42 bytes. | 1 | х | х | X | X | Table 51 • VCAP CLM Actions (continued) | NXT_IDX_CTRL Controls the generation of the G_IDX used in the VCAP CLM 3 x x x x next lookup: 0: TRANSPARENT. G_IDX of previous parser step is carried forward to next parser step. 1: REPLACE. Replace previous G_IDX value with NXT_IDX of this result. 2: ADD. Add NXT_IDX of this result to G_IDX of previous parser step. 3: ISDX.Use ISDX as G_IDX. 4: RPL_COND_ISDX. Replace previous G_IDX value with NXT_IDX of this result. Assign ISDX to ISDX_VAL for terminated data. 5: Use ISDX with NXT_IDX for non terminated data (not CPU redir and MEP traffic). 6: Replace ISDX with NXT_IDX. Use ISDX as G_IDX in next key for non terminated data. 7: Reserved. NXT_IDX Index used as part of key (field G_IDX) in the next lookup. 12 x x x x RESERVED Must be set to 0. 1 x x x PIPELINE_ACT_SEL Used by PIPELINE_FORCE_ENA to control PIPELINE_ACT, see 1 x x x PIPELINE_FORCE_ENA. LPORT_ENA Controls if LPORT_NUM updates LPORT and IFH.SRC_PORT. 1 | Field Name | Description and Encoding | Size | MLBS | MLBS REDUCED | | FULL | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|---|------| | RESERVED Must be set to 0. 1 x x x PIPELINE_ACT_SEL Used by PIPELINE_FORCE_ENA to control PIPELINE_ACT, see 1 x x x PIPELINE_FORCE_ENA. | NXT_IDX_CTRL | next lookup: 0: TRANSPARENT. G_IDX of previous parser step is carried forward to next parser step. 1: REPLACE. Replace previous G_IDX value with NXT_IDX of this result. 2: ADD. Add NXT_IDX of this result to G_IDX of previous parser step. 3: ISDX.Use ISDX as G_IDX. 4: RPL_COND_ISDX. Replace previous G_IDX value with NXT_IDX of this result. Assign ISDX to ISDX_VAL for terminated data. 5: Use ISDX with NXT_IDX for non terminated data (not CPU redir and MEP traffic). 6: Replace ISDX with NXT_IDX. Use ISDX as G_IDX in next key for non terminated data. | 3 | х | х | X | x | | PIPELINE_ACT_SEL Used by PIPELINE_FORCE_ENA to control PIPELINE_ACT, see 1 x x x PIPELINE_FORCE_ENA. | NXT_IDX | Index used as part of key (field G_IDX) in the next lookup. | 12 | Χ | Х | Х | Х | | PIPELINE_FORCE_ENA. | RESERVED | Must be set to 0. | 1 | Х | | Х | Х | | LPORT_ENA Controls if LPORT_NUM updates LPORT and IFH.SRC_PORT. 1 x | PIPELINE_ACT_SEL | | 1 | Х | | Х | х | | | LPORT_ENA | Controls if LPORT_NUM updates LPORT and IFH.SRC_PORT. | 1 | | | | Х | # 3.14 Analyzer Classifier The analyzer classifier (ANA\_CL) handles frame classification. This section provides information about the following tasks performed by ANA\_CL. - Basic classification. Initial classification including frame filtering, VLAN and QoS classification. - VCAP CLM processing. Advanced TCAM-based classification. - QoS mappings. Mapping and translations of incoming QoS parameters. #### 3.14.1 Basic Classifier The analyzer classifier includes a common basic classifier that determines the following basic properties that affect the forwarding of each frame through the switch. - VLAN tag extraction. Parses the frame's VLAN tags in accordance with known tag protocol identifier values. - Pipeline point evaluation. For injected and looped frames, ensures ANA\_CL is part of the frame's processing flow. - Routing control. Evaluates if a frame can be routed in terms of VLAN tags. - · Frame acceptance filtering. Drops illegal frame types. - QoS classification. Assigns one of eight QoS classes to the frame. - Drop precedence (DP) classification. Assigns one of four drop precedence levels to the frame. - DSCP classification. Assigns one of 64 DSCP values to the frame. - VLAN classification. Extracts tag information from the frame or use the port VLAN. - Link aggregation code generation. Generates the link aggregation code. - Layer 2 and Layer 3 control protocol handling. Determines CPU forwarding, CPU extraction queue number, and dedicated protocol QoS handling. - · Versatile Register Access Protocol (VRAP) handling. Extracts VRAP frames to VRAP engine. - · Logical port mapping. Maps physical ingress port to logical port used by analyzer. The outcome of the classifier is the basic classification result, which can be overruled by more intelligent frame processing with VCAP classification matching (VCAP CLM). ### 3.14.1.1 VLAN Tag Extraction The following table lists the register associated with VLAN tag extraction. Table 52 • VLAN Tag Extraction Register | Register | Description | Replication | |-----------------------|-----------------------------------------------------------|-------------| | ANA_CL::VLAN_STAG_CFG | Ethertype for S-tags in addition to default value 0x88A8. | 3 | Up to five different VLAN tags are recognized by the device. - Customer tags (C-tags), which use TPID 0x8100. - Service tags (S-tags), which use TPID 0x88A8 (IEEE 802.1ad). - Service tags (S-tags), which use a custom TPID programmed in ANA\_CL::VLAN\_STAG\_CFG. Three different custom TPIDs are supported. The device can parse and use information from up to three VLAN tags of any of the types previously described. Various blocks in the device use Layer 3 and Layer 4 information for classification and forwarding. Layer 3 and Layer 4 information can be extracted from a frame with up to three VLAN tags. Frames with more than three VLAN tags are always considered non-IP frames. #### 3.14.1.2 Pipeline Point Evaluation The basic classifier is active for all frames with no active pipeline information for frames injected before or at pipeline point ANA CL and for frames extracted at or after pipeline point ANA CL. Frames looped by the rewriter (PIPELINE\_ACT = LBK\_ASM) have their REW pipeline point changed to an ANA pipeline point, which indicates the point in the analyzer flow in ANA where they appear again after being looped. The following pipeline point translation are handled. - PIPELINE PT = REW PORT VOE is changed to ANA PORT VOE - PIPELINE\_PT = REW\_OU\_VOE is changed to ANA\_OU\_VOE - PIPELINE\_PT = REW\_IN\_VOE is changed to ANA\_IN\_VOE - PIPELINE\_PT = REW\_SAT is changed to ANA\_CLM - PIPELINE\_PT = REW\_OU\_VOE is changed to ANA OU SW - PIPELINE\_PT = REW\_IN\_SW is changed to ANA\_IN\_SW #### 3.14.1.3 Routing Tag Control The basic classifier determines which IP frames can be routed in terms of the VLAN tag types. If a frame can be routed, it is signalled to ANA\_L3, where the routing decision is made. The following table lists the register associated with routing control. Table 53 • Routing Tag Control Register | Register | Description | Replication | |-----------------------------------------------------|--------------------------------------------------------------------------------------------|-------------| | ANA_CL:PORT:VLAN_TPID_CTRL.<br>BASIC_TPID_AWARE_DIS | Configures valid TPIDs for routing. This configuration is shared with VLAN classification. | Per port | | ANA_CL:PORT:VLAN_TPID_CTRL.<br>RT_TAG_CTRL | Configures number of valid VLAN tags in routable frames. | Per port | In order for a frame to be routed, the frame's VLAN tags must all be valid, and routing must be enabled for the number of VLAN tags in the frame. The settings in BASIC\_TPID\_AWARE\_DIS define each of three processed VLAN tags of which TPID values are valid for routing. The settings in RT\_TAG\_CTRL define the number of valid VLAN tags that must be present in routable frames. **Example:** If routing is enabled for single-tagged frames with TPID=0x8100, configure the following: - BASIC\_TPID\_AWARE\_DIS = 0x7FFE. This invalidates all TPIDs except TPID = 0x8100 for outer most VLAN tag. - RT TAG CTRL = 0x2. This enables routing of frames with one accepted tag only. In this example, if an untagged frame is received, it is not routable because routing is not enabled for untagged frames. If a single-tagged frame is received with for instance TPID=0x88A8 or a double-tagged frame is received with for instance TPID=0x8100 for outer tag and TPID=0x8100 for inner tag, they are not routable because not all their VLAN tags are valid. **Example:** To configure routing on a VLAN unaware port where routing is enabled for untagged frames only, set RT\_TAG\_CTRL = 0x1 to enable routing of untagged frames only. ### 3.14.1.4 Frame Acceptance Filtering The following table lists the registers associated with frame acceptance filtering. Table 54 • Frame Acceptance Filtering Registers | Register | Description | Replication | |--------------------------|----------------------------------------|----------------| | ANA_CL::FILTER_CTRL | Configures filtering of special frames | Per port | | ANA_CL::VLAN_FILTER_CTRL | Configures VLAN acceptance filter | Three per port | Based on the configurations in the FILTER\_CTRL register, the classifier can discard certain frame types that are normally not allowed to enter the network, such as the following. - Frames with a multicast source MAC address (bit 40 in address is set) - Frames with a null source or null destination MAC address (address = 0x000000000000) The VLAN acceptance filter decides whether a frame's VLAN tagging is allowed on the port. It has three stages where each stage checks one of the up to three processed VLAN tags. Each stage is programmable independently of the other stages in ANA\_CL:PORT:VLAN\_FILTER\_CTRL. The following illustration shows the flowchart for the VLAN acceptance filter. Figure 23 • VLAN Acceptance Filter The VLAN acceptance filter does not apply to untagged Layer 2 control protocol frames. They are always accepted even when VLAN tags are required for other frames. The following frames are recognized as Layer 2 control protocol frames: - Frames with DMAC = 0x0180C2000000 through 0x0180C200000F - Frames with DMAC = 0x0180C2000020 through 0x0180C200002F - Frames with DMAC = 0x0180C2000030 through 0x0180C200003F Tagged Layer 2 control protocol frames are handled by the VLAN acceptance filter like normal tagged frames and they must comply with the filter settings to be accepted. Frames discarded by the frame acceptance filters are assigned PIPELINE\_PT = ANA\_CL and learning of the frames' source MAC addresses are at the same time disabled. ### 3.14.1.5 QoS, DP, and DSCP Classification This section provides information about the functions in the QoS, DP, and DSCP classification. The three tasks are described as one, because the tasks have functionality in common. The following table lists the registers associated with QoS, DP, and DSCP classification. Table 55 • QoS, DP, and DSCP Classification Registers | Register | Description | Replication | |-----------------------------------|---------------------------------------------------------------------------------------|-------------------------------------------| | ANA_CL:PORT:QOS_CFG | Configuration of the overall classification flow for QoS, DP, and DSCP. | Per port | | ANA_CL:PORT:PCP_DEI_MAP_CFG | Port-based mapping of (DEI, PCP) to (DP, QoS). | Per port per DEI per<br>PCP (16 per port) | | ANA_CL::DSCP_CFG | DSCP configuration per DSCP value. | Per DSCP (64) | | ANA_CL::QOS_MAP_CFG.DSCP_REWR_VAL | DSCP rewrite values per QoS class. | Per QoS class (8) | | ANA_CL::CPU_8021_QOS_CFG | Configuration of QoS class for Layer 2 control protocol frames redirected to the CPU. | Per Layer 2 protocol<br>address (32) | The basic classification provides the user with control of the QoS, DP, and DSCP classification algorithms. The result of the basic classification are the following frame properties: - The frame's QoS class. This class is encoded in a 3-bit field, where 7 is the highest priority QoS class and 0 is the lowest priority QoS class. The QoS class is used by the queue system when enqueuing frames and when evaluating resource consumptions, for policing, statistics, and rewriter actions. The QoS class is carried internally in the IFH field IFH.VSTAX.QOS.CL\_QOS. - The frame's DP level. This level is encoded in a 2-bit field, where frames with DP = 3 have the highest probability of being dropped and frames with DP = 0 have the lowest probability. The DP level is used by the MEF compliant policers for measuring committed and peak information rates, for restricting memory consumptions in the queue system, for collecting statistics, and for rewriting priority information in the rewriter. The DP level is incremented by the policers if a frame is exceeding a programmed committed information rate. The DP level is carried internally in the IFH field IFH.VSTAX.QOS.CL DP. - The frame's DSCP. This value is encoded in a 6-bit fields. The DSCP value is forwarded with the frame to the rewriter where it is translated and rewritten into the frame. The DSCP value is only applicable to IPv4 and IPv6 frames. The DSCP is carried internally in the IFH field IFH.QOS.DSCP. The classifier looks for the following fields in the incoming frame to determine the QoS, DP, and DSCP classification: - Priority Code Point (PCP) when the frame is VLAN tagged or priority tagged. There is an option to use the inner tag for double tagged frames (VLAN\_CTRL.VLAN\_TAG\_SEL). - Drop Eligible Indicator (DEI) when the frame is VLAN tagged or priority tagged. There is an option to use the inner tag for double tagged frames (VLAN\_CTRL.VLAN\_TAG\_SEL). - DSCP (all 6 bits, both for IPv4 and IPv6 packets). The classifier can look for the DSCP value behind up to three VLAN tags. For non-IP frames, the DSCP is 0 and it is not used elsewhere in the switch. - Destination MAC address (DMAC) for L2CP frames. Layer 2 control protocol frames that are redirected to the CPU are given a programmable QoS class independently of other frame properties. The following illustration shows the flow chart of basic QoS classification. Figure 24 • Basic QoS Classification Flow Chart The following illustration shows the flow chart for basic DP classification. Figure 25 • Basic DP Classification Flow Chart The following illustration shows the flow chart for basic DSCP classification. Figure 26 • Basic DSCP Classification Flow Chart Note that the DSCP translation part is common for both QoS, DP, and DSCP classification, and the DSCP trust part is common for both QoS and DP classification. The basic classifier has the option to overrule rewriter configuration (REW:PORT:DSCP\_MAP) that remaps the DSCP value at egress. When ANA\_CL:PORT:QOS\_CFG.DSCP\_KEEP\_ENA is set, the rewriter is instructed not to modify the frame's DSCP value (IFH.QOS.TRANSP\_DSCP is set to 1). The basic classified QoS, DP, and DSCP can be overwritten by more intelligent decisions made in the VCAP CLM. #### 3.14.1.6 VLAN Classification The following table lists the registers associated with VLAN classification. Table 56 • VLAN Configuration Registers | Register | Description | Replication | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------| | ANA_CL:PORT:VLAN_CTRL | Configures the port's processing of VLAN information in VLAN-tagged and priority-tagged frames. Configures the port-based VLAN. | | Table 56 • VLAN Configuration Registers (continued) | ANA_CL::VLAN_STAG_CFG | Configures custom S-tag TPID value. | 3 | |--------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------| | ANA_CL:PORT:PCP_DEI_TRANS_CFG | Port-based translation of (DEI, PCP) to basic classified (DEI, PCP). | Per port per<br>DEI per PCP<br>(16 per port) | | ANA_CL:PORT:VLAN_TPID_CTRL. BASIC_TPID_AWARE_DIS | Configures valid TPIDs for VLAN classification. This configuration is shared with routing tag control. | Per port | The VLAN classification determines the following set of VLAN parameters for all frames: - Priority Code Point (PCP). The PCP is carried internally in the IFH field IFH.VSTAX.TAG.CL\_PCP. - Drop Eligible Indicator (DEI). The DEI is carried internally in the IFH field IFH.VSTAX.TAG.CL DEI. - VLAN Identifier (VID). The VID is carried internally in the IFH field IFH.VSTAX.TAG.CL VID. - Tag Protocol Identifier (TPID) type, which holds information about the TPID of the tag used for classification. The TPID type is carried internally in IFH field IFH.VSTAX.TAG.TAG\_TYPE. Extended information about the tag type is carried in IFH.DST.TAG\_TPID. The device recognizes five types of tags based on the TPID, which is the EtherType in front of the tag: - Customer tags (C-tags), which use TPID 0x8100. - Service tags (S-tags), which use TPID 0x88A8 (IEEE 802.1ad). - Custom service tags (S-tags), which use one of three custom TPIDs programmed in ANA\_CL::VLAN\_STAG\_CFG. Three different values are supported. For customer tags and service tags, both VLAN tags (tags with nonzero VID) and priority tags (tags with VID = 0) are processed. It is configurable, which of the five recognized TPIDs are valid for the VLAN classification (VLAN\_TPID\_CTRL.BASIC\_TPID\_AWARE\_DIS). Only VLAN tags with valid TPIDs are used by the VLAN classification. The parsing of VLAN tags stops when a VLAN tag with an invalid TPID is seen. The VLAN tag information is either retrieved from a tag in the incoming frame or from default port-based configuration. The port-based VLAN tag information is configured in ANA\_CL:PORT:VLAN\_CTRL. For double tagged frames (at least two VLAN tags with valid TPIDs), there is an option to use the inner tag instead of the outer tag (VLAN\_CTRL.VLAN\_TAG\_SEL). Note that if the frame has more than two valid VLAN tags, the inner tag refers to the tag immediately after the outer tag. The following illustration shows the flow chart for basic VLAN classification. Figure 27 • Basic VLAN Classification Flow Chart In addition to the classification shown, the port decides the number of VLAN tags to pop at egress (VLAN\_CTRL.VLAN\_POP\_CNT). If the configured number of tags to pop is greater than the actual number of valid tags in the frame, the number is reduced to the number of actual valid tags in the frame. A maximum of three VLAN tags can be popped. The VLAN pop count is carried in IFH field IFH.TAGGING.POP\_CNT. Finally, the VLAN classification sets IFH field IFH.VSTAX.TAG.WAS\_TAGGED if the port is VLAN aware and the frame has one or more valid VLAN tags. WAS\_TAGGED is used the rewriter to make decision on whether tag information from existing tags can be used for rewriting. The basic classified tag information can be overwritten by more intelligent decisions made in the VCAP CLM. #### 3.14.1.7 Link Aggregation Code Generation This section provides information about the functions in link aggregation code generation. The following table lists the registers associated with aggregation code generation. Table 57 • Aggregation Code Generation Registers | Register | Description | Replication | |------------------|--------------------------------------------------------------------------------------------------|-------------| | ANA_CL::AGGR_CFG | Configures use of Layer 2 through Layer 4 flow information for link aggregation code generation. | Common | The classifier generates a link aggregation code, which is used in the analyzer when selecting to which port in a link aggregation group a frame is forwarded. The following contributions to the link aggregation code are configured in the AGGR\_CFG register. - Destination MAC address—use the 48 bits of the DMAC. - Reversed destination MAC address—use the 48 bits of the DMAC in reverse order (bit 47 becomes bit 0, bit 46 becomes bit 1, and so on). - Source MAC address—use the lower 48 bits of the SMAC. - IPv6 flow label—use the 20 bits of the flow label. - · Source and destination IP addresses for IPv4 and IPv6 frames —use all bits of both the SIP and DIP. - TCP/UDP source and destination ports for IPv4 and IPv6 frames use the 16 bits of both the SPORT and DPORT. - Random aggregation code—use a 4-bit pseudo-random number. All contributions that are enabled are 4-bit XOR'ed, and the resulting code is used by the Layer 2 forwarding function (ANA\_AC) to select 1 out of 16 link aggregation port masks. The 16 link aggregation port masks are configured in ANA\_AC:AGGR. For more information see Aggregation Group Port Selection, page 183. If AGGR\_CFG.AGGR\_USE\_VSTAX\_AC\_ENA is enabled and the frame has a VStaX header, all other contributions to link aggregation code calculation are ignored, and the AC field of the VStaX-header is used directly. Otherwise, link aggregation code generation operates as previously described. Note that AGGR\_CFG.AGGR\_DMAC\_REVERSED\_ENA and AGGR\_CFG.AGGR\_DMAC\_ENA are independent. If both bits are enabled, the frame's DMAC contributes both normally and reversed in the link aggregation code calculation. ### 3.14.1.8 **CPU Forwarding Determination** The following table lists the registers associated with CPU forwarding in the basic classifier. Table 58 • CPU Forwarding Registers | Register | Description | Replication | |----------------------------------|-----------------------------------------------------------------------------------------------|-------------| | ANA_CL:PORT:CAPTURE_CFG | Enables CPU forwarding for various frame types.<br>Configures valid TPIDs for CPU forwarding. | Per port | | ANA_CL:PORT:CAPTURE_BPDU_CFG | Enables CPU forwarding per BPDU address | Per port | | ANA_CL:PORT:CAPTURE_GXRP_CFG | Enables CPU forwarding per GxRP address | Per port | | ANA_CL:PORT:CAPTURE_Y1731_AG_CFG | Enables CPU forwarding per Y.1731/IEEE802.1ag address | Per port | | ANA_CL::CPU_PROTO_QU_CFG | CPU extraction queues for various frame types | None | | ANA_CL::CPU_8021_QU_CFG | CPU extraction queues for BPDU, GARP, and Y.1731/IEEE802.1ag addresses | None | | ANA_CL::VRAP_CFG | VLAN configuration of VRAP filter | None | Table 58 • CPU Forwarding Registers (continued) | Register | Description | | |-----------------------|-------------------------------------------------|------| | ANA_CL::VRAP_HDR_DATA | Data match against VRAP header | None | | ANA_CL::VRAP_HDR_MASK | Mask used to don't care bits in the VRAP header | None | The basic classifier has support for determining whether certain frames must be forwarded to the CPU extraction queues. Other parts of the device can also determine CPU forwarding, for example, the VCAPs or the VOEs. All events leading to CPU forwarding are OR'ed together, and the final CPU extraction queue mask, which is available to the user, contains the sum of all events leading to CPU extraction. Upon CPU forwarding by the basic classifier, the frame type and configuration determine whether the frame is redirected or copied to the CPU. Any frame type or event causing a redirection to the CPU causes all front ports to be removed from the forwarding decision—only the CPU receives the frame. When copying a frame to the CPU, the normal forwarding of the frame to front ports is unaffected. The following table lists the standard frame types recognized by the basic classifier, with respect to CPU forwarding. Table 59 • Frame Type Definitions for CPU Forwarding | Frame | Condition | Copy/Redirect | |-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | BPDU Reserved Addresses<br>(IEEE 802.1D 7.12.6) | DMAC = 0x0180C2000000 to 0x0180C20000F | Redirect/Copy/Discard | | GARP Application Addresses (IEEE 802.1D 12.5) | DMAC = 0x0180C2000020 to 0x0180C200002F | Redirect/Copy/Discard | | Y.1731/IEEE802.1ag Addresses | DMAC = 0x0180C2000030 to 0x0180C200003F | Redirect/Copy/Discard | | IGMP | DMAC = 0x01005E0000000 to 0x01005E7FFFF<br>EtherType = IPv4<br>IP Protocol = IGMP | Redirect | | MLD | DMAC = 0x333300000000 to 0x3333FFFFFFFF<br>EtherType = IPv6<br>IPv6 Next Header = 0 (Hop-by-hop options header)<br>Hop-by-hop options header with the first option being a<br>Router Alert option with the MLD message (Option Type<br>= 5, Opt Data Len = 2, Option Data = 0). | Redirect | | Hop-by-hop | EtherType = IPv6<br>IPv6 Next Header = 0 (Hop-by-hop options header) | Redirect | | ICMPv6 | EtherType = IPv6<br>IPv6 Next Header = 58 (ICMPv6) | Redirect | | IPv4 Multicast Ctrl | DMAC = 0x01005E0000000 to 0x01005E7FFFFF<br>EtherType = IPv4<br>IP protocol is not IGMP<br>IPv4 DIP inside 224.0.0.x | Сору | | IPv6 Multicast Ctrl | DMAC = 0x333300000000 to 0x3333FFFFFFFF<br>EtherType = IPv6<br>IPv6 header is not hop-by-hop or ICMPv6<br>IPv6 DIP inside FF02::/16 | Сору | Each frame type has a corresponding CPU extraction queue. Note that hop-by-hop and ICMPv6 frames share the same CPU extraction queue. Prior to deciding whether to CPU forward a frame, the frame's VLAN tagging must comply with a configurable filter (ANA\_CL::CAPTURE\_CFG.CAPTURE\_TPID\_AWARE\_DIS). For all frame types listed in Table 59, page 109, only untagged frames or VLAN-tagged frames where the outer VLAN tag's TPID is not disabled are considered. The basic classifier can recognize VRAP frames and redirect them to the CPU. This is a proprietary frame format, which is used for reading and writing switch configuration registers through Ethernet frames. For more information, see VRAP Engine, page 293. The VRAP filter in the classifier performs three checks in order to determine whether a frame is a VRAP frame: - VLAN check. The filter can be either VLAN unaware or VLAN aware (ANA\_CL::VRAP\_CFG.VRAP\_VLAN\_AWARE\_ENA). If VLAN unaware, VRAP frames must be untagged. If VLAN aware, VRAP frames must be VLAN tagged and the frame's VID must match a configured value (ANA\_CL::VRAP\_CFG.VRAP\_VID). Double VLAN tagged frames always fail this check. - 2. EtherType and EPID check. The EtherType must be 0x8880 and the EPID (bytes 0 and 1 after the EtherType) must be 0x0004. - 3. VRAP header check. The VRAP header (bytes 0, 1, 2, and 3 after the EPID) must match a 32-bit configured value (ANA\_CL::VRAP\_HDR\_DATA) where any bits can be don't cared by a mask (ANA\_CL::VRAP\_HDR\_MASK). If all three checks are fulfilled, frames are redirected to CPU extraction queue ANA\_CL::CPU\_PROTO\_QU\_CFG.CPU\_VRAP\_QU. The VRAP filter is enabled in ANA CL:PORT:CAPTURE CFG.CPU VRAP REDIR ENA. ### 3.14.1.9 Logical Port Mapping The basic classifier works on the physical port number given by the interface where the frame was received. Other device blocks work on a logical port number that defines the link aggregation instance rather than the physical port. The logical port number is defined in ANA\_CL:PORT\_ID\_CFG.LPORT\_NUM. It is, for instance, used for learning and forwarding in ANA\_L2. ### 3.14.2 VCAP CLM Processing Each frame is matched six times against entries in the VCAP CLM. The matching is done in serial implying results from one match can influence the keys used in the next match. The VCAP CLM returns an action for each enabled VCAP CLM lookup. If the lookup matches an entry in VCAP CLM, the associated action is returned. If an entry is not matched, a per-port default action is returned. There is no difference between an action from a match and a default action. ### 3.14.2.1 VCAP CLM Port Configuration and Key Selection This section provides information about special port configurations that control the key generation for VCAP CLM. The following table lists the registers associated with port configuration for VCAP CLM. Table 60 • Port Configuration of VCAP CLM | Register | Description | Replication | |------------------------|----------------------------------------------------------------------------------------------------------|---------------------| | ANA_CL:PORT:ADV_CL_CFG | Configuration of the key selection for the VCAP CLM. Enables VCAP CLM lookups. | Per port per lookup | | ANA_CL::CLM_MISC_CTRL | Force lookup in VCAP CLM for looped frames or frames where processing is terminated by a pipeline point. | None | VCAP CLM is looked up if the lookup is enabled by the port configuration (ADV\_CL\_CFG.LOOKUP\_ENA) or if the previous VCAP CLM lookup has returned a key type for the next lookup through VCAP CLM action NXT\_KEY\_TYPE. However, if the previous lookup returns NXT\_KEY\_TYPE = CLMS\_DONE, then no further lookups are done, even if the port has enabled the lookup. Prior to each VCAP CLM lookup, the type of key to be used in the lookup is selected. A number of parameters control the key type selection: - Configuration parameters (ADV\_CL\_CFG). - For each (port, VCAP CLM lookup) a key type can be specified for different frame types. Although any key type can be specified for a given frame type, not all key types are in reality applicable to a given frame type. The applicable key types are listed in the ANA\_CL:PORT:ADV\_CL\_CFG register description. The following frame types are supported: - IPv6 frames (EtherType 0x86DD and IP version 6) - IPv4 frames (EtherType 0x0800 and IP version 4) - MPLS unicast frames (EtherType 0x8847) - MPLS multicast frames (EtherType 0x8848) - · MPLS label stack processing (frame type after MPLS link layer is processed) - Other frames (non-MPLS, non-IP) - The type of the current protocol layer. For each VCAP CLM lookup, a frame pointer can optionally be moved to the next protocol layer, and the type of the next protocol layer can be specified. This influences key type selection for the next VCAP CLM lookup. The variables frame\_ptr and frame type holds information about the current protocol layer. Key type specified in action in previous VCAP CLM lookup. The action of a VCAP CLM lookup can optionally specify a specific key type to be used in the following VCAP CLM lookup. The full algorithm used for selecting VCAP CLM key type is shown in the following pseudo code. ``` // ANA_CL: VCAP CLM Key Type Selection // // Determine which key type to use in VCAP CLM lookup. // The algorithm is run prior to each VCAP CLM lookup. // ----- // Frame position (byte pointer) for use as base for next VCAP CLM key // Updated by UpdateFramePtrAndType() upon VCAP CLM lookup int frame_ptr = 0; // Frame type at frame_ptr position. // Updated by UpdateFramePtrAndType() upon VCAP CLM lookup // // Supported values: // ETH: frame_ptr points to DMAC CW: frame_ptr points to start of IP header or CW/ACH of MPLS frame // MPLS: frame_ptr points to an MPLS label. frame_type_t frame_type = ETH; int ClmKeyType( // VCAP CLM index. 0=First VCAP CLM lookup, 5=Last lookup clm_idx, // Action from previous VCAP CLM lookup (if clm_idx > 0) // clm_action.vld is only set if VCAP CLM lookup // was enabled. clm_action, { key_type = 0; int port_cfg_t port_clm_cfg; port_clm_cfg = csr.port[port_num].adv_cl_cfg[clm_idx]; if (clm_action.vld && clm_action.nxt_key_type != 0) { // Previous VCAP CLM lookup specifies next key type ``` ``` return clm_action.nxt_key_type; } // Determine key type based on port parameters and frame_ptr/frame_type switch (frame_type) { case ETH: // Choose key type based on EtherType // The EtherType() function skips any VLAN tags. A maximum of 3 VLAN // tags can be skipped. switch (EtherType(frame_ptr)) { case ETYPE_IP4: // 0x0800 key_type = port_clm_cfg.ip4_clm_key_sel; break; case ETYPE_IP6: // 0x86DD key_type = port_clm_cfg.ip6_clm_key_sel; break; case ETYPE_MPLS_UC: // 0x8847 key_type = port_clm_cfg.mpls_uc_clm_key_sel; break; case ETYPE_MPLS_MC: // 0x8848 key_type = port_clm_cfg.mpls_mc_clm_key_sel; if (\text{key\_type} = 0) { key_type = port_clm_cfg.etype_clm_key_sel; break; case CW: switch (IPVersion(frame_ptr)) { case 4 : key_type = port_clm_cfg.ip4_clm_key_sel; case 6 : key_type = port_clm_cfg.ip6_clm_key_sel; break; default: key_type = port_clm_cfg.etype_clm_key_sel; break; break; case MPLS: key_type = port_clm_cfg.mlbs_clm_key_sel; break; } return key_type; } // ClmKeyType // ANA_CL: VCAP CLM Key Type Selection //----- ``` By default, frames looped by the rewriter or frames already discarded or CPU-redirected, for instance the basic classifier, are not subject to VCAP CLM lookups. Optionally, VCAP CLM lookups can be enforced through configuration ANA\_CL::CLM\_MISC\_CTRL.LBK\_CLM\_FORCE\_ENA for looped frames and through ANA\_CL::CLM\_MISC\_CTRL.IGR\_PORT\_CLM\_FORCE\_ENA for frames already discarded or CPU-redirected. When forcing a VCAP CLM lookup, the VCAP CLM key is chosen from the configuration in ANA\_CL::CLM\_MISC\_CTRL.FORCED\_KEY\_SEL. Only selected keys are available. #### 3.14.2.2 Frame Pointer and Frame Type Update After each VCAP CLM lookup, the information in the associated action is used to update frame\_ptr and frame\_type. This in turn influences the key type and key field values used for the next VCAP CLM lookup. The following fields in the VCAP CLM action can be used to move to the next protocol layer: - · NXT OFFSET FROM TYPE. - Move frame pointer past current protocol layer (Ethernet and/or IP). The actual number of bytes the frame pointer is moved may vary depending on content of the current protocol layer, such as the number of VLAN tags or IPv4 options. - NXT\_NORM\_W16\_OFFSET. Move frame pointer a number of 16 bit words. If both NXT\_OFFSET\_FROM\_TYPE and NXT\_NORM\_W16\_OFFSET are specified, then frame pointer is first moved based on NXT\_OFFSET\_FROM\_TYPE and afterwards moved further into the frame based on NXT\_NORM\_W16\_OFFSET. - NXT\_TYPE\_AFTER\_OFFSET. Specify protocol layer at new frame pointer position. For more information about VCAP CLM action fields, see Table 51, page 87. Each VCAP CLM lookup can at most move the frame pointer 66 bytes. The following pseudo code shows the algorithm used to update frame ptr and frame type upon each VCPA CLM lookup. ``` // ANA_CL: VCAP CLM Frame Pointer and Frame Type Update // // Update frame_ptr and frame_type upon VCAP CLM lookup. // Prior to first VCAP CLM lookup frame_ptr is initialized to 0 and // frame_type is set to ETH. // The algorithm is run after each VCAP CLM lookup. // Function for updating // frame_ptr frame_type // based on action from VCAP CLM lookup void UpdateFramePtrAndType( // VCAP CLM index. 0=First VCAP CLM lookup, // 5=Last VCAP CLM lookup clm_idx, // Action from VCAP CLM lookup // clm action.vld is only set if // VCAP CLM lookup was enabled. clm_action, // From ClmKeyFieldsMpls() clm_key_fields_mpls, int frame_ptr_current = frame_ptr; int frame_type_current = frame_type; if (!clm_action.vld) return; if (clm_action.nxt_offset_from_type > 0) { // Move frame_ptr based on frame type switch (clm_action.nxt_offset_from_type) { case SKIP ETH: if (frame_type_current == ETH) { // Move frame_ptr past DMAC, SMAC, 0-3 VLAN tags and EtherType SkipLinkLayer(&frame_ptr); break; ``` ``` case SKIP_IP_ETH: switch (frame_type_current) { // Move frame_ptr past DMAC, SMAC, 0-3 VLAN tags and EtherType (EtherType(frame_ptr) == ETYPE_IP6) { // 0x86DD SkipLinkLayer(&frame_ptr); // Move frame_ptr past IPv4 header (including options) or // IPv6 header SkipIPHeader(&frame_ptr); break; case CW: switch (IPVersion(frame_ptr)) { case 4: case 6: // Move frame_ptr past IPv4 header (including options) or // IPv6 header SkipIPHeader(&frame_ptr); break; break; } } frame_type = clm_action.nxt_type_after_offset; } // clm_action.nxt_offset_from_type > 0 if (clm_action.nxt_norm_w16_offset > 0) { // Move frame_ptr a specific number of bytes frame_ptr = frame_ptr + 2*clm_action.nxt_norm_w16_offset; frame_type = clm_action.nxt_type_after_offset; if (frame_type_current == DATA && clm_action.nxt_key_type != 0) { // Allow frame_type change, regardsless of whether frame_ptr // has been moved frame_type = clm_action.nxt_type_after_offset; } // PW termination of MPLS frame if (clm_action.fwd_type == TERMINATE_PW) { if IsOam(frame_ptr, csr) && (clm_key_fields_mpls.rsv_lbl_pos) { // Reserved label used to identify OAM // Move frame_ptr if reserved MPLS label was skipped by // ClmKeyFieldsMpls() in key generation prior to VCAP CLM lookup frame_ptr += 4; } elsif (frame_type == CW && !IsOam(frame_ptr, csr)) { // PW termination of MPLS frame with CW => Skip CW and // change frame_type frame_ptr += 4; frame_type = ETH; // OAM LSP ``` ``` if (clm_action.fwd_type == POP_LBL && IsOam(frame_ptr, csr) && (clm_key_fields_mpls.rsv_lbl_pos)) { // Reserved label used to identify OAM // Move frame_ptr if reserved MPLS label was skipped by // ClmKeyFieldsMpls() in key generation prior to VCAP CLM lookup frame_ptr += 4; if (frame_ptr - frame_ptr_current > 66) { // Cannot skip >66 bytes per VCAP CLM. // Set sticky bit and don't skip anything csr.adv_cl_max_w16_offset_fail_sticky = 1; frame_ptr = frame_ptr_current; frame_type = frame_type_current; if (frame_ptr > 126 ) { // Cannot skip >126 bytes total. // Set sticky bit and discard frame csr.adv_cl_nxt_offset_too_big_sticky = 1; frame.abort = true; } // UpdateFramePtrAndType // ANA_CL: VCAP CLM Frame Pointer and Frame Type Update //----- ``` ### 3.14.2.3 Removing Protocol Layers The analyzer classifier can instruct the rewriter to remove protocol layers from the frame, that is, to remove a number of bytes from the start of the frame. This is achieved by setting the NXT\_NORMALIZE action field in the VCAP CLM action. When NXT\_NORMALIZE is set in a VCAP CLM action, then the frame pointer for the next VCAP CLM lookup (if any) is calculated, and the rewriter is then instructed to remove all bytes up to, but not including, the position pointed to by the frame pointer. If multiple VCAP CLM actions have the NXT\_NORMALIZE bit set, then the last such action controls the number of bytes removed by the rewriter. Note that the rewriter can skip a maximum of 42 bytes, starting at the DMAC of the frame. This corresponds to an Ethernet header with three VLAN tags and an MPLS stack with three LSEs and a control word (CW). ### 3.14.2.4 Miscellaneous VCAP CLM Key Configuration The analyzer classifier can control some specific fields when generating the VCAP CLM keys. The following table lists the registers that control the parameters. Table 61 • Miscellaneous VCAP CLM Key Configuration | Register | Description | Replication | |------------------------|-------------------------------------------------|---------------------------------| | ANA_CL:PORT:ADV_CL_CFG | Configures L3_DSCP and TCI0 source. | Per port per VCAP<br>CLM lookup | | ANA_CL::CLM_MISC_CTRL | Configures IGR_PORT_MASK_SEL and IGR_PORT_MASK. | None | Each port can control specific fields in the generated keys: Selects source of DSCP in L3\_DSCP key field (ANA\_CL:PORT:ADV\_CL\_CFG.USE\_CL\_DSCP\_ENA). By default, the DSCP value is taken from the frame. Another option is to use the current classified DSCP value as input to the key. The current classified DSCP value is the result from either the previous VCAM\_CLM lookup or the basic classifier if this is the first lookup. Selects source of VID, PCP, and DEI in the VID0, PCP0, and DEI0 key fields (ANA\_CL:PORT:ADV\_CL\_CFG.USE\_CL\_TCI0\_ENA). By default, the values are taken from the outer VLAN tag in the frame (or port's VLAN if frame is untagged). Another option is to use the current classified values as input to the key. The current classified values are the result from either the previous VCAM\_CLM lookup or the basic classifier if this is the first lookup. Note that these configurations are only applicable to keys containing the relevant key fields. VCAP CLM keys NORMAL, NORMAL\_7TUPLE, and NORMAL\_5TUPLE\_IP4 contain the key fields IGR\_PORT\_MASK\_SEL and IGR\_PORT\_MASK. For frames received on a front port, IGR\_PORT\_MASK\_SEL is set to 0 and the bit corresponding to the frame's physical ingress port number is set in IGR\_PORT\_MASK. The following lists some settings for frames received on other interfaces and how this can be configured through register CLM\_MISC\_CTRL: - Loopback frames: - By default, IGR\_PORT\_MASK\_SEL=1 and IGR\_PORT\_MASK has one bit set corresponding to the physical port which the frame was looped on. Optionally use IGR\_PORT\_MASK\_SEL = 3. - Masqueraded frames: By default, IGR\_PORT\_MASK\_SEL=0 and IGR\_PORT\_MASK has one bit set corresponding to the masquerade port. Optionally, use IGR\_PORT\_MASK\_SEL = 2. - Virtual device frames: By default, IGR\_PORT\_MASK\_SEL = 0 a - By default, IGR\_PORT\_MASK\_SEL = 0 and IGR\_PORT\_MASK has one bit set corresponding to the original physical ingress port. Optionally, use IGR\_PORT\_MASK\_SEL = 3. - CPU injected frames: By default, IGR\_PORT\_MASK\_SEL=0 and IGR\_PORT\_MASK has none bits set. Optionally use IGR\_PORT\_MASK\_SEL=3. For more information about the contents of IGR\_PORT\_MASK\_SEL and IGR\_PORT\_MASK, see VCAP CLM Keys and Actions, page 65. ### 3.14.2.5 VCAP CLM Range Checkers The following table lists the registers associated with configuring VCAP CLM range checkers. Table 62 • VCAP CLM Range Checker Configuration Registers Overview | Register | Description | Replication | |---------------------------|---------------------------------------|-------------------| | ANA_CL::ADV_RNG_CTRL | Configures range checker types | Per range checker | | ANA_CL::ADV_RNG_VALUE_CFG | Configures range start and end points | Per range checker | Eight global VCAP CLM range checkers are supported by the NORMAL, NORMAL\_7TUPLE, NORMAL\_5TUPLE\_IP4, and PURE\_5TUPLE\_IP4 keys. All frames using these keys are compared against the range checkers and a 1-bit range "match/no match" flag is returned for each range checker. The combined eight match/no match flags are used in the L4\_RNG key field. So, it is possible to include for example ranges of DSCP values and/or ranges of TCP source port numbers in the VCAP rules. **Note:** VCAP IS2 also supports range checkers, however, they are independent of the VCAP CLM range checkers. The range key is generated for each frame based on extracted frame data and the configuration in ANA\_CL::ADV\_RNG\_CTRL. Each of the eight range checkers can be configured to one of the following range types: - TCP/UDP destination port range Input to the range is the frame's TCP/UDP destination port number. Range is only applicable to TCP/UDP frames. - TCP/UDP source port range Input to the range is the frame's TCP/UDP source port number. Range is only applicable to TCP/UDP frames. TCP/UDP source and destination ports range. Range is matched if either source or destination port is within range. Input to the range are the frame's TCP/UDP source and destination port numbers. Range is only applicable to TCP/UDP frames. VID range Input to the range is the classified VID. Range is applicable to all frames. DSCP range Input to the range is the classified DSCP value. Range is applicable to IPv4 and IPv6 frames. EtherType range Input to the range is the frame's EtherType. Range is applicable to all frames. Range start points and range end points are configured in ANA\_CL::ADV\_RNG\_VALUE\_CFG with both the start point and the end point being included in the range. A range matches if the input value to the range (for instance the frame's TCP/UDP destination port) is within the range defined by the start point and the end point. ### 3.14.2.6 Cascading VCAP CLM Lookups Each of the six VCAP CLM lookups can be "cascaded" such that a frame only matches a VCAP CLM entry in lookup n+1 if it also matched a specific entry in VCAP CLM lookup n. In other words, VCAP CLM entries in different VCAP CLM lookups are bound together. The following parameters controls cascading of VCAP CLM entries: Key field: G IDX The generic index, G\_IDX, is available in most VCAP CLM key types. The value of this field can be specified in the action of the preceding VCAP CLM lookup. Action fields: NXT\_IDX\_CTRL and NXT\_IDX Control how to calculate G\_IDX for next VCAP CLM lookup. For information about detailed encoding of NXT\_IDX\_CTRL, see Table 51, page 87. In addition to cascading VCAP CLM lookups, it is also possible for each VCAP CLM lookup to move to the next protocol layer of the frame, such that key values for lookup n + 1 are retrieved from a different offset in the frame than for lookup n. # 3.14.3 QoS Mapping Table The following table lists the registers associated with the QoS mapping table. Table 63 • VCAP CLM QoS Mapping Table Registers Overview | Register | Description | Replication | |--------------------------|------------------------------------------|-------------| | ANA_CL:MAP_TBL:SET_CTRL | Controls which mapping results to use. | 256 | | ANA_CL:MAP_TBL:MAP_ENTRY | Configuration of the QoS mapping values. | 2,048 | The classifier contains a shared QoS mapping table with 2,048 entries (ANA\_CL:MAP\_TBL:MAP\_ENTRY) that maps incoming QoS information to classified internal QoS information. Inputs to a mapping can be either DEI and PCP from VLAN tags, DSCP value, or MPLS TC bits. Outputs from a mapping are new classified values for COSID, DEI, PCP, DSCP, QoS class, DP level, and TC bits. The table is looked up twice for each frame with two different keys. The QoS mapping table is laid out with 256 rows with each eight mapping entries. Each specific QoS mapping only uses a subset of the 2,048 entries and it therefore allows for many QoS different mappings at the same time. It can for instance hold 32 unique mappings from DSCP to DEI/PCP or 128 unique translations of DEI/PCP to DEI/PCP. The two lookups per frame in the QoS mapping table are defined by the VCAP CLM actions MAP\_IDX and MAP\_KEY. One VCAP CLM match can only define one set MAP\_IDX and MAP\_KEY so two lookups in the QoS mapping table requires two VCAP CLM matches. Action MAP\_IDX defines which one of the 256 rows the QoS mapping starts at and the MAP\_KEY defines which parameter from the frame to use as key into the QoS mapping table. The following lists the available keys and how the resulting row and entry number in the mapping table is derived: PCP. Use PCP from the frame's outer VLAN tag. If the frame is untagged, the port's VLAN tag is used. Row and entry number is derived the following way: Row = MAP IDX, Entry = PCP. Number of entries per mapping: 8 entries. • **DEI and PCP.** Use DEI and PCP from one of the frame's VLAN tags. The MAP\_KEY can select between using either outer, middle, or inner tag. If the frame is untagged, the port's VLAN tag is used. Row and entry number is derived the following way: Row = (8x DEI + PCP) DIV 8 + MAP\_IDX, Entry = (8x DEI + PCP) MOD 8. Number of entries per mapping: 16 entries. DSCP (IP frames only). Use the frame's DSCP value. For non-IP frames, no mapping is done. Row and entry number is derived the following way: Row = DSCP DIV 8 + MAP IDX, Entry = DSCP MOD 8. Number of entries per mapping: 64 entries. DSCP (all frames). Use the frame's DSCP value. For non-IP VLAN tagged frames, use DEI and PCP from the frame's outer VLAN tag. For non-IP untagged frames, use DEI and PCP from port VLAN. Row and entry number is derived the following way: IP frames: Row = DSCP DIV 8 + MAP\_IDX, Entry = DSCP MOD 8. Non-IP frames: Row = (8x DEI + PCP) DIV 8 + MAP IDX + 8, Entry = (8x DEI + PCP) MOD 8. Number of entries per mapping: 80 entries. TC. Use the frame's classified TC bits from the extracted MPLS label (label selected by VCAP CLM actions TC\_ENA or TC\_LABEL). Row and entry number is derived the following way: Row = MAP\_IDX, Entry = TC. Number of entries per mapping: 8 entries. QoS mappings can be shared between multiple VCAP CLM entries by defining the same mapping and using the same entries in the mapping table. It is up to the user of the QoS mapping table to make sure that entries are allocated so that they do not overlap unintentionally. Each entry in the QoS mapping table (ANA\_CL:MAP\_TBL:MAP\_ENTRY) contains a full set of new QoS values (COSID, DEI, PCP, QoS class, DP level, DSCP, TC) to be used as new classified values instead of the current classified values from basic classification and VCAP CLM. Each of the QoS values is gated by an enable bit (ANA\_CL:MAP\_TBL:SET\_CTRL) so that a mapping can for example define a complete new set of QoS values by enabling all values or it can override selected values only. Note that ANA\_CL:MAP\_TBL:SET\_CTRL must be configured for each used row in the mapping table. The following illustration shows an example of a frame for which a DSCP and a DEI/PCP mapping are defined. Figure 28 • Example of QoS Mappings # 3.14.4 Analyzer Classifier Diagnostics The analyzer classifier contains a large set of sticky bits that can inform about the frame processing and decisions made by ANA\_CL. The following categories of sticky bits are available. - Frame acceptance filtering (ANA\_CL::FILTER\_STICKY, ANA\_CL::VLAN\_FILTER\_STICKY). - VLAN and QoS classification (ANA CL::CLASS STICKY) - CPU forwarding (ANA CL::CAT STICKY) - VCAP CLM lookups and actions, QoS mapping tables (ANA\_CL::ADV\_CL\_STICKY) - IP header checks (ANA\_CL::IP\_HDR\_CHK\_STICKY) The sticky bits are common for all ports in the analyzer classifier. All sticky bits, except for VCAP CLM sticky bits, have four corresponding sticky mask bits (ANA\_CL:STICKY\_MASK) that allow any sticky bit to be counted by one of the four per-port analyzer access control counters. For more information, see Analyzer Statistics, page 194. ### 3.15 VLAN and MSTP The VLAN table and the MSTP table are the two main tables that control VLAN and Spanning Tree frame processing. The following table shows the configuration parameters (located within the ANA\_L3 configuration target) for each entry in the VLAN table. Table 64 • VLAN Table (4224 Entries) | Field in ANA_L3:VLAN | Bits | Description | |-----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VMID | 5 | VMID, identifying VLAN's router leg. | | VLAN_MSTP_PTR | 7 | Pointer to STP instance associated with VLAN. | | VLAN_FID | 13 | FID to use for learning and forwarding. | | VLAN_IGR_FILTER_ENA | 1 | Enable VLAN ingress filtering. | | VLAN_SEC_FWD_ENA | 1 | Enables secure forwarding on a per VLAN basis. When secure forwarding is enabled, only frames with known SMAC are forwarded. | | VLAN_FLOOD_DIS | 1 | Disables flooding of frames with unknown DMAC on a per VLAN basis. | | VLAN_LRN_DIS | 1 | Disables learning of SMAC of frames received on this VLAN. | | VLAN_RLEG_ENA | 1 | Enables router leg in VLAN. | | VLAN_PRIVATE_ENA | 1 | Enables/disables this VLAN as a Private VLAN (PVLAN). | | VLAN_MIRROR_ENA | 1 | VLAN mirror enable flag. If this field is set, frames classified to this ingress VLAN are mirrored. Note that a mirroring probe must also be configured to enable VLAN based mirroring. see Mirroring, page 202. | | VLAN_PORT_MASK<br>VLAN_PORT_MASK1 | 11 | Specifies mask of ports belonging to VLAN. | | TUPE_CTRL | 16 | Controls value for Table Update Engine (TUPE). | The following table shows the configuration parameters for each entry in the MSTP table. Table 65 • MSTP Table (66 Entries) | Field in ANA_L3:MSTP | Bits | Description | |----------------------|------------|--------------------------------------| | MSTP_FWD_MASK | 1 per port | Enables/disables forwarding per port | | MSTP_LRN_MASK | 1 per port | Enables/disables learning per port | The following table lists common parameters that also affect the VLAN and MSTP processing of frames. Table 66 • Common VLAN and MSTP Parameters | Register/Field in ANA_L3_COMMON | Bits | Description | |---------------------------------|------------|--------------------------------------------| | VLAN_CTRL.VLAN_ENA | 1 | Enables/disables VLAN lookup | | PORT_FWD_CTRL | 1 per port | Configures forwarding state per port | | PORT_LRN_CTRL | 1 per port | Configures learning state per port | | VLAN_FILTER_CTRL | 1 per port | Configures VLAN ingress filtering per port | | VLAN_ISOLATED_CFG | 1 per port | Configures isolated port mask | | VLAN_COMMUNITY_CFG | 1 per port | Configures community port mask | If VLAN support is enabled (in VLAN\_CTRL.VLAN\_ENA), the classified VID is used to lookup the VLAN information in the VLAN table. The VLAN table in turn provides an address (VLAN\_MSTP\_PTR) into the MSTP table. Learn, mirror, and forwarding results are calculated by combining information from the VLAN and MSTP tables. ### 3.15.1 Private VLAN In a Private VLAN (PVLAN), ports are configured to be one of three different types: Promiscuous, isolated, or community. **Promiscuous Ports** A promiscuous port can communicate with all ports in the PVLAN, including the isolated and community ports. **Isolated Ports** An isolated port has complete Layer 2 separation from the other ports within the same PVLAN, but not from the promiscuous ports. PVLANs block all traffic to isolated ports except traffic from promiscuous ports. Traffic from isolated port is forwarded only to promiscuous ports. **Community Ports** Community ports communicate among themselves and with the PVLAN's promiscuous ports. Community ports cannot communicate with isolated ports. PVLAN can be enabled per VLAN, and port type can be configured per physical port. ### 3.15.2 VLAN Pseudo Code The pseudo code for the ingress VLAN processing is shown below. For routed frames, an egress VLAN processing also takes place. This is not part of the following pseudo code. In the pseudo code, "csr." is used to denote configuration parameters, "req." is used to denote input from previous processing steps in the analyzer, as well as information provided for the following steps in the analyzer. ``` if (req.cpu_inject != 0) { // cpu_inject => Bypass! return; } if (csr.vlan_ena) { // Get VLAN entry based on Classified VID igr_vlan_entry = csr.vlan_tbl[req.ivid + req.vsi_ena*4096]; } else { // Default VLAN entry igr_vlan_entry.vlan_mstp_ptr = 0; igr_vlan_entry.vlan_fid = 0; igr vlan entry.vlan sec fwd ena = 0; igr_vlan_entry.vlan_flood_dis = 0; igr_vlan_entry.vlan_lrn_dis = 0; igr_vlan_entry.vlan_rleg_ena = 0; igr_vlan_entry.vlan_private_ena = 0; igr_vlan_entry.vlan_mirror_ena = 0; igr_vlan_entry.vlan_port_mask = -1; // All-ones igr_vlan_entry.vmid = 0; } // Retrieve MSTP state if (csr.vlan_ena) { igr_mstp_entry = csr.mstp_tbl[igr_vlan_entry.vlan_mstp_ptr]; } else { igr_mstp_entry.mstp_fwd_mask = -1; // All-ones igr_mstp_entry.mstp_lrn_mask = -1; // All-ones if (IsCpuPort(req.port_num) | | IsVD0(req.port_num) | | IsVD1(req.port_num)) { // Received from CPU or VD0/VD1 => // * Do not learn // * Do not perform ingress filtering ``` ``` (these ports are not in ingress masks) req.12_lrn = 0; } else { _____ // Perform ingress filtering and learning disable // Port forwarding state if (csr.common.port_fwd_ena[req.port_num] == 0) { // Ingress port not enabled for forwarding req.12_fwd = 0; csr.port_fwd_deny_sticky =1; } // Port learning state if (csr.port_lrn_ena[req.port_num] == 0) { req.12_lrn = 0; csr.port_lrn_deny_sticky = 1; } if (csr.vlan_ena) { // Empty VLAN? if (igr_vlan_entry.vlan_port_mask == 0) { csr.vlan_lookup_invld_sticky = 1; } // VLAN ingress filtering if ((csr.vlan_igr_filter_ena[req.port_num] || igr_vlan_entry.vlan_igr_filter_ena) igr_vlan_entry.vlan_port_mask[req.port_num] == 0) { req.12_fwd = 0; req.12_lrn = 0; csr.vlan_igr_filter_sticky = 1; } else { // MSTP forwarding state if (igr_mstp_entry.mstp_fwd_mask[req.port_num] == 0) { req.12_fwd = 0; csr.mstp_discard_sticky = 1; } else { csr.mstp_fwd_allowed_sticky = 1; // Learning enabled for VLAN? if (igr_vlan_entry.vlan_lrn_dis) { req.12_lrn = 0; csr.vlan_lrn_deny_sticky = 1; // MSTP learning state } else if (igr_mstp_entry.mstp_lrn_mask[req.port_num] == 0) { req.12_lrn = 0; csr.mstp_lrn_deny_sticky = 1; } else { csr.mstp_lrn_allowed_sticky = 1; // Private VLAN handling if (igr_vlan_entry.vlan_private_ena) { if (req.vs2_avail == 0) { ``` ``` // Not received from stack port, so determine port type and // update req accordingly. // 0b00: Promiscuous port // 0b01: Community port // 0b10: Isolated port req.ingr_port_type = 0b00; if (csr.vlan_community_mask[req.port_num]) { req.ingr_port_type = 0b01; if (csr.vlan_isolated_mask[req.port_num]) { req.ingr_port_type = 0b10; } if (req.ingr_port_type == 0b10) { // Isolated port // Only allow communication with promiscuous ports igr_vlan_entry.vlan_port_mask &= (~csr.vlan_isolated_mask & ~csr.vlan_community_mask); } else if (req.ingr_port_type == 0b01) { // Community port // Allow communication with promiscuous ports and other community ports, // but not with isolated ports igr_vlan_entry.vlan_port_mask &= ~csr.vlan_isolated_mask; } } } // vlan_igr_filter_ena } // csr.vlan_ena // Only allow forwarding to enabled ports igr_vlan_entry.vlan_port_mask &= csr.port_fwd_ena; // Update req with results req.vlan_mask = igr_vlan_entry.vlan_port_mask & igr_mstp_entry.mstp_fwd_mask; req.ifid = igr_vlan_entry.vlan_fid; req.vlan_mirror = igr_vlan_entry.vlan_mirror_ena; req.vlan_flood_dis = igr_vlan_entry.vlan_flood_dis; req.vlan_sec_fwd_ena = igr_vlan_entry.vlan_sec_fwd_ena; // Identical ingress and egress FID/VID. // May be overruled later by egress VLAN handling. // Note: ANA_L2 DMAC lookup always use req.efid, even when req.13_fwd=0. req.evid = req.ivid; if (req.dmac[40]) { // If MC, DA lookup must use EVID req.efid = req.vsi_ena . req.evid; } else { // If UC, DA lookup must use IFID req.efid = req.ifid; // Store vmid for later use (e.g. in rleg detection) req.irleg = igr_vlan_entry.vmid; req.erleg = req.irleg; ``` ### 3.15.2.1 VLAN Table Update Engine The VLAN Table Update Engine (TUPE) can be used to quickly update a large number of port masks in the VLAN Table. For example, to support fast fail-over in scenarios with redundant forwarding paths. The following table lists the TUPE related parameters that are outside the VLAN Table. Table 67 • VLAN Table Update Engine (TUPE) Parameters | Register/Field in ANA_L3:TUPE | Bits | Description | |------------------------------------------------|------|-----------------------------------------------------------------| | TUPE_MISC.TUPE_START | 1 | Start TUPE. | | TUPE_MISC.TUPE_CTRL_VAL_ENA | 1 | Enable use of TUPE_CTRL_VAL and TUPE_CTRL_VAL_MASK. | | TUPE_CTRL_BIT_ENA | 1 | Enable use of TUPE_CTRL_BIT_MASK. | | TUPE_PORT_MASK_A_ENA | 1 | Enable use of TUPE_PORT_MASK_A. | | TUPE_PORT_MASK_B_ENA | 1 | Enable use of TUPE_PORT_MASK_B | | TUPE_COMB_MASK_ENA | 1 | Enable combined use of TUPE_CTRL_BIT_MASK and TUPE_PORT_MASK_A. | | TUPE_ADDR.TUPE_START_ADDR | 13 | First address in VLAN table for TUPE to process. | | TUPE_ADDR.TUPE_END_ADDR | 13 | Last address in VLAN table for TUPE to process. | | TUPE_CMD_PORT_MASK_CLR TUPE_CMD_PORT_MASK_CLR1 | 11 | TUPE command: Port mask bits to clear. | | TUPE_CMD_PORT_MASK_SET TUPE_CMD_PORT_MASK_SET1 | 11 | TUPE command: Port mask bits to set. | | TUPE_CTRL_VAL | 16 | TUPE parameter controlling which VLAN table entries to update. | | TUPE_CTRL_VAL_MASK | 16 | TUPE parameter controlling which VLAN table entries to update. | | TUPE_CTRL_BIT_MASK | 16 | TUPE parameter controlling which VLAN table entries to update. | | TUPE_PORT_MASK_A TUPE_PORT_MASK_A1 | 11 | TUPE parameter controlling which VLAN table entries to update. | | TUPE_PORT_MASK_B TUPE_PORT_MASK_B1 | 11 | TUPE parameter controlling which VLAN table entries to update. | The TUPE\_CTRL field in the VLAN table can be used to classify VLANs into different groups, and the VLAN\_PORT\_MASK for such groups of VLANs are quickly updated using TUPE. Using the parameters listed, the TUPE\_CTRL field in the VLAN table can be processed as a field of individual bits, a field with one value, or a combination of the two. For example, if a command for TUPE uses the following, the TUPE\_CTRL field is treated as an 8-bit value field and eight individual bits. - TUPE\_CTRL\_BIT\_ENA = 1 - TUPE CTRL BIT MASK = 0x00ff - TUPE\_CTRL\_VAL\_MASK = 0xff00 In order for TUPE to update a VLAN entry's VLAN\_PORT\_MASK, the value part of TUPE\_CTRL must match the required value, and one or more bits of the bit part of TUPE\_CTRL must be set. If all bits in TUPE\_CTRL are used as a value field, then a total of 2<sup>16</sup> groups can be created, but each VLAN can only be member of one such group. On the other end of the spectrum, if all bits in TUPE\_CTRL are treated as individual bits, then only 16 groups can be created, but every VLAN can be member of any number of these groups. In configurations that have fewer physical ports than the number of bits in the VLAN\_PORT\_MASK, such bits can be used as an extension to the bit part of the TUPE CTRL field. Apart from the VLAN's TUPE\_CTRL, the value of the VLAN's VLAN\_PORT\_MASK is also used to decide whether to update a given VLAN table entry. The following illustration depicts the TUPE functionality. Figure 29 • VLAN Table Update Engine (TUPE) The following pseudo code shows the full algorithm used by TUPE. ``` for (addr = csr.tupe_start_addr; addr < csr.tupe_end_addr; addr++) {</pre> vlan_entry = vlan_tbl[addr]; if ( (// If enabled, check matching value !csr.tupe_ctrl_val_ena ((vlan_entry.tupe_ctrl & csr.tupe_ctrl_val_mask) == csr.tupe_ctrl_val)) (// If enabled, check if VLAN's tupe_ctrl has any bits overlapping // with csr.tupe_CTRL_BIT_MASK !csr.tupe_ctrl_bit_ena ((vlan_entry.tupe_ctrl & csr.tupe_ctrl_bit_mask) != 0)) && (// If enabled, check if VLAN's vlan_port_mask has any bits overlapping // with csr.tupe_PORT_MASK_A !csr.tupe_port_mask_a_ena ((vlan_entry.vlan_port_mask & csr.tupe_port_mask_a) != 0)) && (// Combined mode // If enabled, check if VLAN's tupe_ctrl has any bits overlapping // with TUPE_CTRL_BIT_MASK or VLAN's vlan_port_mask has any bits // overlapping with TUPE_PORT_MASK_A // I.e. the bit mask part of TUPE_CTRL is extended with bits from // vlan_port_maks. !csr.tupe_comb_mask_ena ((vlan_entry.tupe_ctrl & csr.tupe_ctrl_bit_mask) != 0) ((vlan_entry.vlan_port_mask & csr.tupe_port_mask_a) != 0)) (// If enabled, check if VLAN's vlan_port_mask has any bits overlapping // with csr.tupe_PORT_MASK_B ``` ``` !csr.tupe_port_mask_b_ena ((vlan_entry.vlan_port_mask & csr.tupe_port_mask_b) != 0)) ) { // vlan_port_mask must be updated for this addr for (p = 0; p < port_count; p++) {</pre> if (csr.tupe_cmd_port_mask_clr[p] == 1 && csr.tupe_cmd_port_mask_set[p] == 1) { // clr+set => toggle vlan_entry.vlan_port_mask[p] = !vlan_entry.vlan_port_mask[p]; } else if (csr.tupe_cmd_port_mask_clr[p] == 1) { vlan_entry.vlan_port_mask[p] = 0; } else if (csr.tupe_cmd_port_mask_set[p] == 1) { vlan_entry.vlan_port_mask[p] = 1; } // Write back to VLAN table vlan_tbl[addr] = vlan_entry; ``` ## 3.16 VCAP LPM: Keys and Action The IP addresses used for IP source/destination guard and for IP routing are stored in a VCAP in the VCAP\_SUPER block. The part of the VCAP\_SUPER block allocated for this purpose is VCAP LPM (Longest Path Match). VCAP LPM encodes both the IP addresses (VCAP keys) and the action information associated with each VCAP key. The following table shows the different key types supported by the VCAP LPM. | Key Name | Key Size | Number of VCAP Words | |----------|----------|----------------------| | SGL_IP4 | 33 | 1 | | DBL_IP4 | 64 | 2 | | SGL_IP6 | 129 | 4 | | DBL IP6 | 256 | 8 | Table 68 • VCAP LPM Key and Sizes The following table provides an overview of the VCAP LPM key. When programming an entry in VCAP LPM, the associated key fields listed must be programmed in the listed order with the first field in the table starting at bit 0 of the entry. For more information, see, Versatile Content-Aware Processor (VCAP), page 49. Table 69 • VCAP LPM Key Overview | Field Name | Short Description | Size | SGL_IP4 | DBL_IP4 | SGL_IP6 | DBL_IP6 | |------------|-------------------|------|---------|---------|---------|---------| | DST_FLAG | 0=SIP, 1=DIP | 1 | Х | | Х | | | IP4_XIP | IPv4 SIP/DIP | 32 | Х | | | | | IP4_SIP | IPv4 SIP | 32 | | Х | | | | IP4_DIP | IPv4 DIP | 32 | | Х | | | | IP6_XIP | IPv6 SIP/DIP | 128 | | | Х | | | IP6_SIP | IPv6 SIP | 128 | | | | Х | | IP6_DIP | IPv6 DIP | 128 | | | | х | ## 3.16.1 VCAP LPM SGL\_IP4 Key Details The SGL IP4 key is to be used for IPv4 UC routing as well as IPv4 Source/Destination Guard. Table 70 • VCAP LPM SGL\_IP4 Key Details | Field Name | Description | Size | |------------|-------------------------------------------------------------------------------------------------|------| | DST_FLAG | 0: IP4_XIP is only to be used for SIP matching. 1: IP4_XIP is only to be used for DIP matching. | 1 | | IP4_XIP | IPv4 address | 32 | ## 3.16.2 VCAP LPM DBL\_IP4 Key Details The DBL\_IP4 key is to be used for IPv4 MC routing. Table 71 • VCAP LPM DBL\_IP4 Key Details | Field Name | Description | Size | |------------|--------------------------|------| | IP4_SIP | IPv4 source address | 32 | | IP4_DIP | IPv4 destination address | 32 | ## 3.16.3 VCAP LPM SGL\_IP6 Key Details The SGL\_IP6 key is to be used for IPv6 UC routing as well as IPv6 Source/Destination Guard. Table 72 • VCAP LPM SGL\_IP6 Key Details | Field Name | Description | Size | |------------|-----------------------------------------------------------------------------------------------|------| | DST_FLAG | 0: IP6_XIP is only to be used for SIP matching 1: IP6_XIP is only to be used for DIP matching | 1 | | IP6_XIP | IPv6 address | 128 | ## 3.16.4 VCAP LPM DBL\_IP6 Key Details The DBL\_IP6 key is to be used for IPv6 MC routing. Table 73 • VCAP LPM DBL\_IP6 Key Details | Field Name | Description | Size | |------------|--------------------------|------| | IP6_SIP | IPv6 source address | 128 | | IP6_DIP | IPv6 destination address | 128 | ## 3.16.5 VCAP LPM Actions VCAP LPM supports three different actions: - ARP PTR - L3MC PTR - ARP ENTRY The following table lists the actions and the key types for which they are intended to be used. Table 74 • VCAP LPM Action Selection | Action Name | Size | Description and Appropriate VCAP LPM Key Types | |-------------|------|-------------------------------------------------------------------------------------------| | ARP_PTR | 18 | Provides pointer to ARP entry in ARP Table (ANA_L3:ARP). LPM key types: SGL_IP4, SGL_IP6. | | L3MC_PTR | 10 | Provides pointer to L3MC Table (ANA_L3:L3MC). LPM key types: DBL_IP4, DBL_IP6. | | ARP_ENTRY | 62 | ARP entry. LPM key types: SGL_IP4, SGL_IP6. | The following table provides information about the VCAP LPM actions. When programming an action in VCAP LPM, the associated action fields listed must be programmed in the listed order, with the first field in the table starting at bit 0 of the action. Table 75 • VCAP LPM Actions | Field Name | Description and Encoding | Size | ARP_PTR | L3MC_PTR | ARP_ENTRY | |--------------------------|-----------------------------------------------------------------------------------------------------|------|---------|----------|-----------| | Action Type | 0: ARP_PTR 1: L3MC_PTR 2: ARP_ENTRY 3: Reserved | 2 | х | Х | Х | | ARP_PTR | Pointer to entry in ARP Table (ANA_L3:ARP) | 8 | Х | | | | ARP_PTR_REMA<br>P_ENA | If set, ARP_PTR is used to point to an entry in the ARP Pointer Remap Table (ANA_L3:ARP_PTR_REMAP). | 1 | Х | | | | ECMP_CNT | Number of equal cost, multiple paths routes to DIP. See IP Multicast Routing, page 139. | 4 | Х | | | | RGID | Route Group ID. Used for SIP RPF check. See SIP RPF Check, page 142. | 3 | Х | | | | L3MC_PTR | Pointer to entry in L3MC Table (ANA_L3:L3MC) | 8 | | Х | | | MAC_MSB | See ANA_L3:ARP:ARP_CFG_0.MAC_MSB. | 16 | | | х | | MAC_LSB | See ANA_L3:ARP:ARP_CFG_1.MAC_LSB. | 32 | | | х | | ARP_VMID | See ANA_L3:ARP:ARP_CFG_0.ARP_VMID. | 5 | | | х | | ZERO_DMAC_CP<br>U_QU | See<br>ANA_L3:ARP:ARP_CFG_0.ZERO_DMAC_CP<br>U_QU. | 3 | | | | | SIP_RPF_ENA | See<br>ANA_L3:ARP:ARP_CFG_0.SIP_RPF_ENA. | 1 | | | | | SECUR_MATCH_<br>VMID_ENA | See<br>ANA_L3:ARP:ARP_CFG_0.SECUR_MATCH_<br>VMID_ENA. | 1 | | | | | SECUR_MATCH_<br>MAC_ENA | See ANA_L3:ARP:ARP_CFG_0.SECUR_MATCH_ MAC_ENA. | 1 | | | | | ARP_ENA | See ANA_L3:ARP:ARP_CFG_0.ARP_ENA. | 1 | | | | ## 3.17 IP Processing This section provides information about IP routing and IP security checks. The configuration parameters for IP routing are located within the ANA L3 configuration target. Each frame is subject to two lookups in VCAP LPM. One lookup is used for looking up SIP, and the other lookup is used for looking up DIP or DIP+SIP (for IP multicast frames). ### 3.17.1 IP Source/Destination Guard For security purposes, the device can be configured to identify specific combinations of the following information and apply security rules based on that information. - (SMAC, SIP) or (VMID, SIP) - (DMAC, DIP) or (VMID, DIP) The VCAP LPM and ARP table in ANA\_L3 are used to perform matching. The result of the matching is available for security rules in ANA\_ACL through the following VCAP fields: - L3 SMAC SIP MATCH. Set to 1 if (VMID, SIP) and/or (SMAC, SIP) match was found. - L3 DMAC DIP MATCH. Set to 1 if (VMID, DIP) and/or (DMAC, DIP) match was found. IP source/destination guard check can be enabled per port using COMMON:SIP\_SECURE\_ENA and COMMON:DIP\_SECURE\_ENA. When enabled, the frame's DIP and the frame's SIP are each looked up in VCAP LPM. The associated VCAP action provides an index to an ARP Table entry in which the required SMAC/DMAC and/or VMID is configured. The following pseudo code specifies the behavior of the IP Source Guard checks. ``` // Determine value of req.13_sip_match (available in ANA_ACL as L3_SMAC_SIP_MATCH) if (!req.ip4_avail && !req.ip6_avail) { req.13_sip_match = 1; return; if (csr.sip_cmp_ena(req.port_num)) { req.13_sip_match = 0; } else { req.13_sip_match = 1; if (!LpmHit()) { return; if (req.ip4_avail) { csr.secur_ip4_lpm_found_sticky = 1; if (req.ip6_avail) { csr.secur_ip6_lpm_found_sticky = 1; sip_arp_entry = csr.arp_tbl[sip_lpm_entry.arp_ptr]; if ((sip_arp_entry.secur_match_vmid_ena == 0 || igr_vlan_entry.vmid == sip_arp_entry.arp_vmid) (sip_arp_entry.secur_match_mac_ena == 0 || req.smac == sip_arp_entry.mac)) { ``` ``` req.13_sip_match = 1; if (req.ip4_avail) { csr.secur_ip4_sip_match_sticky = 1; } else { csr.secur_ip6_sip_match_sticky = 1; } if (req.13_sip_match == 0) { csr.secur_sip_fail_sticky = 1; } ``` The IP Destination Guard check works in the same way as the SIP check, except for the following: - DIP check is not performed if frame has a multicast DMAC. - DIP check is not performed if router leg has been matched. The following pseudo code specifies the behavior of the IP Destination Guard checks. ``` // Determine value of req.13_sip_match (available in ANA_ACL as L3_SMAC_SIP_MATCH) if (!req.ip4_avail && !req.ip6_avail) { req.13_sip_match = 1; return; if (csr.sip_cmp_ena(req.port_num)) { req.13_sip_match = 0; } else { req.13_sip_match = 1; if (!LpmHit()) { return; if (req.ip4_avail) { csr.secur_ip4_lpm_found_sticky = 1; if (req.ip6_avail) { csr.secur_ip6_lpm_found_sticky = 1; sip_arp_entry = csr.arp_tbl[sip_lpm_entry.arp_ptr]; if ((sip_arp_entry.secur_match_vmid_ena == 0 || igr_vlan_entry.vmid == sip_arp_entry.arp_vmid) (sip_arp_entry.secur_match_mac_ena == 0 || req.smac == sip_arp_entry.mac)) { req.13_sip_match = 1; if (req.ip4_avail) { csr.secur_ip4_sip_match_sticky = 1; } else { csr.secur_ip6_sip_match_sticky = 1; } ``` ``` if (req.13_sip_match == 0) { csr.secur_sip_fail_sticky = 1; } ``` ## **3.17.2 IP Routing** The device supports routing of IPv4 and IPv6 unicast and multicast packets through the 32 router interfaces, also known as "router legs". Each router leg is attached to a VLAN. The following illustration shows a configuration with three VLANs, each with an attached router leg for routing IP packets between the VLANs. Port 11 is member of both VLAN 1 and VLAN 2. When a packet is being routed from one VLAN (the ingress VLAN) to another VLAN (the egress VLAN), the VID of the ingress VLAN is termed IVID, and the VID of the egress VLAN is termed the EVID. #### Figure 30 • Router Model Within the device, a router leg is identified by a 5-bit VMID value. When a packet is being routed, it is then received by the router entity using a router leg identified by an ingress VMID (or IVMID) and transmitted on an egress router leg identified by an egress VMID (or EVMID). IP routing, also known as L3 forwarding, is only supported in VLAN-aware mode. ### 3.17.2.1 Frame Types for IP Routing In order for IP packets to be routed by the device, the following conditions must be met. - IPv4 packets must not contain options. - IPv6 packets must not contain hop-by-hop options. - Optionally packets with some illegal SIP and DIP addresses can be filtered. For more information, see Illegal IPv4 Addresses, page 135 and Illegal IPv6 Addresses, page 135. - IPv4 header checksum must be correct. ## 3.17.2.2 Routing Table Overview The following illustration provides an overview of the table lookups involved in IP unicast routing within the L3 part of the analyzer. The VCAP and ARP table lookups are performed in parallel with the VLAN/MSTP/VMID table lookups. If the frame does not match a router leg, the result of VCAP and ARP table lookups are not used for routing. Figure 31 • Unicast Routing Table Overview The following illustration provides an overview of the table lookups involved in IP multicast routing within the L3 part of the analyzer. The VCAP and L3MC table lookups are performed in parallel with the VLAN/MSTP/VMID table lookups. If the frame does not match a router leg, the result of VCAP and L3MC table lookups are not used for routing. Figure 32 • Multicast Routing Table Overview ## 3.17.2.3 Ingress Router Leg Lookup The VID used to determine the ingress router leg is the classified VID. The classified VID can be deducted based on a variety of parameters, such as VLAN tag or ingress port. For more information, see VLAN Classification, page 105. A total of 32 router legs are supported. Each router leg can be used for both IPv4 and IPv6 unicast and multicast routing. A maximum of one router leg per VLAN is supported. When processing incoming frames, the classified VID is used to index the VLAN table. The RLEG\_ENA parameter determines if the VLAN is enabled for routing of packets, and if so, the VMID is used to index the VMID table. The flow is depicted in the following illustration. Figure 33 • Ingress Router Leg Lookup Flow #### 3.17.2.3.1 Unicast Router Leg Detection On L2, up to three different MAC addresses are used to identify the router leg: The normal router leg MAC address. This MAC address consists of a base address that is configured using COMMON:RLEG\_CFG\_0.RLEG\_MAC\_LSB and COMMON:RLEG\_CFG\_0.RLEG\_MAC\_MSB. To have different MAC addresses for each router leg, the three least significant bytes of the base MAC address can optionally be incremented by the Classified VID or the VMID. This is configured using COMMON:RLEG\_CFG\_1.RLEG\_MAC\_TYPE\_SEL. VRRP MAC address for IPv4. This MAC address consists of a base address that is configured using COMMON:VRRP\_IP4\_CFG\_0.VRRP\_IP4\_BASE\_MAC\_MID and COMMON:VRRP\_IP4\_CFG\_0.VRRP\_IP4\_BASE\_MAC\_HIGH. For each router leg, the least signficant byte is configured per router leg using VMID:VRRP\_CFG.RLEG\_IP4\_VRID. Up to two VRID values are supported per router leg. Use of VRRP for IPv4 is enabled using VMID:RLEG\_CTRL.RLEG\_IP4\_VRID\_ENA. VRRP MAC address for IPv6. This is configured in the same manner as VRRP MAC address for IPv4. The matching of router leg MAC address for unicast packets is shown in the following illustration. Figure 34 • Ingress Router Leg MAC Address Matching for Unicast Packets The packet is a candidate for unicast routing if a frame's DMAC matches one of the router leg MAC addresses. Packets sent to the router itself will also match the router leg MAC address, but these will be caught through entries in the ARP table. Despite matching a router leg MAC address, routing is not performed for any of the following reasons. If any of following criteria are met, the frame may be redirected to the CPU, depending on configuration parameters. - It is not an IP packet (for example, an ARP reply). - · There are IP header errors. - DIP or SIP address is illegal (optional). - Packet contains IPv4 options/IPv6 hop-by-hop options. - IPv4 TTL or IPv6 HL is less than two. #### 3.17.2.3.2 Multicast Router Leg Detection For each router leg, IP multicast routing can be enabled using VMID:RLEG\_CTRL.RLEG\_IP4\_MC\_ENA and VMID:RLEG\_CTRL.RLEG\_IP6\_MC\_ENA. In addition to having multicast routing enabled for the router leg configured for the VLAN, the frame's DMAC must be within a specific range in order for the packet to be candidate for IPv4/6 routing. - IPv4 DMAC range: 01-00-5E-00-00-00 to 01-00-5E-7F-FF-FF - IPv6 DMAC range: 33-33-00-00-00 to 33-33-FF-7F-FF Despite having a DMAC address within the required range, routing is not performed for any of the following reasons: - · There are IP header errors. - DIP or SIP address is illegal (optional). - Packet contains IPv4 options/IPv6 hop-by-hop options - IPv4 TTL or IPv6 HL is less than two. If any of above criteria are met, then the frame may be redirected to CPU, depending on configuration parameters. The frame is still L2 forwarded if no router leg match is found. #### 3.17.2.3.3 Illegal IPv4 Addresses Use the ROUTING\_CFG.IP4\_SIP\_ADDR\_VIOLATION\_REDIR\_ENA parameters to configure each of the following SIP address ranges to be considered illegal. - 0.0.0.0 to 0.255.255.255 (IP network zero) - 127.0.0.0 to 127.255.255.255 (IP loopback network) - 224.0.0.0 to 255.255.255.255 (IP multicast/experimental/broadcast) Frames with an illegal SIP can be redirected to the CPU using CPU\_RLEG\_IP\_HDR\_FAIL\_REDIR\_ENA. Use the ROUTING\_CFG.IP4\_DIP\_ADDR\_VIOLATION\_REDIR\_ENA parameters to configure each of the following DIP address ranges to be considered illegal. - 0.0.0.0 to 0.255.255.255 (IP network zero) - 127.0.0.0 to 127.255.255.255 (IP loopback network) - 240.0.0.0 to 255.255.255.254 (IP experimental) Frames with an illegal DIP can be redirected to the CPU using CPU\_RLEG\_IP\_HDR\_FAIL\_REDIR\_ENA. #### 3.17.2.3.4 Illegal IPv6 Addresses Use the ROUTING\_CFG.IP6\_SIP\_ADDR\_VIOLATION\_REDIR\_ENA parameters to configure each of the following SIP address ranges to be considered illegal. - ::/128 (unspecified address) - ::1/128 (loopback address) - ff00::/8 (IPv6 multicast addresses) Frames with an illegal SIP can be redirected to the CPU using CPU RLEG IP HDR FAIL REDIR ENA. Use the ROUTING\_CFG.IP6\_DIP\_ADDR\_VIOLATION\_REDIR\_ENA parameters to configure each of the following DIP address ranges to be considered illegal. - ::/128 (unspecified address) - ::1/128 (loopback address) Frames with an illegal DIP can be redirected to the CPU using CPU RLEG IP HDR FAIL REDIR ENA. ### 3.17.2.4 Unicast Routing The IPv4/IPv6 unicast forwarding table in the Analyzer is configured with known routes. There are typically two types of routes: Local IP and Remote IP. - Local IP networks directly accessible through the router. These entries return the DMAC address of the destination host and correspond to an ARP lookup. - Remote IP networks accessible through a router. These entries return the DMAC address of the next-hop router. If frames are deemed suitable for IP unicast routing, a DIP lookup is performed in the Longest Prefix Match (LPM) table. The lookup is a Classless Inter-Domain Routing (CIDR) lookup. That is, all network sizes are supported. For IP addresses in local IP networks without corresponding MAC addresses, LPM entry with a corresponding ARP entry with a zero MAC address should be configured. This results in redirecting the matching frames to the CPU and thus allows the CPU to exchange ARP/NDP messages with the stations on the local IP networks to request their MAC address and afterwards use this information to update the ARP table. Packets with IVMID = EVMID (packets that are to be routed back to the router leg on which they were received) can optionally be redirected to the CPU such that the CPU can generate an ICMP Redirect message. This is configurable using VMID:RLEG\_CTRL.RLEG\_IP4\_ICMP\_REDIR\_ENA and VMID:RLEG\_CTRL.RLEG\_IP6\_ICMP\_REDIR\_ENA. If such packets are not redirected to the CPU, they are routed. IVMID and EVMID are configured using VLAN:VMID CFG.VMID and ARP:ARP CFG 0.ARP VMID. The following illustration shows an IPv4 unicast routing example. IPv6 unicast routing works identically to IPv4 unicast routing, with the exception that each of the IPv6 addresses occupies four times as much space in VCAP LPM. Figure 35 • IP Unicast Routing Example Ports o, n, and m are connected to Router A3, Host A1, and Host A2. These stations are included in an IP subnet associated with VLAN 1 and connected to the router by router leg 1. Router leg 1's MAC address is shown. Ports a, b, and c are connected to Router B2, Host B1, and Host B3. These stations are included in an IP subnet associated with VLAN 2 and connected to the router by router leg 2. The router leg MAC addresses in the example offsets the base MAC address by the respective router leg's VMID. Traffic destined within a subnet is L2-forwarded. For example, traffic from Host A1 to Host A2 is L2 forwarded. Traffic destined outside a subnet is sent to the router using the router leg's MAC address. The router performs the routing decision as follows: - 1. Known local host. If the destination IP address is known to be a local host (with the full IP address installed in the VCAP LPM table), the router takes the local host DMAC address and egress router leg VMID (EVMID) from the ARP table entry pointed to by the ARP\_IDX of the VCAP Action. For example, if traffic sent from Host A1 to B1 is routed using LPM entry m+2 (2.2.2.1/32) and ARP entry m+2, the local host's DMAC address is found to be 0x000002020201 and egress router leg to be RLEG2 (that is, VMID = 2). - 2. **Known longest prefix.** If the full destination IP address is not known, the router finds the longest matching IP prefix and uses it to determine the next hop DMAC address and egress router leg. For example, traffic sent from host A1 to host 4.4.4.2 is routed using LPM entry n + 2 (the 4.4.0.0 subnet is reached through Router B2) and using ARP entry 0, the next hop's DMAC address is found to be 0x000002020202 and egress router leg to be RLEG2 (for example, VMID = 2). - 3. **Known equal cost multiple paths (ECMP).** If the full destination IP address is not known by the router and the longest matching IP prefix is an equal cost path, the next hop DMAC address and egress router leg is derived from one of up to 16 ARP entries. For example, traffic sent from host A1 to host 5.5.5.13 is routed using VCAP LPM entry n + 1. The corresponding VCAP action has ECMP = 1, so the ARP table entry is chosen to be either n + 2 or n + 3, based on a pseudo random number. If entry n + 2 is chosen, the next hop's DMAC address is found to be 0x000001010103 (Router A3) and egress router leg to be RLEG1. If entry n + 3 is chosen, the next hop's DMAC address is found to be 0x0000020202020 (Router B2) and egress router leg to be RLEG2. - 4. **Default gateway.** In order to forward packets destined to unknown subnets to a default router, a default rule can be configured for the VCAP LPM. This is illustrated in the IP Unicast Routing example as a "0.0.0.0" rule. For example, traffic sent from host A1 to host 8.9.4.2 is routed using LPM entry 0 (the default router is reached through Router B2) and ARP entry 0, the next hop's DMAC address is found to be 0x000002020202 and egress Router Leg to be RLEG2. When routing packets, the router replaces the frame's DMAC with the ARP table's DMAC and replaces the SMAC with MAC address associated with the egress router leg. The classified VID is replaced by the egress VID (VMID:RLEG\_CTRL.RLEG\_EVID). The TTL/HL is decremented by 1. Note that the VMID tables (ANA\_L3:VMID and REW:VMID) and the router leg MAC address must be configured consistently in the analyzer Layer 3 and rewriter. If host A2 wants to send traffic to a host in subnet 3.3.0.0/16, the host issues an ARP request and gets a response to send traffic to router A3. Host A2 can choose to ignore this request, in which case, the router routes to router A3 in the same VLAN. Local networks 1.1.1.0/24 and 2.2.2.0/24 are also configured. Hosts and routers located in these networks can be directly L2 accessed. This includes IP addresses 1.1.1.0 and 2.2.2.0, which are the IP addresses of the router in the respective subnets to be used for IP management traffic, for example. #### 3.17.2.4.1 Encoding ARP Entry in VCAP Action Instead of using an entry in the ARP table, the ARP information can alternatively be written into the VCAP action of the LPM entry so as to not be limited by the size of the ARP table. ARP entries written into a VCAP actions have the following limitations compared to ARP entries in the ARP table. - ECMP cannot be supported. If there are multiple paths to a given subnet, then ARP table entries must be used. - RGID cannot be configured. If RGIDs of SIP RPF are used, then ARP table entries must be used for such routes. - Alternative Next Hop Configuration cannot be supported. If Alternative Next Hop Configuration is required, then ARP table entries must be used. #### 3.17.2.4.2 ARP Pointer Remap An ARP Pointer Remap table is available to support fast fail-over when the next hop changes for a large group of LPM VCAP entries. By setting ARP\_PTR\_REMAP\_ENA=1 in LPM VCAP action, the ARP\_PTR in the VCAP action is used to address an entry in the ARP\_PTR\_REMAP table and through this, new ARP\_PTR and ECMP\_CNT values are looked up and used for lookup in the ARP table. Thus instead of updating ARP\_PTR and ECMP\_CNT for many LPM VCAP entries, only the corresponding entry in ARP\_PTR\_REMAP needs to be updated. The following illustration depicts both the case where ARP Pointer remapping is not used as well as the case where it is used, that is ARP\_PTR\_REMAP\_ENA = 1. Figure 36 • ARP Pointer Remapping #### ARP PTR REMAP Table not used # ARP\_PTR remapped through ARP PTR REMAP Table #### 3.17.2.5 IP Multicast Routing The multicast system is split into two stages, stage 1 and stage 2. In stage 1, the frame is received on a front port and the IP multicast system in ANA\_L3 is activated. This stage is used to ensure L2 forwarding to all relevant ports in the ingress VLAN as well as ingress mirroring. If the frame needs to be L3 forwarded to other VLANs, an internal port module called virtual device 0 (VD0) also receives an L2 copy, together with information about the number of VLANs that receive a routed copy of the frame. In stage 2, the analyzer processes each frame copy from VD0, and L3 forwards each frame copy to its egress VLAN. In stage 1, ANA\_L3 uses the VCAP LPM to determine the forwarding of the frame. Typically, two types of VCAP LPM multicast entries exist: source-specific and source-independent. - Source specific IP multicast groups, where the same group IP address can be used by multiple sources. Such groups are denoted (S,G). - Source independent IP multicast groups, where the group IP address uniquely identifies the IP multicast flow. Such groups are denoted (\*,G). IPv4 multicast groups occupies two entries in the VCAP LPM, and IPv6 multicast groups occupies eight entries. Source-specific multicast groups must be placed with higher precedence than source-independent multicast groups. A matching entry in the VCAP LPM results in an index (L3MC\_IDX) to an entry in the L3MC Table. Each L3MC table entry contains a list of egress router legs to which frames are routed. Upon removing the ingress router leg from the list, the required number of routed multicast copies is calculated and this number (L3MC\_COPY\_CNT) is sent to VD0. Stage 1 L2 forwards the frame. ANA\_ACL can be used to limit the L2 forwarding, for example, to support IGMP/MLD snooping. For each L3MC entry, it can optionally be configured that routing is only performed if the frame was received by a specific ingress router leg. This is termed reverse path forwarding check and is configured using L3MC:L3MC\_CTRL.RPF\_CHK\_ENA and L3MC:L3MC\_CTRL.RPF\_VMID. Note that this RPF check is unrelated to the SIP RPF check. For more information about the SIP RPF check, see SIP RPF Check, page 142. Reverse path forwarding check does not affect the L2 forwarding decision. In stage 2, VD0 replicates the frame according to L3MC\_COPY\_CNT, and L3MC\_IDX is written into the frame's IFH. For each copy, which ANA\_L3 receives from VD0 during stage 2, L3MC\_IDX from IFH is used to lookup the L3MC table entry and thus find the list of egress router legs that require a routed copy. The egress router leg is used to determine the egress VID which in turn is used to perform (VID, DMAC) lookup in the MAC table for L2 forwarding within the egress VLAN. For each egress router leg, it can be configured that frames are only L3 forwarded to the router leg if the TTL/HL of the packet is above a certain value. This is configured using VMID:VMID\_MC.RLEG\_IP4\_MC\_TTL and VMID:VMID\_MC.RLEG\_IP6\_MC\_TTL. In stage 2, both learning and ingress filtering is disabled. The following illustration shows an IPv4 multicast routing example. IPv6 multicast routing works identically to IPv4 multicast routing, with the exception that the IPv6 entries occupies four times as much space in VCAP LPM. Figure 37 • IP Multicast Routing Example A sender host with IPv4 address 1.1.1.3 is transmitting IPv4 multicast frames to the group address 230.1.1.1 and DMAC = 0x01005E010101. The frames must be L2 forwarded to receivers in VLAN 1 and L3 forwarded to receivers in VLAN 2. For the latter, an entry for the (1.1.1.3, 230.1.1.1) pair is added to the VCAP LPM. #### 3.17.2.5.1 Stage 1 - Lookup of (SIP,G) = (1.1.1.3, 230.1.1.1) in VCAP LPM returns L3MC\_IDX = 0 and a corresponding entry in L3MC table. L3MC\_IDX = 0 is inserted into the IFH. - The L3MC entry has RPF check enabled (RPF\_ENA = 1). Because the frame has been received through the specified router leg. L3 forwarding is allowed. - The L3MC entry specifies that frames are forwarded to router leg 1 and 2. Because the frame has been received on router leg 1, only router leg 2 needs a routed copy. In other words, the number of L3 frame copies required is set to 1. - If the frame's TTL is <2, then the frame is not L3 forwarded.</li> - Lookup of (DMAC, VID) = (0x01005E010101, 1) in the MAC table returns a destination set with port 8 and 9. Port 8 is source filtered due to normal L2 source port filtering, so the resulting destination set consists only of port 9. - As a result of the first stage, the frame has been L2 forwarded to port 9 and a copy with L3MC\_IDX = 0 and L3 copies required = 1 has been forwarded to the VD0. #### 3.17.2.5.2 Stage 2 - A frame is received once from VD0 with L3MC\_IDX = 0 and L3MC\_COPY\_CNT = 1. - Lookup of L3MC\_IDX = 0 in the L3MC table returns the same entry as used in stage 1. Because this is the first routed copy, the new EVMID is 2, and through lookup in the VMID table, the corresponding EVID is 2. - If Frame.IP.TTL < VMID.VMID MC.RLEG IP4 MC TTL, the frame is not L3 forwarded.</li> - The frame's TTL is decremented. - Lookup of (DMAC, VID) = (0x01005E010101, 2) in the MAC table returns a destination set with port 10 and 11. Because this is a routed copy, no source port filtering is applied. The result is a routed copy to ports 10 and 11 with replaced SMAC and VID from VMID = 2 and TTL decremented. #### 3.17.2.6 SIP RPF Check As a security measure, the device can be configured to only L3 forward frames if the SIP belongs to a known subnet and is received by one (or more) specific router legs, for example, the router leg through which the subnet is reached. This configuration can be used to filter IP address spoofing attempts. To support SIP RPF check, each route in VCAP LPM is assigned a Route Group ID (RGID); that is, any route in the VCAP LPM belongs to exactly one Route Group. Eight RGID values are supported. In the VMID table the set of acceptable RGIDs for each router leg is configured using RGID MASK. Each router leg can be configured to operate in the following SIP RPF modes. - · Disabled. No SIP RPF check is performed. - RGID mode. Frames are only L3 forwarded if the SIP's RGID is enabled in the router leg's RGID\_MASK. If the ARP information is encoded directly in the VCAP action and SIP RPF mode is set to RGID mode, then an Rleg mode check is performed instead, because an ARP entry encoded in the VCAP Action contains to RGID. - Rleg mode. Frames are only L3 forwarded if the VMID of the ARP table entry resulting from SIP LPM lookup is identical to the ingress VMID. For example, the router leg, which the frame was received on, is also the router leg used for forwarding frames to the SIP. Rleg mode cannot be used for ECMP LPM entries, because each route is only accepted by one router leg. In Rleg mode, no SIP RPF check is performed if SIP is reachable using an ECMP path. Combined mode. This is a combination of RGID mode and Rleg mode. If the SIP LPM lookup results in an LPM entry with ECMP\_CNT = 0, an Rleg mode check is performed, otherwise a RGID Mode check is performed. RFC3704 defines a number of different SIP RPF modes, which can be supported by the device as follows: - · Strict RPF. Use Rleg mode or Combined mode to also support ECMP. - Loose RPF. Use RGID mode and configure RGID\_MASK to all-ones. For example, any RGID value is acceptable. - Loose RPF ignoring default routes. Use RGID mode and configure a separate RGID value for the default route. Exclude this value in router leg's RGID\_MASK. - Feasible RPF. Use RGID mode, group LPM entries using RGID and enable only the accepted groups in the router leg's RGID\_MASK. Note that SIP RPF is unrelated to the L3MC RPF check enabled in L3MC:L3MC\_CTRL.RPF\_CHK\_ENA, which validates that a given IP multicast flow (identified by (S,G) or (\*,G) was received by the expected router leg. Frames that are not routed due to SIP RPF check can optionally be redirected to CPU by configuring COMMON:ROUTING\_CFG.RLEG\_IP4\_SIP\_RPF\_REDIR\_ENA and COMMON:ROUTING\_CFG.RLEG\_IP6\_SIP\_RPF\_REDIR\_ENA. #### 3.17.2.7 CPU Redirection of Filtered Frames The following table provides an overview of the available CPU queues used when copying/redirecting frames to CPU. Table 76 • CPU Queue Overview | CPU Queue | Description | |--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | COMMON:CPU_QU_CFG.CPU_RLEG_QU | Non-IP unicast frames matching an ingress router leg.<br>For example, ARP PDUs.<br>CPU queue for IP frames with L2 broadcast DMAC,<br>received by router leg. | | COMMON:CPU_QU_CFG.CPU_RLEG_IP_OPT_QU | IPv4 frames with options and IPv6 frames with hop-by-hop option. | Table 76 • CPU Queue Overview (continued) | CPU Queue | Description | |-------------------------------------------|---------------------------------------------------------------------------------------------------| | COMMON:CPU_QU_CFG.CPU_RLEG_IP_HDR_FAIL_QU | IPv4 frames with IP header errors. | | COMMON:CPU_QU_CFG.CPU_IP_LEN_QU | CPU queue for IPv4/IPv6 frames failing MTU check. | | COMMON:CPU_QU_CFG.CPU_MC_FAIL_QU | Failed IP multicast lookup or failed RPF check. | | COMMON:CPU_QU_CFG.CPU_UC_FAIL_QU | Failed IPv4/IPv6 unicast LPM lookup, invalid ARP entry (ARP_ENA=0) or failed ICMP redirect check. | | COMMON:CPU_QU_CFG.CPU_IP_TTL_FAIL_QU | Frames with TTL/HL <2. | | COMMON:CPU_QU_CFG.CPU_SIP_RPF_QU | Frames failing SIP RPF check. | | ARP:ARP_CFG_0.DMAC0_CPU_QU | MAC address in ARP entry is all-zeros. | | L3MC:L3MC_CTRL.CPU_QU | L3MC.L3MC_CTRL.CPU_REDIR_ENA = 1. | ## 3.17.3 Statistics For each frame, ANA\_L3 generates a number of events that can be counted in ANA\_AC's statistics block. Events are generated separately for ingress and egress router legs, and in ANA\_AC, event counting is further split into IPv4 and IPv6. ### 3.17.3.1 Ingress Router Leg Statistics The ingress router leg statistics events generated by ANA L3 are listed in the following table. Table 77 • Ingress Router Leg Events | Event Name | Description | |---------------------------|---------------------------------------------------------------------------| | ivmid_ip_uc_received | IP unicast frame received by router. | | ivmid_ip_mc_received | IP multicast frame received by router. | | ivmid_ip_uc_routed | IP unicast frame received and L3 forwarded by router. | | ivmid_ip_mc_routed | IP multicast frame received and L3 forwarded by router. | | ivmid_ip_mc_rpf_discarded | IP multicast frame received by router, but discarded due to MC RPF check. | | ivmid_ip_ttl_discarded | IP multicast frame received by router, but discarded due to TTL <2. | | ivmid_ip_acl_discarded | IP frame received by router, but discarded by ACL rules in ANA_AC. | For counting of ingress router leg events, eight counter pairs are provided per router leg. Each pair consists of a counter for IPv4 and a counter for IPv6, for a total of 16 counters that are available per router leg. For each of the eight counter pairs, an event mask can be configured to specify which of the Ingress router leg events listed will trigger the counter. Each counter pair can be configured to count either bytes or frames. An example usage of the counters is shown in the following table. Table 78 • Ingress Router Leg Statistics Example | | Event Name | | | | | | | | | |-----------|--------------------------|---------------------------|----------------------|----------------------|--------------------|--------------------|---------------------------|------------------------|------------------------| | Reference | Counter Name | Byte<br>(b/)/Frame<br>(f) | ivmid_ip_uc_received | ivmid_ip_mc_received | ivmid_ip_uc_routed | ivmid_ip_mc_routed | ivmid_ip_mc_rpf_discarded | ivmid_ip_ttl_discarded | ivmid_ip_acl_discarded | | RFC 4293 | iplfStatsInReceives | f | Х | Х | | | | | | | RFC 4293 | iplfStatsInOctets | b | Х | Х | | | | | | | RFC 4293 | iplfStatsInForwDatagrams | f | | | Х | Х | | | | | RFC 4293 | ipIfStatsInMcastPkts | f | | Х | | | | | | | RFC 4293 | iplfStatsInMcastOctets | b | | Х | | | | | | | RFC 4293 | iplfStatsInHdrErrors | f | | | | | | Х | | | | MC RPF discards | f | | | | | Х | | | | | ACL discards | f | | | | | | | Х | ## 3.17.3.2 Egress Router Leg Statistics The egress router leg statistics events generated by ANA L3 are listed in the following table. Table 79 • Egress Router Leg Events | Event Name | Description | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | evmid_ip_uc_routed | IP unicast frame L3 forwarded by router. | | evmid_ip_mc_routed | IP multicast frame L3 forwarded by router. | | evmid_ip_mc_switched | IP multicast frame L2 forwarded by switch. | | evmid_ip_mc_ttl_discarded | IP multicast frame discarded by router due to TTL value configured for egress router leg. See VMID:VMID_MC:RLEG_IP4_MC_TTL and VMID:VMID_MC:RLEG_IP6_MC_TTL. | | evmid_ip_acl_discarded | IP frame discarded by ACL rules in ANA_AC. | For counting of egress router leg events, eight counter pairs are provided per router leg. Each pair consists of a counter for IPv4 and a counter for IPv6, for a total of 16 counters available per router leg. For each of the eight counter pairs, an event mask can be configured to specify which of the events listed in the following table will trigger the counter. Each counter pair can be configured to count either bytes or frames. An example usage of the counters is shown in the following table. Table 80 • Egress Router Leg Statistics Example | | Event Name | | | | | | | |--------------|---------------------------|---------------------------|--------------------|--------------------|----------------------|------------------------|------------------------| | Reference | Counter Name | Byte<br>(b/)/Frame<br>(f) | evmid_ip_uc_routed | evmid_ip_mc_routed | evmid_ip_mc_switched | evmid_ip_ttl_discarded | evmid_ip_acl_discarded | | RFC 4293 | ipIfStatsOutForwDatagrams | f | Х | Х | | | | | RFC 4293 | ipIfStatsOutOctets | b | Х | Х | | | | | RFC 4293 | ipIfStatsOutMcastPkts | f | | Х | | | | | RFC 4293 | ipIfStatsOutMcastOctets | b | | Х | | | | | Microsemi | IP MC TTL discards | f | | | | Х | | | WIIOLOGCITII | ii iii o i i E diocardo | - | | | | | | #### 3.17.3.3 LPM Statistics For debugging purposes and usage monitoring, the VCAP includes a sticky bit per entry. ## 3.17.4 IGMP/MLD Snooping Switch RFC4541 describes recommendations on how an IGMP/MLD snooping switch forwards IP Multicast packets. To implement the required data forwarding rules for an IGMP/MLD snooping switch, the VCAP IS2 lookup in ANA\_ACL must be used. For each IP multicast flow, the VCAP IS2 lookup can be used to limit the forwarding within each VLAN using the following key types: - IGMP snooping switch: IP4 VID - MLD snooping switch: IP6\_VID Both key types include SIP, DIP, and VID such that snooping switches can be supported for IGMPv3 and MLDv2. In the action of the VCAP rules, the following fields can be used to limit the forwarding. - PORT\_MASK. The ports to which the frame is forwarded within the VLAN. - MASK MODE. Should normally be set to 1 (AND VLANMASK). When IP multicast routing is combined with snooping, a lookup in VCAP IS2 is made for each copy of the IP multicast packet. The VID in each such lookup is the VID of the egress VLAN (of that copy). In order for the VCAP rules to use the EVID in the IP4\_VID/IP6\_VID key, the second VCAP lookup must be used, and ANA\_ACL::VCAP\_S2\_CFG.SEC\_ROUTE\_HANDLING\_ENA must be set to 1. ## 3.18 VCAP IS2 Keys and Actions VCAP IS2 is part of ANA\_ACL and enables access control lists using VCAP functionality. This section provides detailed information about all available VCAP IS2 keys and actions. For information about how to select which key to use and how the VCAP IS2 action is applied, see VCAP IS2, page 156. ## **3.18.1 VCAP IS2 Keys** VCAP IS2 supports a number of different keys that can be used for different purposes and frame types. The keys are of type X4, X8, or X16 depending on the number of words each key uses. The keys are grouped after size as shown in the following table. Table 81 • VCAP IS2 Keys and Sizes | Key Name | Key Size | Number of Words | Key Type | |-------------|----------|-----------------|----------| | IP4_VID | 88 bits | 4 words | X4 type | | MAC_ETYPE | 271 bits | 8 words | X8 type | | ARP | 210 bits | | | | IP4_TCP_UDP | 283 bits | | | | IP4_OTHER | 274 bits | | | | CUSTOM_2 | 284 bits | | | | IP6_VID | 284 bits | | | | IP_7TUPLE | 567 bits | 16 words | X16 type | | CUSTOM_1 | 546 bits | | | | | | | | The following table lists details for all VCAP IS2 keys and fields. When programming an entry in VCAP IS2, the associated key fields must be programmed in the listed order with the first field in the table starting at bit 0 in the entry. As an example, for a MAC\_ETYPE entry, the first field X8\_TYPE must be programmed at bits 3:0 of the entry, the second field FIRST must be programmed at bit 4, and so on. Table 82 • VCAP IS2 Key Overview | Field Name | Description | Size | IP4 VID | | | IP4 TCP UDP | · 뿐<br>- | CUSTOM 2 | -<br>IP6 VID | P 7TUPLE | CUSTOM_1 | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|---|---|-------------|----------|----------|--------------|----------|----------| | X8_TYPE | X8 type. 0: MAC_ETYPE 3: ARP 4: IP4_TCPUDP 5: IP4_OTHER 8: CUSTOM_2 9: IP6_VID | 4 | | х | x | х | x | x | x | | | | X16_TYPE | X16 type.<br>1: IP7_TUPLE<br>2: CUSTOM_1 | 2 | | | | | | | | Х | х | | FIRST | Selects between entries relevant for first and second lookup. Set for first lookup, cleared for second lookup. | 1 | Х | Х | Х | х | х | Х | Х | Х | Х | | PAG | Classified Policy Association Group (PAG). PAG can be used to tie VCAP CLM lookups with VCAP IS2 lookups. The default PAG value is configurable per port in ANA_CL:PORT:PORT_ID_CFG.PAG_VAL. | 8 | Х | Х | Х | Х | Х | Х | Х | X | х | Table 82 • VCAP IS2 Key Overview (continued) | | | | IP4_VID | .C_ETYPE | <b>_</b> | _TCP_UDP | OTHER | CUSTOM_2 | IP6_VID | IP_7TUPLE | CUSTOM_1 | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|----------|----------|----------|-------|----------|---------|-----------|----------| | Field Name | Description | Size | IP4 | MAC | ARP | IP4_I | IP4_( | S | IP6 | ₽, | 3 | | IGR_PORT_MASK_SEL | Mode selector for IGR_PORT_MASK. 0: Default setting. 1: Set for frames received from a loopback device, i.e. LBK_DEV*. 2: Set for masqueraded frames if ANA_ACL::VCAP_S2_MISC_CTRL.MASQ_IGR_ MASK_ENA == 1. A masqueraded frame is identified by the following criteria: (IFH.FWD.DST_MODE == INJECT && IFH.SRC_PORT != physical src port) (MISC.PIPELINE_ACT == INJ_MASQ) 3: Set for the following frame types: 3a: CPU injected frames and ANA_ACL::VCAP_S2_MISC_CTRL.CPU_IGR_M ASK_ENA == 1. 3b: Frames received from VD0 or VD1 and ANA_ACL::VCAP_S2_MISC_CTRL.VD_IGR_MA SK_ENA == 1. 3c: Frame received on a loopback device and ANA_ACL::VCAP_S2_MISC_CTRL.LBK_IGR_M ASK_SEL3_ENA == 1. If a frame fulfills multiple of above criteria, then higher value of IGR_PORT_MASK_SEL takes precedence. | 2 | | x | x | x | x | x | | x | x | | IGR_PORT_MASK | Ingress port mask. IGR_PORT_MASK_SEL == 0: Each bit in the mask correspond to physical ingress port. IGR_PORT_MASK_SEL == 1: Each bit in the mask correspond to the physical port on which the frame was looped. IGR_PORT_MASK_SEL == 2: Each bit in the mask correspond to the masqueraded port. If IGR_PORT_MASK_SEL == 3: Bit 0: Physical src port == CPU0 Bit 1: Physical src port == CPU1 Bit 2: Physical src port == VD0 Bit 3: Physical src port == VD1 Bits 4:9: Src port (possibly masqueraded or looped) Bits 44:48: IFH.MISC.PIPELINE_PT Bits 49:51: IFH.MISC.PIPELINE_ACT Bits 52: Reserved | 53 | | x | x | x | x | x | | x | X | | L2_MC | Set if frame's destination MAC address is a multicast address (bit 40 = 1). | 1 | | х | х | Х | х | х | | х | x | Table 82 • VCAP IS2 Key Overview (continued) | Field Name | Description | Size | IP4 VID | MAC_ETYPE | ARP | P4_TCP_UDP | P4_OTHER | CUSTOM_2 | IP6_VID | IP_7TUPLE | CUSTOM_1 | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-----------|-----|------------|----------|----------|---------|-----------|----------| | L2_BC | Set if frame's destination MAC address is the broadcast address (FF-FF-FF-FF). | 1 | = | | X | | × | | = | x | | | SERVICE_FRM | Set if classified ISDX > 0. | 1 | | Х | х | Х | Х | Х | | Х | х | | L2_FWD | Set if the frame is allowed to be forwarded to front ports. L2_FWD can for instance be cleared due to MSTP filtering or frame acceptance. | 1 | | х | Х | Х | Х | Х | | Х | х | | VLAN_TAGGED | Set if frame was received with a VLAN tag. | 1 | | Х | Х | Х | Х | Х | | Х | х | | VID | For ISDX = 0 (non-service frames): Classified VID. If ANA_ACL::VCAP_S2_CFG.SEC_ROUTE_HAND LING_ENA is set, VID is IRLEG VID for first lookup and ERLEG VID for second lookup for routable frames (L3_RT=1). For ISDX > 0 (service frames): By default, classified ISDX. When ANA_ACL::VCAP_S2_MISC_CTRL.PAG_FORCE_VID_ENA is set, bit 7 in the PAG controls whether VID or ISDX is used: If PAG[7] = 0: Use classified ISDX. If PAG[7] = 1: Use classified VID. | | X | X | | | | | X | X | x | | DEI | Classified DEI. | 1 | | X | Х | Х | X | X | | Х | Х | | PCP | Classified PCP. | 3 | | Χ | Х | Χ | Χ | Х | | Х | Х | | L3_SMAC_SIP_MATCH | Match found in SIP security lookup in ANA_L3. See IP Source/Destination Guard, page 129. | 1 | X | Х | | Х | Х | Х | Х | Х | X | | L3_DMAC_DIP_MATCH | Match found in DIP security lookup in ANA_L3. See IP Source/Destination Guard, page 129. | 1 | Х | Х | | Х | Х | Х | Х | Х | Х | | L3_RT | Set if frame has hit a router leg. | 1 | Х | Х | | Х | Х | Х | Х | Х | х | | L2_DMAC | Destination MAC address. | 48 | | Х | | | | | | Х | | | L2_SMAC | Source MAC address. | 48 | | Х | Х | | | | | Х | | | ETYPE_LEN | Frame type flag indicating that the frame is EtherType encoded. Set if frame has EtherType >= 0x600. | 1 | | Х | | | | | | | | Table 82 • VCAP IS2 Key Overview (continued) | | | | <b>□</b> | ETYPE | | CP_UDP | THER | OM_2 | UPLE | | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|-------|-----|----------|-----------|--------|--------------------|--------| | Field Name | Description | Size | IP4_VID | MAC | ARP | IP4_TCP_ | IP4_OTHER | CUSTOM | IP_AVID<br>IP_TTUF | CUSTOM | | ETYPE | Frame's EtherType Overloading: OAM Y.1731 frames: ETYPE[6:0] contains OAM MEL flags, see below. OAM_Y1731 is set to 1 to indicate the overloading of ETYPE. | 16 | | Х | | | | | | _ | | | OAM MEL flags: Encoding of MD level/MEG level (MEL). One bit for each level where lowest level encoded as zero. The following keys can be generated: MEL=0: 0b0000000 MEL=1: 0b0000001 MEL=2: 0b0000011 MEL=3: 0b0000111 MEL=3: 0b0001111 MEL=5: 0b0011111 MEL=5: 0b0111111 MEL=6: 0b0111111 Together with the mask, the following kinds of rules may be created: - Exact match. Fx. MEL = 2: 0b0000011 - Below. Fx. MEL< = 4: 0b000XXXX - Above. Fx. MEL> = 5: 0bXX11111 - Between. Fx. 3< = MEL< = 5: 0b000XX111, where 'X' means don't care. | | | | | | | | | | | IP4 | Frame type flag indicating the frame is an IPv4 frame. Set if frame is IPv4 frame (EtherType = 0x800 and IP version = 4) | 1 | | | | Х | x | | х | | | L2_PAYLOAD_ETYPE | Byte 0-7 of L2 payload after Type/Len field. Overloading: OAM Y.1731 frames (OAM_Y1731 = 1): Bytes 0-3: OAM PDU bytes 0-3 Bytes 4-5: OAM_MEPID Bytes 6-7: Unused. | 64 | | Х | | | | | | | | L3_FRAGMENT | Set if IPv4 frame is fragmented (more fragments flag = 1 or fragments offset > 0). | 1 | | | | Х | Х | | | _ | | L3_FRAG_OFS_GT0 | Set if IPv4 frame is fragmented but not the first fragment (fragments offset > 0) | 1 | | | | Х | Х | | | | | ARP_ADDR_SPACE_OK | Set if hardware address is Ethernet. | 1 | | | х | | | | | _ | | ARP_PROTO_SPACE_OK | Set if protocol address space is 0x0800. | 1 | | | Х | | | | | _ | | ARP_LEN_OK | Set if Hardware address length = 6 (Ethernet) and IP address length = 4 (IP). | 1 | | | Х | | | | | | | ARP_TARGET_MATCH | Target Hardware Address = SMAC (RARP). | 1 | - | | Х | | | | | _ | | ARP_SENDER_MATCH | Sender Hardware Address = SMAC (ARP). | 1 | | | Х | | | | | | Table 82 • VCAP IS2 Key Overview (continued) | | | | P4_VID | MAC_ETYPE | ۲. | IP4_TCP_UDP | P4_OTHER | CUSTOM_2 | S_VID | P_7TUPLE<br>CUSTOM_1 | |---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|-----------|-----|-------------|----------|----------|-----------|----------------------| | Field Name | Description | Size | ₫ | È | ARP | <u>4</u> | <u>4</u> | ರ | <u>P6</u> | <u>ਜ਼</u> ਹ | | ARP_OPCODE_UNKNOW N | Set if ARP opcode is none of the below mentioned. | 1 | | | Х | | | | | | | ARP_OPCODE | ARP opcode. Only valid if ARP_OPCODE_UNKNOWN is cleared. 0: ARP request. 1: ARP reply. 2: RARP request. 3: RARP reply. | 2 | | | X | | | | | | | L3_OPTIONS | Set if IPv4 frame contains options (IP len > 5). IP options are not parsed. | 1 | | | | Х | Х | | | | | L3_TTL_GT0 | Set if IPv4 TTL / IPv6 hop limit is greater than 0. | 1 | | | | Х | Х | | | Х | | L3_TOS | Frame's IPv4/6 DSCP and ECN fields. | 8 | | | | Х | Х | | | Х | | L3_IP4_DIP | IPv4 frames: Destination IPv4 address. IPv6 frames: Source IPv6 address, bits 63:32. | 32 | х | | х | Х | Х | | | | | L3_IP4_SIP | IPv4 frames: Source IPv4 address. IPv6 frames: Source IPv6 address, bits 31:0. | 32 | Х | | х | Х | Х | | | | | L3_IP6_DIP | IPv6 frames: Destination IPv6 address. IPv4 frames: Bits 31:0: Destination IPv4 address. | 128 | | | | | | | Х | х | | L3_IP6_SIP | IPv6 frames: Destination IPv6 address. IPv4 frames: Bits 31:0: Destination IPv4 address. In addition, for IP_7TUPLE and IPv4 frames: Bit 127: L3_FRAGMENT. Bit 126: L3_FRAG_OFS_GT0. Bit 125: L3_OPTIONS. | 128 | | | | | | | Х | Х | | DIP_EQ_SIP | Set if destination IP address is equal to source IP address. | 1 | | | х | Х | Х | | | х | | L3_IP_PROTO | IPv4 frames (IP4 = 1): IP protocol.<br>IPv6 frames (IP4 = 0): Next header. | 8 | | | | | х | | | | | TCP_UDP | Frame type flag indicating the frame is a TCP or UDP frame. Set if frame is IPv4/IPv6 TCP or UDP frame (IP protocol/next header equals 6 or 17). | 1 | | | | | | | | х | | TCP | Frame type flag indicating the frame is a TCP frame. Set if frame is IPv4 TCP frame (IP protocol = 6) or IPv6 TCP frames (Next header = 6) | 1 | | | | x | | | | Х | | L4_DPORT | TCP/UDP destination port. Overloading for IP_7TUPLE: Non-TCP/UDP IP frames: L4_DPORT = L3_IP_PROTO. | 16 | | | | x | | | | Х | | L4_SPORT | TCP/UDP source port. | 16 | | | | Х | | | | х | | · · · · · · · · · · · · · · · · · · · | · | | | | | | | | | | Table 82 • VCAP IS2 Key Overview (continued) | Field Name | Description | Size | P4_VID | MAC_ETYPE | • | IP4_TCP_UDP | IP4_OTHER | CUSTOM_2 | P6_VID | CUSTOM_1 | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|-----------|---|--------------|-----------|----------|--------|----------| | L4_RNG | Range mask. Range types: SPORT, DPORT, SPORT or DPORT, VID, DSCP, custom. Input into range checkers is taken from classified results (VID, DSCP) and frame (SPORT, DPORT, custom). | 8 | | | ; | <u></u><br>x | | | × | | | SPORT_EQ_DPORT | Set if TCP/UDP source port equals TCP/UDP destination port. | 1 | | | | X | | | Х | | | SEQUENCE_EQ0 | Set if TCP sequence number is 0. | 1 | | | | X | | | Х | | | L4_FIN | TCP flag FIN. | 1 | | | | X | | | Х | | | L4_SYN | TCP flag SYN. | 1 | | | | X | | | Х | | | L4_RST | TCP flag RST. | 1 | | | | x | | | Х | | | L4_PSH | TCP flag PSH. | 1 | | | | x | | | Х | | | L4_ACK | TCP flag ACK. | 1 | | | | X | | | Х | | | L4_URG | TCP flag URG. | 1 | | | | X | | | Х | | | L3_PAYLOAD | Payload bytes after IP header. IPv4: IPv4 options are not parsed so payload is always taken 20 bytes after the start of the IPv4 header. | 96 | | | | | x | | | | | L4_PAYLOAD | Payload bytes after TCP/UDP header. Overloading for IP_7TUPLE: Non TCP/UDP frames (TCP_UDP = 0): Payload bytes 0 – 7 after IP header. IPv4 options are not parsed so payload is always taken 20 bytes after the start of the IPv4 header for non TCP/UDP IPv4 frames. | 64 | | | ì | X | | | х | | | OAM_CCM_CNTS_EQ0 | Flag indicating if dual-ended loss measurement counters in CCM frames are used. This flag is set if the TxFCf, RxFCb, and TxFCb counters are set to all zeros. | 1 | | Х | | | | | | | | OAM_Y1731 | Set if frame's EtherType = 0x8902. If set, ETYPE is overloaded with OAM MEL flags, See ETYPE. | 1 | | Х | | | | | | | | CUSTOM1 | 57 bytes payload starting from current frame pointer position, as controlled by VCAP CLM actions. Note that if frame_type==ETH, then payload is retrieved from a position following the Ethernet layer, for example, after DMAC, SMAC, 0 – 3 VLAN tags, and EtherType. | 456 | | | | | | | | X | | CUSTOM2 | 24 bytes payload from frame. Location in frame is controlled by VCAP CLM actions. Note that if frame_type==ETH, payload is retrieved from a position following the Ethernet layer, for example, after DMAC, SMAC, 0 – 3 VLAN tags and EtherType. | 192 | | | | | | x | | | ## 3.18.2 VCAP IS2 Actions VCAP IS2 supports only one action, size 196 bits, which applies to all VCAP IS2 keys. The action is listed in the following table. When programming an action in VCAP IS2, the associated action fields listed must be programmed in the listed order with the first field in the table starting at bit 0 in the action. Table 83 • VCAP IS2 Actions | Action Name | Description | Size | |--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | IS_INNER_ACL | Set if VCAP IS2 action belongs to ANA_IN_SW pipeline point. | 1 | | PIPELINE_FORCE<br>_ENA | If set, use PIPELINE_PT unconditionally and set PIPELINE_ACT = NONE if PIPELINE_PT == NONE. Overrules previous settings of pipeline point. | 1 | | PIPELINE_PT | Pipeline point used if PIPELINE_FORCE_ENA is set: 0: NONE 1: ANA_VRAP 2: ANA_PORT_VOE 3: ANA_CL 4: ANA_CLM 5: ANA_IPT_PROT 6: ANA_OU_MIP 7: ANA_OU_SW 8: ANA_OU_PROT 9: ANA_OU_VOE 10: ANA_MID_PROT 11: ANA_IN_VOE 12: ANA_IN_PROT 13: ANA_IN_SW 14: ANA_IN_SW 15: ANA_VLAN 16: ANA_DONE | 5 | | HIT_ME_ONCE | If set, the next frame hitting the rule is copied to CPU using CPU_QU_NUM. CPU_COPY_ENA overrules HIT_ME_ONCE implying that if CPU_COPY_ENA is also set, all frames hitting the rule are copied to the CPU. | 1 | | INTR_ENA | If set, an interrupt is triggered when this rule is hit | 1 | | CPU_COPY_ENA | If set, frame is copied to CPU using CPU_QU_NUM. | 1 | | CPU_QU_NUM | CPU queue number used when copying to the CPU | 3 | | CPU_DIS | If set, disable extraction to CPU queues from previous forwarding decisions. Action CPU_COPY_ENA is applied after CPU_DIS. | 1 | | LRN_DIS | If set, autolearning is disallowed. | 1 | | RT_DIS | If set, routing is disallowed. | 1 | | POLICE_ENA | If set, frame is policed by policer pointed to by POLICE_IDX. Overloading: If cleared, POLICE_IDX can be used to select a new source IP address from table ANA_ACL::SWAP_SIP when replacing IP addresses. See ACL_RT_MODE. | 1 | | POLICE_IDX | Selects policer index used when policing frames. Overloading: If POLICE_ENA=0, selects source IP address when replacing IP addresses. | 5 | | IGNORE_PIPELIN<br>E_CTRL | Ignore ingress pipeline control. This enforces the use of the VCAP IS2 action even when the pipeline control has terminated the frame before VCAP IS2. | 1 | Table 83 • VCAP IS2 Actions (continued) | Action Name | Description | Size | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | LOG_MSG_INT | Controls logMessageInterval when REW_CMD[5] = 1: For multicast Delay_Resp frames, SWAP_MAC_ENA and LOG_MSG_INT encode a new logMessageInterval: SWAP_MAC_ENA=0, LOG_MSG_INT=0: logMessageInterval = 0 SWAP_MAC_ENA=0, LOG_MSG_INT=1: logMessageInterval = 1 SWAP_MAC_ENA=0, LOG_MSG_INT=7: logMessageInterval = 7 SWAP_MAC_ENA=1, LOG_MSG_INT=0: logMessageInterval = -8 SWAP_MAC_ENA=1, LOG_MSG_INT=1: logMessageInterval = -7 SWAP_MAC_ENA=1, LOG_MSG_INT=7: logMessageInterval = -1 | 3 | | MASK_MODE | Controls how PORT_MASK is applied. 0: OR_DSTMASK: Or PORT_MASK with destination mask. 1: AND_VLANMASK: And PORT_MASK with VLAN mask. 2: REPLACE_PGID: Replace PGID port mask from MAC table lookup by PORT_MASK. 3: REPLACE_ALL: Use PORT_MASK as final destination set replacing all other port masks. Note that with REPLACE_ALL, the port mask becomes sticky and cannot be modified by later processing steps. 4: REDIR_PGID: Redirect using PORT_MASK[7:0] as PGID table index. See PORT_MASK for extra configuration options. options. Note that the port mask becomes sticky and cannot be modified by subsequent processing steps. 5: OR_PGID_MASK: Or PORT_MASK with PGID port mask from MAC table lookup. 6: Reserved. 7: Reserved. The CPU port is untouched by MASK_MODE. | 3 | | PORT_MASK | Port mask applied to the forwarding decision. MASK_MODE=4: PORT_MASK[52]: SRC_PORT_MASK_ENA. If set, SRC_PORT_MASK is AND'ed with destination result. PORT_MASK[51]: AGGR_PORT_MASK_ENA. If set, AGGR_PORT_MASK is AND'ed with destination result. MASK_MODE=4: PORT_MASK[50]: VLAN_PORT_MASK_ENA. If set, VLAN_PORT_MASK is AND'ed with destination result. PORT_MASK[7:0]: PGID table index. | 55 | | MIRROR_PROBE | Mirroring performed according to configuration of a mirror probe. 0: No mirroring. 1: Mirror probe 0. 2: Mirror probe 1. 3: Mirror probe 2. | 2 | Table 83 • VCAP IS2 Actions (continued) | Action Name | Description | Size | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | REW_CMD | REW_CMD[1:0] - PTP command: 0: No command. 1: ONE-STEP update. Update PTP PDU according to ingress and egress port mode. 2: TWO-STEP stamping. Send frame untouched, but store ingress and egress time stamps in the time stamp FIFO. 3: TIME-OF-DAY update. Fill system time-of-day into frame. | 8 | | | REW_CMD[3:2] - Delay command: 0: No command. 1: Add configured egress delay for the egress port (REW::PTP_EDLY_CFG). 2: Add configured ingress delay for the ingress port (REW::PTP_IDLY1_CFG). 3: Add configured ingress delay for the ingress port (REW::PTP_IDLY2_CFG). | | | | REW_CMD[5:4] - Sequence number and time stamp command: 0: No command. 1: Fill in sequence number and increment. Sequence number is selected by IFH.TSTAMP. 2: Enable Delay_Req/resp processing. This mode includes updating the requestReceiptTimestamp with the ingress time stamp. 3: Enable Delay_Req/resp processing. This mode excludes updating the requestReceiptTimestamp. | | | | Note that if REW_CMD[5] is set, REW_CMD[5:4] is cleared by ANA_ACL before passing the REW_CMD action to the rewriter. REW_CMD[6]: If set, set DMAC to incoming frame's SMAC. | | | | REW_CMD[7]: If set, set SMAC to configured value for the egress port. | | | TTL_UPDATE_ENA | A If set, IPv4 TTL or IPv6 hop limit is decremented. Overloading: If ACL_RT_MODE[3]=1 (SWAPPING) and ACL_RT_MODE[2:0]=4, 5, 6, or 7, the IPv4 TTL or IPv6 hop limit is preset to value configured in ANA_ACL::SWAP_IP_CTRL. | 1 | | SAM_SEQ_ENA | If set, ACL_RT_MODE only applies to frames classified as SAM_SEQ. Overloading: If ACL_RT_MODE=0x8 (replace DMAC): If set, ANA_ACL::SWAP_IP_CTRL.DMAC_REPL_OFFSET_VAL controls number of bits in frame's DMAC, counting from MSB, to replace with corresponding bits in ACL_MAC. | 1 | | TCP_UDP_ENA | If set, TCP/UDP ports are set to new values: DPORT = MATCH_ID, SPORT = MATCH_ID_MASK. | 1 | | MATCH_ID | Logical ID for the entry. The MATCH_ID is extracted together with the frame if the frame is forwarded to the CPU (CPU_COPY_ENA). The result is placed in IFH.CL_RSLT. Overloading: If TCP_UDP_ENA is set, MATCH_ID defines new DPORT. | 16 | | MATCH_ID_MASK | Mask used by MATCH_ID. Overloading: If TCP_UDP_ENA is set, MATCH_ID defines new SPORT. | 16 | | CNT_ID | Counter ID, used per lookup to index the 4K frame counters (ANA_ACL:CNT_TBL). Multiple VCAP IS2 entries can use the same counter. | 12 | | SWAP_MAC_ENA | Swap MAC addresses. Overloading: If REW_CMD[5]=1: For multicast Delay_Resp frames, SWAP_MAC_ENA and LOG_MSG_INT encodes a new logMessageInterval. See LOG_MSG_INT. | 1 | Table 83 • VCAP IS2 Actions (continued) | Action Name | Description | Size | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | ACL_RT_MODE | Controls routing updates in ANA_AC and how ACL_MAC is applied: 0: No change. ACL_RT_MODE[3] = 0 (ROUTING mode): ACL_RT_MODE[0] = 1: Enable Unicast routing updates in ANA_AC ACL_RT_MODE[1] = 1: Enable Multicast routing updates in ANA_AC ACL_RT_MODE[2] = 1: Enable overloading of ACL_MAC field. ACL_RT_MODE[3] = 1 (SWAPPING mode): ACL_RT_MODE[2:0] encodes a SWAPPING sub-mode: 0: Replace DMAC. 1: Replace SMAC. 2: Swap MAC addresses. Replace SMAC if new SMAC is multicast. 3: Swap MAC addresses if DMAC is unicast. Replace SMAC if DMAC is multicast. 4: Swap MAC addresses. Replace SMAC if new SMAC is multicast. Swap IP addresses. Replace SIP if new SIP is multicast. 5: Swap MAC addresses if DMAC is unicast. Replace SMAC if DMAC is multicast. Swap IP addresses if DIP is unicast. Replace SIP if DIP is multicast. 6: Swap IP addresses. Replace SIP if new SIP is multicast. 7: Replace SMAC. Swap IP addresses. Replace SIP if new SIP is multicast. Note that when replacing a MAC address, the new MAC address is taken from ACL_MAC. When replacing a SIP, the new SIP is taken from ANA_ACL::SWAP_SIP[POLICE_IDX]. | 4 | | ACL_MAC | MAC address used to replace either SMAC or DMAC based on ACL_RT_MODE. Overloading: ACL_RT_MODE[3:2] = 1. ACL_MAC[0]: PORT_PT_CTRL_ENA - Overrule PORT_PT_CTRL. ACL_MAC[6:1]: PORT_PT_CTRL_IDX - into ANA_AC_POL:PORT_PT_CTRL. ACL_MAC[16]: Enable use of ACL_MAC[26:17] as DLB policer index. ACL_MAC[26:17]: DLB policer index. ACL_RT_MODE(3) = 1: MAC address used to replace either SMAC or DMAC based on ACL_RT_MODE. | 48 | | PTP_DOM_SEL | PTP domain selector. PTP_DOM_SEL indexes the PTP configuration in ANA_ACL:PTP_DOM used in Delay_Resp frames. See REW_CMD. | 2 | ## 3.19 Analyzer Access Control Lists The analyzer access control list (ANA\_ACL) block performs the following tasks. - Controls the VCAP IS2 lookups in terms of key selection, evaluation of range checkers, and control of specific VCAP IS2 key fields such as IGR PORT MASK SEL and VID. - Generates VCAP IS2 keys and execute the two lookups. - Updates VCAP IS2 statistics based on match results. - Assigns actions from VCAP IS2 matching or default actions when there is no match. - Controls routing-related frame rewrites. The following sections provides specific information about each of these tasks. ## 3.19.1 VCAP IS2 Each frame is classified to one of nine overall VCAP IS2 frame types. The frame type determines which VCAP IS2 key types are applicable and controls which frame data to extract. Table 84 • VCAP IS2 Frame Types | Frame Type | Condition | |----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IPv6 multicast frame | The Type/Len field is equal to 0x86DD. The IP version is 6. The destination IP address is a multicast address (FF00::/8). Special IPv6 frames: •IPv6 TCP frame: Next header is TCP (0x6). •IPv6 UDP frame: Next header is UDP (0x11). •IPv6 Other frame: Next header is neither TCP nor UDP. | | IPv6 unicast frame | The Type/Len field is equal to 0x86DD. The IP version is 6. The destination IP address is not a multicast address. Special IPv6 frames: •IPv6 TCP frame: Next header is TCP (0x6). •IPv6 UDP frame: Next header is UDP (0x11). •IPv6 Other frame: Next header is neither TCP nor UDP | | IPv4 multicast frame | The Type/Len field is equal to 0x800. The IP version is 4. The destination IP address is a multicast address (224.0.0.0/4). Special IPv4 frames: •IPv4 TCP frame: IP protocol is TCP (0x6). •IPv4 UDP frame: IP protocol is UDP (0x11). •IPv4 Other frame: IP protocol is neither TCP nor UDP. | | IPv4 unicast frame | The Type/Len field is equal to 0x800. The IP version is 4. The destination IP address is not a multicast address. Special IPv4 frames: •IPv4 TCP frame: IP protocol is TCP (0x6). •IPv4 UDP frame: IP protocol is UDP (0x11). •IPv4 Other frame: IP protocol is neither TCP nor UDP. | | (R)ARP frame | The Type/Len field is equal to 0x0806 (ARP) or 0x8035 (RARP). | | OAM Y.1731 frame | The Type/Len field is equal to 0x8902 (ITU-T Y.1731). | | SNAP frame | The Type/Len field is less than 0x600. The Destination Service Access Point field, DSAP is equal to 0xAA. The Source Service Access Point field, SSAP is equal to 0xAA. The Control field is equal to 0x3. | | LLC frame | The Type/Len field is less than 0x600 The LLC header does not indicate a SNAP frame. | | ETYPE frame | The Type/Len field is greater than or equal to 0x600, and the Type field does not indicate any of the previously mentioned frame types, that is, ARP, RARP, OAM, IPv4, or IPv6. | Some protocols of interest do not have their own frame type but are included in other mentioned frame types. For instance, Precision Time Protocol (PTP) frames are handled by VCAP IS2 as either ETYPE frames, IPv4 frames, or IPv6 frames. The following encapsulations of PTP frames are supported: - PTP over Ethernet: ETYPE frame with Type/Len = 0x88F7. - PTP over UDP over IPv4: IPv4 UDP frame with UDP destination port numbers 319 or 320. - PTP over UDP over IPv6: IPv6 UDP frame with UDP destination port numbers 319 or 320. Specific PTP fields are contained in eight bytes of payload extracted after either the EtherType for PTP over Ethernet or in eight bytes of payload after the UDP header for IPv4/IPv6 frames. ### 3.19.1.1 Port Configuration and Key Selection This section provides information about special port configurations that control the key generation for VCAP IS2. The following table lists the registers associated with port configuration for VCAP IS2. Table 85 • Port Configuration of VCAP IS2 | Register | Description | Replication | |------------------------------|-----------------------------------------------------|---------------------| | ANA_ACL:PORT:VCAP_S2_KEY_SEL | Configuration of the key selection for the VCAP IS2 | Per port per lookup | | ANA_ACL::VCAP_S2_CFG | Enabling of VCAP IS2 lookups. | Per port per lookup | Each of the two lookups in VCAP IS2 must be enabled before use (VCAP\_S2\_CFG.SEC\_ENA) for a key to be generated and a match to be used. If a lookup is disabled on a port, frames received by the port are not matched against rules in VCAP IS2 for that lookup. Each port controls the key selection for each of the two lookups in VCAP IS2 through the VCAP\_S2\_KEY\_SEL register. For some frame type (OAM Y.1731, SNAP, LLC, EYTYPE) the key selection is given as only the MAC\_ETYPE key can be used. For others frame types (ARP and IP) multiple keys can be selected from. The following table lists the applicable key types available for each frame type listed in Table 84, page 156. Table 86 • VCAP IS2 Key Selection | Frame Type | Applicable VCAP IS2 keys | |-----------------------|---------------------------------------------------| | IPv6 multicast frames | IP6_VID IP_7TUPLE MAC_ETYPE | | IPv6 unicast frames | IP_7TUPLE<br>MAC_ETYPE | | IPv4 multicast frames | IP4_VID IP_7TUPLE IP4_TCP_UDP IP4_OTHER MAC_ETYPE | | IPv4 unicast frames | IP_7TUPLE IP4_TCP_UDP IP4_OTHER MAC_ETYPE | | (R)ARP frames | ARP<br>MAC_ETYPE | | OAM Y.1731 frames | MAC_ETYPE | | SNAP frames | MAC_ETYPE | | LLC frames | MAC_ETYPE | | ETYPE frames | MAC_ETYPE | **Note:** The key selection is overruled if VCAP CLM instructs the use of a custom key, where data from the frame is extracted at a VCAP CLM-selected point. For more information, see VCAP IS2 Custom Keys, page 158. For information about VCAP IS2 keys and actions, see VCAP IS2 Keys and Actions, page 145. ### 3.19.1.2 VCAP IS2 Custom Keys VCAP IS2 supports two custom keys, CUSTOM\_1 and CUSTOM\_2. Custom keys extract raw data from the frame at one selectable location. The custom keys enable matching against protocol fields not supported by other VCAP IS2 keys. The use of the custom keys must be enabled through a VCAP CLM FULL action using CUSTOM\_ACE\_ENA and CUSTOM\_ACE\_OFFSET. CUSTOM\_1 extracts 57 consecutive bytes of data from the frame and CUSTOM\_2 extracts 24 consecutive bytes of data from the frame. The data is extracted at one of four different positions in the frame. For frames of frame\_type ETH (IFH.TYPE\_AFTER\_POP), the positions are defined as: - · Link layer. Corresponds to first byte in DMAC. - Link layer payload. Corresponds to first byte in L3, after VLAN tags and EtherType. - Link layer payload plus 20 bytes. Corresponds to first byte in L4 for IPv4 frame. - Link layer payload plus 40 bytes. Corresponds to first byte in L4 for IPv6 frame. For frames of frame type CW, the first link layer position is not available. The positions are defined as: - Link layer payload. Corresponds to first byte in control word for non-IP frames and first byte in IP header for IP frames. - Link layer payload plus 20 bytes. Corresponds to first byte in L4 for IPv4 frame. - Link layer payload plus 40 bytes. Corresponds to first byte in L4 for IPv6 frame. #### 3.19.1.3 VCAP IS2 Range Checkers The following table lists the registers associated with configuring VCAP IS2 range checkers. Table 87 • VCAP IS2 Range Checker Configuration | Register | Description | Replication | |---------------------------------|---------------------------------------------------------------------------------|-------------------| | ANA_ACL::VCAP_S2_RNG_CTRL | Configuration of the range checker types | Per range checker | | ANA_ACL::VCAP_S2_RNG_VALUE_CFG | Configuration of range start and end points | Per range checker | | ANA_ACL::VCAP_S2_RNG_OFFSET_CFG | Offset into frame when using a range checker based on selected value from frame | None | Eight global VCAP IS2 range checkers are supported by the IP4\_TCP\_UDP and IP\_7TUPLE keys. All frames using these keys are compared against the range checkers and a 1-bit range "match/no match" flag is returned for each range checker. The combined eight match/no match flags are used in the L4\_RNG key field. So, it is possible to include for example ranges of DSCP values and/or ranges of TCP source port numbers in the ACLs. Note, VCAP CLM also supports range checkers but they are independent of the VCAP IS2 range checkers. The range key is generated for each frame based on extracted frame data and the configuration in ANA\_ACL::VCAP\_S2\_RNG\_CTRL. Each of the eight range checkers can be configured to one of the following range types: - TCP/UDP destination port range Input to the range is the frame's TCP/UDP destination port number. Range is only applicable to TCP/UDP frames. - TCP/UDP source port range - Input to the range is the frame's TCP/UDP source port number. - Range is only applicable to TCP/UDP frames. - TCP/UDP source and destination ports range. Range is matched if either source or destination port is within range. - Input to the range are the frame's TCP/UDP source and destination port numbers. - Range is only applicable to TCP/UDP frames. - · VID range - Input to the range is the classified VID. - Range is applicable to all frames. - DSCP range Input to the range is the classified DSCP value. Range is applicable to IPv4 and IPv6 frames. - Selected frame field range Input to the range is a selected 16-bit wide field from the frame. The field is selected using the offset value configured in ANA\_ACL::VCAP\_S2\_RNG\_OFFSET\_CFG. The offset starts at the Type/Len field in the frame after up to 3 VLAN tags have been skipped. Note that only one selected value can be configured for all eight range checkers. Range is applicable to all frames. Range start points and range end points are configured in ANA\_ACL::VCAP\_S2\_RNG\_VALUE\_CFG with both the start point and the end point being included in the range. A range matches if the input value to the range (for instance the frame's TCP/UDP destination port) is within the range defined by the start point and the end point. ### 3.19.1.4 Miscellaneous VCAP IS2 Key Configurations The following table lists the registers associated with configuration that control the specific fields in the VCAP IS2 keys. Table 88 • Other VCAP IS2 Key Configurations | Register | Description | Replication | |----------------------------------------------|-------------------------------------------------------------------|-------------| | ANA_ACL::VCAP_S2_CFG.SEC_ROUTE_HA NDLING_ENA | Enables use of IRLEG VID and ERLEG VID instead of classified VID. | Per port | | ANA_ACL:VCAP_S2:VCAP_S2_MISC_CTRL | Configuration of IGR_PORT_MASK_SEL and IGR_PORT_MASK. | None | By default, the field VID contains the frame's classified VID for both VCAP IS2 lookups. Routable frames (determined by ANA\_L3) with field L3\_RT=1, can be configured (ANA\_ACL::VCAP\_S2\_CFG.SEC\_ROUTE\_HANDLING\_ENA) to use the IRLEG VID for the first lookup in VCAP IS2 and ERLEG VID for the second lookup. This enables ACL rules that apply to the ingress router leg and ACL rules that apply to the egress router leg. The IRLEG VID and ERLEG VID are provided by ANA L3. All VCAP IS2 keys except IP4\_VID and IP6\_VID contain the field IGR\_PORT\_MASK\_SEL and IGR\_PORT\_MASK. For frames received on a front port, IGR\_PORT\_MASK\_SEL is set to 0 and the bit corresponding to the frame's physical ingress port number is set in IGR\_PORT\_MASK. The following lists some settings for frames received on other interfaces and how this can be configured through register VCAP\_S2\_MISC\_CTRL: - Loopback frames. By default, IGR\_PORT\_MASK\_SEL = 1 and IGR\_PORT\_MASK has one bit set corresponding to the physical port which the frame was looped on. Optionally use IGR\_PORT\_MASK\_SEL = 3. - Masqueraded frames. By default, IGR\_PORT\_MASK\_SEL=0 and IGR\_PORT\_MASK has one bit set corresponding to the masquerade port. Optionally, use IGR\_PORT\_MASK\_SEL = 2. - Virtual device frames. By default, IGR\_PORT\_MASK\_SEL=0 and IGR\_PORT\_MASK has one bit set corresponding to the original physical ingress port. Optionally use IGR\_PORT\_MASK\_SEL = 3. - **CPU injected frames.** By default, IGR\_PORT\_MASK\_SEL = 0 and IGR\_PORT\_MASK has none bits set. Optionally use IGR\_PORT\_MASK\_SEL = 3. For more information about the contents of IGR\_PORT\_MASK\_SEL and IGR\_PORT\_MASK, see VCAP IS2 Key Overview, page 146. ## 3.19.1.5 Processing of VCAP IS2 Actions VCAP IS2 returns an action for each enabled VCAP IS2 lookup. If the lookup matches an entry in VCAP IS2 then the associated action is returned. A default action is returned when no entries are matched. The first VCAP IS2 lookup returns a default action per physical ingress port while the second VCAP IS2 lookup returns a common default action. There is no difference between an action from a match and a default action. VCAP IS2 contains 58 default actions that are allocated the following way: - 0-52: Per ingress port default actions for first lookup. - 53, 54: Per CPU port (CPU0 and CPU1) default actions for first lookup. - 55, 56: Per virtual device (VD0 and VD1) default actions for first lookup. - 57: Common default action for second lookup. Each of the two VCAP IS2 actions (from first and second lookups) can be processed either at the pipeline point ANA\_OU\_SW or at pipeline point ANA\_IN\_SW. This is controlled by VCAP IS2 action IS INNER ACL. The order of processing is given as: - 1. Process first action if the first's action IS INNER ACL is 0. - 2. Process second action if the second's action IS INNER ACL is 0. - 3. Process first action if the first's action IS\_INNER\_ACL is 1. - 4. Process second action if the second's action IS INNER ACL is 1. This implies that the second action can be processed in ANA\_OU\_SW pipeline point and the first action can be processed in ANA\_IN\_SW pipeline point, or vice versa. Both actions can also be placed at the same pipeline point in which case the first action is processed before the second. Processing of each action obeys the frame's current pipeline information (pipeline point and pipeline action). For instance if the frame has been redirected at pipeline point ANA\_CLM then neither of the VCAP IS2 actions are applied. However, VCAP IS2 action IGNORE\_PIPELINE\_CTRL can overrule this. Furthermore, frame processing between pipeline points ANA\_OU\_SW and ANA\_IN\_SW such as OAM filtering or protection switching can influence the processing of the VCAP IS2 actions so that only an action belonging to pipeline point ANA\_OU\_SW is processed. The following table lists how the two VCAP IS2 action are combined when both VCAP IS2 actions are processed. For most cases, the processing is sequential, meaning that if both actions have settings for the same (for instance MIRROR\_PROBE), the second processing takes precedence. Others are sticky meaning they cannot be undone by the second processing if already set by the first. Table 89 • Combining VCAP IS2 Actions | Action name | Combining actions | |----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IS_INNER_ACL | Processed individually for each action. | | PIPELINE_FORCE_ENA | Processed individually for each action. Second processing uses the result from the first processing which can prevent its processing if the pipeline information from first processing disables the second processing. | | PIPELINE_PT | See PIPELINE_FORCE_ENA. | | HIT_ME_ONCE | Sticky. | | INTR_ENA | Sticky. | | CPU_COPY_ENA | Sticky. | | CPU_QU_NUM | Sticky (each action can generate a CPU copy and based on configuration in ANA_AC:PS_COMMON:CPU_CFG.ONE_CPU_COPY_ONLY_MASK, both copies can be sent to CPU). | | CPU_DIS | Processed individually for each action. Second processing may clear CPU copy from first processing. | | LRN_DIS | Sticky. | | RT_DIS | Sticky. | | POLICE_ENA | Sticky. | | POLICE_IDX | Second action takes precedence when POLICE_ENA is set. | | IGNORE_PIPELINE_CTRL | Processed individually for each action. | | LOG_MSG_INT | Second action takes precedence when LOG_MSG_INT > 0. | Table 89 • Combining VCAP IS2 Actions (continued) | Action name | Combining actions | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MASK_MODE | Processed individually for each action. Second processing uses the result from the first processing. (If the first processing is sticky, the second processing is not applied). MASK_MODE is sticky for the following values: 3: REPLACE_ALL 4: REDIR_PGID 6: VSTAX | | PORT_MASK | See MASK_MODE. | | MIRROR_PROBE | Second action takes precedence when MIRROR_PROBE > 0. | | REW_CMD | Second action takes precedence same functions are triggered by both actions. If different functions are used, both are applied. | | TTL_UPDATE_ENA | Second action takes precedence when same function is triggered by both actions. If different functions are used, both are applied. | | TCP_UDP_ENA | Second action takes precedence when TCP_UDP_ENA is set. | | MATCH_ID | Processed individually for each action. Second processing uses the result from the first processing. | | MATCH_ID_MASK | Processed individually for each action. Second processing uses the result from the first processing. | | CNT_ID | Processed individually for each action. Two counters are updated, one for each action. | | SWAP_MAC_ENA | Sticky. | | ACL_RT_MODE | Second action takes precedence when same function is triggered by both actions. If different functions are used, both are applied. | | ACL_MAC | Second action takes precedence when same function is triggered by both actions. If different functions are used, both are applied. | | PTP_DOM_SEL | Second action takes precedence when PTP_DOM_SEL > 0. | ### 3.19.1.6 VCAP IS2 Statistics and Diagnostics The following table lists the registers associated with VCAP IS2 statistics and diagnostics. Table 90 • VCAP IS2 Statistics and Diagnostics | Register | Description | Replication | |----------------------------|---------------------------------------------------------------|-------------| | ANA_ACL::SEC_LOOKUP_STICKY | Sticky bits for each key type used in VCAP IS2. | Per lookup | | ANA_ACL::CNT | VCAP IS2 match counters. Indexed with VCAP IS2 action CNT_ID. | 1,024 | Each key type use in a lookup in VCAP IS2 triggers a sticky bit being set in ANA ACL::SEC LOOKUP STICKY. A sticky bit is cleared by writing. Each action returned by VCAP IS2 triggers one of 1,024 counters (ANA\_ACL::CNT) to be incremented. This applies to both actions from matches and default actions. The index into the counters is provided by VCAP IS2 action CNT\_ID. The CNT\_ID is fully flexible meaning multiple actions can point to the same counter. The counters are writable so they can be preset to any value. A counter is cleared by writing 0. ## 3.19.1.7 Routing Statistics If a routed frame is discarded by a VCAP IS2 rule it is configurable how the frame is counted in terms of ingress and egress router leg statistics. If the frame is discarded by the first VCAP IS2 lookup, it is selectable whether to count the frame in the ingress router leg statistics (ANA\_ACL::VCAP\_S2\_MISC\_CTRL.ACL\_RT\_IGR\_RLEG\_STAT\_MODE). The frame is never counted by the egress router leg statistics. If the frame is discarded by the second VCAP IS2 lookup, it is selectable whether to count the frame in the egress router leg statistics (ANA\_ACL::VCAP\_S2\_MISC\_CTRL.ACL\_RT\_EGR\_RLEG\_STAT\_MODE). The frame is always counted by the ingress router leg statistics. ## 3.19.2 Analyzer Access Control List Frame Rewriting The ANA\_ACL block supports various frame rewrite functions used in routing and PTP. When rewriting in the ANA\_ACL block, ingress mirroring with an exact mirror copy of the incoming frame is no longer possible, because any rewrites are also reflected in the mirror copy. ## 3.19.2.1 Address Swapping and Rewriting VCAP IS2 actions can trigger frame rewrites in the ANA\_ACL block with focus on MAC addresses, IP addresses, TCP/UDP ports as well as IPv4 TTL and IPv6 hop limit. The following table lists the registers associated with address swapping and rewriting capabilities in ANA ACL. Table 91 • ANA\_ACL Address Swapping and Rewriting Registers | Register | Description | Replication | |-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | ANA_ACL::SWAP_SIP | IP table with 32 IPv4 addresses or 8 IPv6 addresses. Provides new source IP address when swapping IP addresses in frame with multicast destination IP address. | 32 | | ANA_ACL::SWAP_IP_CTRL | Controls IPv4 TTL and IPv6 hop limit values. Controls number of bits to replace in DMAC. | None | VCAP IS2 action ACL RT MODE can enable the following rewrite modes: - Replace DMAC. The frame's DMAC is replaced with the MAC address specified in VCAP IS2 action ACL\_MAC. It is selectable to only replace part of the DMAC (for instance the OUI only). This is enabled with VCAP IS2 action REW\_CMD[9], and the number of bits to replace is set in ANA ACL::SWAP IP CTRL.DMAC REPL OFFSET VAL. - Replace SMAC. The frame's SMAC is replaced with the MAC address specificed in VCAP IS2 action ACL MAC. - Swap MAC addresses and replace SMAC if MC. The frame's MAC addresses are swapped. If the new SMAC is a multicast MAC, it is replaced with the MAC address specificed in VCAP IS2 action ACL MAC. - Swap MAC addresses if UC else replace SMAC if MC. The frame's MAC addresses are swapped if the frame's DMAC is unicast. Otherwise, the frame's SMAC is replaced with the MAC address specificed in VCAP IS2 action ACL MAC. - Swap MAC and IP addresses and replace SIP and SMAC if MC. The frame's MAC addresses are swapped and the frame's IP addresses are swapped. If the new SMAC is a multicast MAC, it is replaced with the MAC address specificed in VCAP IS2 action ACL\_MAC. If the new SIP is a multicast, it is replaced with an IP address from the IP address table ANA ACL::SWAP SIP. - Swap MAC and IP addresses if UC else replace SIP and SMAC if MC. The frame's MAC addresses are swapped if the frame's DMAC is unicast. Otherwise, the frame's SMAC is replaced with the MAC address specificed in VCAP IS2 action ACL\_MAC. The frame's IP addresses are swapped if the frame's DIP is unicast. Otherwise, the frame's SIP is replaced with an IP address from the IP address table ANA\_ACL::SWAP\_SIP. - Swap IP addresses and replace SIP if MC. The frame's IP addresses are swapped. If the new SIP is a multicast, it is replaced with an IP address from the IP address table ANA ACL::SWAP SIP. - Replace SMAC, swap IP addresses, and replace SIP if MC. The frame's SMAC is replaced with the MAC address specificed in VCAP IS2 action ACL MAC. The frame's IP addresses are swapped. If the new SIP is a multicast, it is replaced with an IP address from the IP address table ANA ACL::SWAP SIP. The IP address table (ANA\_ACL::SWAP\_SIP) used by some of the above mentioned modes is indexed using VCAP IS2 action POLICE\_IDX (VCAP IS2 action POLICE\_ENA must be 0). The IP address table can contain 32 IPv4 addresses or 8 IPv6 addresses. When swapping IP addresses or replacing the source IP address, it is also possible to preset the IPv4 TTL or the IPv6 hop limit. This is enabled by VCAP IS2 action TTL\_UPDATE\_ENA. The new TTL value for IPv4 frames is configured in ANA\_ACL::SWAP\_IP\_CTRL.IP\_SWAP\_IP4\_TTL\_VAL and the new hop limit value for IPv6 frames is configured in ANA\_ACL::SWAP\_IP\_CTRL.IP\_SWAP\_IP4\_TTL\_VAL. IPv4 and IPv6 TCP/UDP frames have the option to replace the source and destination port numbers with new values. This is enabled through VCAP IS2 action TCP\_UDP\_ENA and new port numbers are provided by VCAP IS2 action MATCH ID and MATCH ID MASK. The IPv4 header checksum is updated whenever required by above mentioned frame rewrites. The UDP checksum is updated whenever required for IPv6 frames and cleared for IPv4 frames. ## 3.19.2.2 Routing in ANA\_ACL The following table lists the registers associated with routing capabilities in ANA ACL. Table 92 • ANA\_ACL Routing Registers | Register | Description | Replication | |----------------------------------------------------------------|-----------------------------------------------------|-------------| | ANA_ACL::VCAP_S2_MISC_CTRL.ACL_RT_SEL | Enable routing related frame rewrites in ANA_ACL | None | | ANA_ACL::VCAP_S2_MISC_CTRL.ACL_RT_UPDATE_<br>GEN_IDX_ERLEG_ENA | Enable use of egress router leg as VSI in rewriter. | None | | ANA_ACL::VCAP_S2_MISC_CTRL.ACL_RT_UPDATE_<br>GEN_IDX_EVID_ENA | Enable use of egress VID as VSI in rewriter. | None | If PTP and routing is to be supported concurrently, then some routing related frame rewrites must be done in ANA ACL instead of in the rewriter. This is enabled in ANA\_ACL::VCAP\_S2\_MISC\_CTRL.ACL\_RT\_SEL or by setting VCAP IS2 action ACL\_RT\_MODE. When enabled, the frame's DMAC is changed to the next-hop MAC address specificed by ANA\_L3 and the rewriter is informed not to rewrite the DMAC. The following classification results used by the rewriter are changed when routing in ANA ACL: - The frame's classified VID is set to the egress VID. - The frame's classified VSI is optionally set to the egress router leg (ANA\_ACL::VCAP\_S2\_MISC\_CTRL.ACL\_RT\_UPDATE\_GEN\_IDX\_ERLEG\_ENA) or the egress VID (ANA ACL::VCAP S2 MISC CTRL.ACL RT UPDATE GEN IDX EVID ENA) In addition, ANA\_L3 must be setup to change the source MAC address with the address belonging to the egress router leg (ANA\_L3::ROUTING\_CFG.RT\_SMAC\_UPDATE\_ENA). The IPv4 TTL or IPv6 hop limit is still decremented by the rewriter. ## 3.19.2.3 PTP Delay Reg/Resp Processing VCAP IS2 actions can trigger PTP Delay\_Req/resp processing where an incoming Delay\_Req frame is terminated and a Delay\_Resp frame is generated with appropriate PTP updates. The following table lists the registers associated with PTP processing and rewriting capabilities in ANA ACL. Table 93 • ANA\_ACL PTP Processing and Rewriting Registers | Register | Description | Replication | |----------------------|--------------------------------------------------------------------------------------|-------------| | ANA_ACL:PORT:PTP_CFG | PTP time domain configuration and PTP portNumber configuration used in portIdentity. | Per port | Table 93 • ANA ACL PTP Processing and Rewriting Registers (continued) | Register | Description | Replication | |----------------------------------|----------------------------------------------------------------------------------------------------------------|----------------| | ANA_ACL::PTP_MISC_CTRL | Enable Delay_Req/resp processing. Enable logMessageInterval update for multicast Delay_Resp frames. | None | | ANA_ACL:PTP_DOM:PTP_CLOCK_ID_MSB | PTP clockIdentity used in portIdentity. | Per PTP domain | | ANA_ACL:PTP_DOM:PTP_CLOCK_ID_LSB | PTP clockIdentity used in portIdentity. | Per PTP domain | | ANA_ACL:PTP_DOM:PTP_SRC_PORT_CFG | PTP portNumber used in portIdentity. Configuration of whether to use fixed portNumber or per-port portNumber. | Per PTP domain | | ANA_ACL:PTP_DOM:PTP_MISC_CFG | Configuration of flagField with associated mask. The PTP domain is specified with VCAP IS2 action PTP_DOM_SEL. | Per PTP domain | VCAP IS2 action REW CMD defines the Delay Reg/Resp processing mode where two modes exist: - Generate Delay\_Resp from Delay Req frame and update the receiveTimestamp in the PTP header with the ingress PTP time stamp. Use the time stamp from the configured time domain (ANA\_ACL:PORT:PTP\_CFG.PTP\_DOMAIN). This time domain must match the selected time domain on the ingress port (DEVxx::PTP\_CFG.PTP\_DOM) - Generate Delay Resp from Delay Req frame and do not update the receiveTimestamp. In addition to the VCAP IS2 action, the Delay\_Req/Resp processing must also be enabled in ANA\_ACL (ANA\_ACL::PTP\_MISC\_CTRL.PTP\_ALLOW\_ACL\_REW\_ENA). In addition to updating the receiveTimestamp, the following PTP header modifications are done independently of the Delay Req/Resp processing mode: - messageType. The PTP messageType is set to 0x9 (Delay Resp) - messageLength. The PTP messageLength is set to 0x54 and the frame is expanded with 10 bytes to accommodate the requestingPortIdentity. If the frame expands beyond 148 bytes, then the frame is discarded. For PTP frames carried over UDP, the UDP length is increased with 10 bytes. It is mandatory that the original UDP length is 44 bytes. For PTP frames carried over IPv4, the IP total length is increased with 10 bytes. flagField. Selected bits in the PTP flagField can be reconfigured using the per-PTP domain configured flagField and flagField mask (ANA\_ACL:PTP\_DOM:PTP\_MISC\_CFG). The PTP domain is selected using VCAP IS2 action PTP\_DOM\_SEL. • **sourcePortIdentity.** The sourcePortIdentity is constructed using a 64-bit clockIdentity and a 16-bit portNumber. The clockIdentity is configurable per-PTP domain. By default, the portNumber is set to a per-PTP domain configured value. In addition, it is selectable to overwrite the six least significant bits with a per-port configured value. The PTP domain is selected using VCAP IS2 action PTP DOM SEL. - controlField. The PTP controlField is set to 0x3. - logMessageInterval. The PTP logMessageInterval can be specified for multicast frames only with new values ranging from –8 through 7. The new value is configured using VCAP IS2 actions SWAP MAC ENA and LOG MSG INT. This update can be globally disabled in ANA\_ACL::PTP\_MISC\_CTRL.PTP\_DELAY\_REQ\_MC\_UPD\_ENA. requestingPortIdentity. This fields is set to the incoming frame's sourcePortIdentity. For PTP frames carried over UDP, any PTP header modifications trigger the UDP checksum to be updated for IPv6 frames and to be cleared for IPv4 frames. In addition to the PTP header modifications, address swapping and rewriting can also be enabled for PTP frames. For PTP carried over UDP it can be useful to also swap MAC addresses, swap IP addresses, change UDP port numbers, and preset the IPv4 TTL or IPv6 hop limit. # 3.20 Analyzer Layer 2 Forwarding and Learning The analyzer Layer 2 (ANA\_L2) block performs the following tasks: - · Determining forwarding decisions - · Tracking network stations and their MAC addresses through learning and aging - Tracking and setting limits for number station learned per FID/ports - Scanning and updating the MAC table The analyzer Layer 2 block makes a forwarding decision based on a destination lookup in the MAC table. The lookup is based on the received Destination MAC address together with either the classified VID for multicast traffic or the classified FID for unicast traffic. If an entry is found in the MAC table lookup, the associated entry address is used for selecting forwarding port or ports. A flood forwarding decision is made if no entry is found and forwarding to unknown destinations is permitted (ANA L3:VLAN:VLAN CFG.VLAN SEC FWD ENA). The analyzer Layer 2 block performs a source lookup in the MAC table to determine if the source station is known or unknown by looking at if there is an entry in the MAC table. If a MAC table entry exists, a port move detection is performed by looking at whether the frame was received at the expected interface specified. The source check can trigger the following associated actions. - Disabling forwarding from unknown or moved stations - Triggering automated learning - · Sending copy to CPU If the source station is known, the entry AGE\_FLAG is cleared to indicate that source associated with the entry is active. The AGE\_FLAG is part of the aging functionality to remove inactive MAC table entries. For more information, see Automated Aging (AUTOAGE), page 178. The following subsections further describe the main analyzer Layer 2 blocks. # 3.20.1 Analyzer MAC Table The analyzer Layer 2 block contains a MAC table with 16,384 entries containing information about stations learned or known by the device. The table is organized as a hash table with four buckets on each row. Each row is indexed based on a hash value calculated based on the station's (FID, MAC) pair. The filtering ID (FID) used is either the FID from the VLAN table if a unicast MAC is looked up or else it is the classified VID. It is possible to enforce use of FID for multicast (ANA\_L3:COMMON:SERVICE\_CFG). MAC table organization is depicted in the following illustration. Figure 38 • MAC Table Organization # 3.20.1.1 MAC Entry Table Each entry in the MAC table contains the fields listed in the following table. Table 94 • MAC Table Entry | Field | Bits | Description | | |--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | VLD | 1 | Entry is valid. | | | MAC | 48 | The MAC address of the station. (Part of primary key). | | | FID | 13 | VLAN filtering identifier (FID) unicast C-MAC entries. VLAN identifier (VID) for multicast C-MAC entries. (Part of primary key). | | | LOCKED | 1 | Lock the entry as static. Note: Locking an entry will prevent hardware from changing anything but the AGE_FLAG in the entry. | | | MIRROR | 1 | Frames from or to this station are candidate for mirroring. | | | AGE_FLAG | 2 | The number of loopbackaging periods that have taken place since the last frame was received from this station. Incremented by hardware during a CPU SCAN and AUTOAGE SCAN for the entry configured AGE_INTERVAL. | | | AGE_INTERVAL | 2 | Used to select which age timer is associated with the entry. | | | NXT_LRN_ALL | 1 | Used to ensure consistent MAC tables in a stack. | | | CPU_COPY | 1 | Frames from or to this station are candidate for CPU copy. Used together with CPU_QU (to specify queue number). | | | CPU_QU | 3 | Used together with CPU_COPY. | | | SRC_KILL_FWD | 1 | Frames from this station will not be forwarded. This flag is not used for destination lookups. | | | VLAN_IGNORE | 1 | Used for ignoring the VLAN_PORT_MASK contribution from the VLAN table when forwarding frames to this station. Can optionally be used for source port ignore (ANA_L2::FWD_CFG.FILTER_MODE_SEL). | | | ADDR | 12 | Stored entry address used for forwarding and port move detection. The field is encoded according to ADDR_TYPE. | | Table 94 • MAC Table Entry (continued) | Field | Bits | Description | |-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADDR_TYPE | 3 | This field encodes how to interpret the ADDR field. Encoded as: ADDR_TYPE= UPSID_PN(0): Unicast entry address. Used to associate the entry with a unique {UPSID, UPSPN} port. ADDR(9:5) = UPSID ADDR(4:0) = UPSPN | | | | ADDR_TYPE=GCPU_UPS(1): CPU management entry address. Used to associate the entry with a unique global CPU port or internal port. ADDR(9:5) = UPSID ADDR(11) = 0: ADDR(3:0) = CPU port number. ADDR(11) = 1: ADDR(3:0) = 0xe: Internal port number. ADDR(3:0) = 0xf: Local lookup at destination unit (UPSID). | | | | ADDR_TYPE=GLAG(2): Unicast GLAG address. Used to associate the entry with a global aggregated port. ADDR = GLAGID. | | | | ADDR_TYPE=MC_IDX(3): Multicast entry address. Used to associate the entry with an entry in the PGID table. Specifies forwarding to the ports found in the PGID table entry indexed by mc_idx. ADDR = mc_idx. | ## 3.20.1.2 CAM Row Under some circumstances, it might be necessary to store more entries than possible on a MAC table row, in which case entries are continuously changed or automatically updated. To reduce this issue, one additional MAC table row (named CAM row) exist with entries that can be used to extend any hash chain, and thereby reduce the probability for hash depletion where all the buckets on a MAC table row are used. These entries on the CAM row can be used as any other MAC table entries. CAM row usage is controlled separately (by ANA\_L2::LRN\_CFG.AUTO\_LRN\_USE\_MAC\_CAM\_ENA, ANA\_L2::LRN\_CFG.CPU\_LRN\_USE\_MAC\_CAM\_ENA and ANA\_L2::LRN\_CFG.LRN\_MOVE\_CAM\_ENTRY\_BACK). # 3.20.2 MAC Table Updates Entries in the MAC table are added, deleted, or updated by the following methods. - Automatic (hardware-based) learning of source MAC addresses; that is, inserting new (MAC, FID) pairs in the MAC table - CPU access to MAC table (for example, CPU-based learning and table maintenance) - Automated age scan. ## 3.20.3 CPU Access to MAC Table This section describes CPU access to the MAC table. The following table lists the applicable registers. Table 95 • MAC Table Access Registers | Target::Register.Field | Description | Replication | |------------------------|-----------------------------------|-------------| | LRN:: | Controls CSR access to MAC table. | 1 | | COMMON_ACCESS_CTRL | | | Table 95 • MAC Table Access Registers (continued) | Target::Register.Field | Description | Replication | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | LRN::MAC_ACCESS_CFG_0 | Configures MAC (most significant bits) and FID for MAC table entries. | 1 | | LRN::MAC_ACCESS_CFG_1 | Configures MAC address (Least significant bits) for MAC table entries and FID. | 1 | | LRN::MAC_ACCESS_CFG_2 | Configures the following MAC entry fields: ADDR ADDR_TYPE SRC_KILL_FWD NXT_LRN_ALL CPU_COPY VLAN_IGNORE AFE_FLAG AGE_INTERNAL MIRROR LOCKED VLD | 1 | | LRN::EVENT_STICKY | Sticky status for access performed. | 1 | | LRN::SCAN_NEXT_CFG | MAC table scan filter controls. | 1 | | LRN::SCAN_NEXT_CFG_1 | MAC table port move handles when performing MAC table SCAN. | 1 | | ANA_L2::SCAN_FID_CTRL | Controls use of additional FIDs when doing scan. | 1 | | ANA_L2::SCAN_FID_CFG | Configures additional VID/FID filters during scan if enabled via ANA_L2::SCAN_FID_CTRL. | 16 | | LRN::SCAN_LAST_ROW_CFG | Configures a last row applicable for scan. | 1 | | LRN::SCAN_NEXT_CNT | MAC table status when performing MAC table SCAN. | 1 | | LRN::LATEST_POS_STATUS | Holds the latest CPU accessed MAC table location after a CPU_ACCESS_CMD has finished. | 1 | CPU access to the MAC table is performed by an indirect command-based interface where a number of fields are configured (in LRN::MAC\_TABLE\_ACCESS\_CFG\_\*) followed by specifying the command (in LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_CMD). The access is initiated by a shot bit that is cleared upon completion of the command (LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT). It is possible to trigger CPU interrupt upon completion (ANA\_L2:COMMON:INTR.LRN\_ACCESS\_COMPLETE\_INTR). The following table lists the types of access possible. Table 96 • MAC Table Access Commands | Command | Purpose | Use | |----------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Learn | Insert/learn new entry in MAC table. Position given by HASH(MAC, FID). | Configure MAC and FID of the new entry in LRN::MAC_ACCESS_CFG_0 and LRN::MAC_ACCESS_CFG_1. Configure entry fields in LRN::MAC_ACCESS_CFG_2. | | | | Status of operation returned in: LRN::EVENT_STICKY.CPU_LRN_REFRESH_STICKY, LRN::EVENT_STICKY.CPU_LRN_INSERT_STICKY, LRN::EVENT_STICKY.CPU_LRN_REPLACE_STICKY, LRN::EVENT_STICKY.CPU_LRN_REPLACE_FAILED_STICK Y, LRN::EVENT_STICKY.CPU_LRN_FAILED_STICKY, and LRN::EVENT_STICKY.LRN_MOVE_STICKY | | Unlearn/Forget | Delete/unlearn entry in MAC table given by (MAC, FID). | Configure MAC and FID of the entry to be unlearned in LRN::MAC_ACCESS_CFG_0 and LRN::MAC_ACCESS_CFG_1. | | | Position given by HASH(MAC, FID). | Status of operation returned in: LRN::EVENT_STICKY.CPU_UNLEARN_STICKY and LRN::EVENT_STICKY.CPU_UNLEARN_FAILED_STICKY. | | Lookup | Lookup entry in MAC table given by (MAC, FID). | Configure MAC and FID of the entry to be looked up in LRN::MAC_ACCESS_CFG_0 and LRN::MAC_ACCESS_CFG_1. | | | Position given by HASH(MAC, FID) | Status of lookup operation returned in: LRN::EVENT_STICKY.CPU_LOOKUP_STICKY and LRN::EVENT_STICKY.CPU_LOOKUP_FAILED_STICKY | | | | Entry fields are returned in LRN::MAC_ACCESS_CFG_2 if lookup succeeded. | | Read direct | Read entry in MAC table indexed by (row, column) | Configure the index of the entry to read in LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_R OW, LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_C OL and LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_T YPE | | | | Status of read operation returned in LRN::EVENT_STICKY.CPU_READ_DIRECT_STICKY | | | | Entry fields are returned in LRN::MAC_ACCESS_CFG_0, LRN::MAC_ACCESS_CFG_1 and LRN::MAC_ACCESS_CFG_2 if read succeeded. | Table 96 • MAC Table Access Commands (continued) | Command | Purpose | Use | |---------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Write direct | Write entry in MAC table indexed by (row, column) | Configure the index of the entry to write in LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_R OW, LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_C OL and LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_T YPE | | | | Configure entry fields in LRN::MAC_ACCESS_CFG_0, LRN::MAC_ACCESS_CFG_1 and LRN::MAC_ACCESS_CFG_2 | | | | Status of write operation returned in LRN::EVENT_STICKY.CPU_WRITE_DIRECT_STICKY | | Scan | Find next/Find all | Configure the starting row for the scan in: LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_R | | | Searches through the MAC table and either stops at the first row with entries matching | OW, LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_C OL and LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_T | | | the specified filter conditions<br>or perform the specified<br>actions on all entries matching | LRN::COMMON_ACCESS_CTRL.CPU_ACCESS_DIRECT_T YPE | | | the specified filter conditions. | Configure an ending row for the scan (if searching through the complete table is not required): LRN::SCAN_LAST_ROW_CFG.SCAN_LAST_ROW | | | | For information about search filters and corresponding actions, see SCAN Command, page 171. | | Find smallest | Get the smallest entry in the MAC table numerically larger than the specified (FID, MAC). | Configure MAC and FID of the starting point for the search in LRN::MAC_ACCESS_CFG_0 and LRN::MAC_ACCESS_CFG_1. | | | FID and MAC are evaluated as a 61 bit number with the FID | Configure search filters to be used during find smallest: | | | being most significant. | Use LRN::SCAN_NEXT_CFG.SCAN_NEXT_IGNORE_LOCKED_E NA to only search among entries with LRN::MAC_ACCESS_CFG_2.MAC_ENTRY_LOCKED cleared. | | | | Use LRN::SCAN_NEXT_CFG.FID_FILTER_ENA to only search among entries with the VID/FID specified in LRN::MAC_ACCESS_CFG_0.MAC_ENTRY_FID. | | | | Use LRN::SCAN_NEXT_CFG.ADDR_FILTER_ENA to only search among entries with the address specified in LRN::MAC_ACCESS_CFG_2.MAC_ENTRY_ADDR and LRN::MAC_ACCESS_CFG_2.MAC_ENTRY_ADDR_TYPE | | Clear all | Initialize the table | Clears the entire table. | # 3.20.3.1 Adding a Unicast Entry Use the following steps to add a unicast entry to the MAC table using the CPU interface. - Configure the entry MAC address: LRN::MAC\_ACCESS\_CFG\_0.MAC\_ENTRY\_MAC\_MSB <16 MS MAC bits > LRN::MAC ACCESS CFG 1.MAC ENTRY MAC LSB < 32 LS MAC bit > - 2. Configure the VLAN FID: - LRN::MAC\_ACCESS\_CFG\_0.MAC\_ENTRY\_FID <fid value> - 3. Configure the UPSID/UPSPN value: - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR\_TYPE 0 (=UPSID) - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR <UPSPN/port value > - 4. Make the entry valid: LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_VLD 1 - 5. Perform access: - LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_CMD 0 (=LEARN) LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT 1 - Verify that access succeeded: LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT == 0? LRN::EVENT\_STICKY.CPU\_LRN\_INSERT\_STICKY==1? ## 3.20.3.2 Adding Multicast Entry with Destination Set in PGID Table Use the following steps to add Layer 2 multicast entries to the MAC table using the CPU interface. - Configure the entry MAC address: LRN::MAC\_ACCESS\_CFG\_0.MAC\_ENTRY\_MAC\_MSB <16 MSB MAC bits > LRN::MAC ACCESS CFG 1.MAC ENTRY MAC LSB < 32 LSB MAC bits > - 2. Configure the VLAN ID: - LRN::MAC ACCESS CFG 0.MAC ENTRY FID <vid value> - 3. Configure the PGID pointer: - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR\_TYPE 3 (=MC\_IDX) - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR <pgid value > - 4. Lock the entry (not subject to aging and automatic removal): - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_LOCKED 1 - 5. Make the entry valid: - LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_VLD 1 - 6. Perform access: - LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_CMD 0 (=LEARN) - LRN::COMMON ACCESS CTRL.MAC TABLE ACCESS SHOT 1 - 7. Verify that access succeeded: LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT == 0? LRN::EVENT\_STICKY.CPU\_LRN\_INSERT\_STICKY==1? ## 3.20.4 SCAN Command The SCAN command easily performs table management, such as port flushing, CPU-based aging, and port moves. Scan can be configured with a variety of filters and modifiers that allows the CPU to easily identify and optionally modify entries matching the configured filter conditions. The scan operates by running through all entries and whenever entries are found with matching conditions, the scan either stops with a status of the matching location (for example, a "find next" operation) or performs the configured modification actions for all entries (for example, "scan all" operation). When the scan runs as "find next", the scan commands are performed for finding the next matching entry. In this case it is possible to specify a starting row for a scan ( LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_DIRECT\_ROW and LRN::COMMON ACCESS CTRL.CPU ACCESS DIRECT TYPE). Whenever the scan stops with a matching entry, the CPU can process the entry and then sets the starting row to the row following the matching row and, issue another scan command. This can then be repeated until all entries have been scanned. SCAN is started by setting LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_CMD 5 (=SCAN) and setting the shot bit LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT SCAN is completed when the shot bit is cleared in LRN::COMMON ACCESS CTRL.MAC TABLE ACCESS SHOT. The following table lists the supported SCAN filters. Table 97 • Scan Filters | Filter Type | Target::Register.Field | Description | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FID filter | LRN::SCAN_NEXT_CFG.FID_FILTER_ENA LRN::MAC_ACCESS_CFG_0.MAC_ENTRY_FID ANA_L2::SCAN_FID_CTRL ANA_L2::SCAN_FID_CFG | Finds entries with a specific VID/FID. | | Port or Address filter | LRN::SCAN_NEXT_CFG.ADDR_FILTER_ENA, LRN::MAC_ACCESS_CFG_2.MAC_ENTRY_ADDR, LRN::MAC_ACCESS_CFG_2.MAC_ENTRY_ADDR_TYPE LRN::SCAN_NEXT_CFG_1.SCAN_ENTRY_ADDR_MASK | Finds entries with a specific ADDR_TYPE and ADDR. Note that this can be combined with ADDR wildcards; for example, to find all entries related with a given ADDR_TYPE, and so on. | | Automatic age scan port filter | LRN::SCAN_NEXT_CFG.SCAN_USE_PORT_FILTER_ENA ANA_L2::FILTER_OTHER_CTRL ANA_L2::FILTER_LOCAL_CTRL | Configures a port filter used for defining which ports are applicable for automatic aging. | | Non-locked only filter | LRN::SCAN_NEXT_CFG.SCAN_NEXT_IGNORE_LOCKED _ENA | Finds non locked entries. | | Aged only filter | LRN::SCAN_NEXT_CFG.SCAN_NEXT_AGED_ONLY_ENA | Finds only aged entries, that is, AGE_FLAG equal to maximum (configured in ANA_L2::LRN_CFG.AGE_SIZE). | | AGE_INTERVAL filter | LRN::SCAN_NEXT_CFG.SCAN_AGE_INTERVAL_MASK | Finds entries with a specific AGE_INTERVAL. | | AGE_FLAG filter | LRN::SCAN_NEXT_CFG.SCAN_AGE_FILTER_SEL MAC_ACCESS_CFG_2.MAC_ENTRY_AGE_FLAG | Finds only entries with a specific value. | | NXT_LRN_ALL filter | LRN::SCAN_NEXT_CFG.NXT_LRN_ALL_FILTER_ENA MAC_ACCESS_CFG_2. MAC_ENTRY_NXT_LRN_ALL | Finds only entries with a specific value. | | Ignore locked filter | LRN::SCAN_NEXT_CFG.SCAN_NEXT_IGNORE_LOCKED _ENA | Finds all or only non locked entries. | | Aged only filter | LRN::SCAN_NEXT_CFG.SCAN_NEXT_AGED_ONLY_ENA | Finds all or only aged entries (AGE_FLAG != 0). | The following table lists the available SCAN related actions. Table 98 • Scan Modification Actions | Action Type | Target::Register.Field | Description | |--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------| | Scan next until found | LRN::SCAN_NEXT_CFG.SCAN_NEXT_UNTIL_FOUND_ENA | Controls if scan stops when finding an entry or scans through all entries. | | Update<br>AGE_FLAG | LRN::SCAN_NEXT_CFG.SCAN_AGE_FLAG_UPDATE_SEL | Updates AGE_FLAG for found entries. See LRN::SCAN_NEXT_CFG. | | Update<br>NXT_LRN_ALL | LRN::SCAN_NEXT_CFG.SCAN_NXT_LRN_ALL_UPDATE_S<br>EL | Update sNXT_LRN_ALL for found entries. See LRN::SCAN_NEXT_CFG. | | Change address<br>(MOVE) | LRN::SCAN_NEXT_CFG.SCAN_NEXT_MOVE_FOUND_ENA<br>LRN::SCAN_NEXT_CFG_1.PORT_MOVE_NEW_ADDR<br>LRN::SCAN_NEXT_CFG_1.SCAN_ENTRY_ADDR_MASK | Updates address for found entries. | Table 98 • Scan Modification Actions (continued) | Action Type | Target::Register.Field | Description | |--------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Remove | LRN::SCAN_NEXT_CFG.SCAN_NEXT_REMOVE_FOUND_E<br>NA | Removes found entries. | | CPU age scan | LRN::SCAN_NEXT_CFG.SCAN_NEXT_INC_AGE_BITS_ENA | A Performs CPU based age scan. Aged entries. For example, entries with AGE_FLAG equal to maximum (configured in ANA_L2::LRN_CFG.AGE_SIZE) are removed and Non aged entries, such as entries with AGE_FLAG less than maximum, gets the AGE_FLAG incremented. Automatic Learning, page 176. | The following SCAN status is available: - Match scan result for the last matching row is reported (LRN::LATEST POS STATUS.SCAN NEXT STATUS). - Number of entries found during the scan found (LRN::SCAN NEXT CNT.SCAN NEXT CNT). - Scan remove is reported via the sticky event (LRN::EVENT STICKY.SCAN REMOVED STICKY) - Scan match found is reported via the sticky event (LRN::EVENT STICKY.ROW WITH SCAN ENTRY STICKY). ## 3.20.4.1 Initiating a Port Move for a Specific FID The following example initiates a port move for specific FID. - Move found entries: - Set LRN::SCAN NEXT CFG.SCAN NEXT MOVE FOUND ENA = 1. - Specify the FID filter: - Set LRN::SCAN NEXT CFG.FID FILTER ENA = 1. - Set LRN::MAC ACCESS CFG 0.MAC ENTRY FID = <FID value>. - Specify port filter: - Set LRN::SCAN NEXT CFG.ADDR FILTER ENA = 1. - Set LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR\_TYPE = 0 to specify address type UPSID\_PN. - Set LRN::MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_ADDR = <UPSID, UPSPN> to specify UPSID and UPSPN. - Specify the new address: - Set LRN::SCAN\_NEXT\_CFG\_1.PORT\_MOVE\_NEW\_ADDR = <new UPSID, new UPSPN> Set LRN::SCAN\_NEXT\_CFG\_1.SCAN\_ENTRY\_ADDR\_MASK = all ones. - Scan through all rows by starting at row 0: - Set LRN::COMMON ACCESS CTRL.CPU ACCESS DIRECT ROW = 0. - Set LRN::COMMON ACCESS CTRL.CPU ACCESS DIRECT TYPE = 0. - Issue SCAN command: - Set LRN::COMMON\_ACCESS\_CTRL.CPU\_ACCESS\_CMD = 5. - Set LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT = 1. - Wait until LRN::COMMON\_ACCESS\_CTRL.MAC\_TABLE\_ACCESS\_SHOT is cleared. # 3.20.5 Forwarding Lookups This section describes forwarding handling. The following table lists the applicable registers. Table 99 • Forwarding Registers | Target::Register.Field | Description | Replication | |------------------------|--------------------------------------|-------------| | ANA_L2:COMMON:FWD_CFG | Configures common forwarding options | 1 | ## 3.20.5.1 DMAC-Based Forwarding The analyzer performs destination lookup in the MAC table to determine if the destination MAC address is known or unknown. - If the destination is unknown, a flood forwarding decision is made if forwarding from unknown sources is allowed (ANA\_L3:VLAN:VLAN\_CFG.VLAN\_SEC\_FWD\_ENA). The associated flood masks are located in the PGID table. - If the destination address is known, the associated ADDR\_TYPE and ADDR stored in the destination entry is used to find the destination port or ports in the PGID table. Flooded traffic can be made available for mirroring (ANA\_L2:COMMON:FWD\_CFG.FLOOD\_MIRROR\_ENA) and CPU copying (ANA\_L2:COMMON:FWD\_CFG.FLOOD\_CPU\_COPY\_ENA ANA L2:COMMON:FWD\_CFG.CPU\_DMAC\_QU). Traffic with known DMAC and VLAN IGNORE set LRN:COMMON:MAC\_ACCESS\_CFG\_2.MAC\_ENTRY\_VLAN\_IGNORE for CPU learned frames or LRN:COMMON:AUTO\_LRN\_CFG.AUTO\_LRN\_IGNORE\_VLAN for auto learned entries) and optionally also flooded traffic (when ANA\_L2:COMMON:FWD\_CFG.FLOOD\_IGNORE\_VLAN\_ENA set) can be configured to ignore VLAN port mask or source port mask (ANA\_L2:COMMON:FWD\_CFG.FILTER\_MODE\_SEL). The DMAC lookup of the received {DMAC, EFID} in the MAC table is shown in the following illustration. Figure 39 • DMAC Lookup ## 3.20.6 Source Check and Automated Learning This section describes hardware (or automated) learning related to source checking. The following table lists the applicable registers. Table 100 • Hardware-Based Learning | Target::Register.Field | Description | Replication | |-----------------------------------------|------------------------------------------------------------------|------------------------------------------| | ANA_L2::AUTO_LRN_CFG | Configures automatic learning per port | 1 | | ANA_L2::LRN_SECUR_CFG | Configures secure forwarding per port | 1 | | ANA_L2::LRN_SECUR_LOCKED_CF | Configures secure forwarding for static locked entries per port. | 1 | | ANA_L2::LRN_COPY_CFG | Configures CPU copy of learn frames per port. | 1 | | ANA_L2::MOVELOG_STICKY | Identifies ports with moved stations. | 1 | | ANA_L2::LRN_CFG | Configures common learning properties. | 1 | | ANA_L3:VLAN:VLAN_CFG.VLAN_FID | Configures filtering identifier (FID) to be used for learning. | Per VLAN | | LRN::AUTO_LRN_CFG | Configures automatic learning options. | 1 | | LRN::EVENT_STICKY | Signal various sticky learning events. | 1 | | ANA_L2:PORT_LIMIT:PORT_LIMIT_<br>CTRL | Controls automatic learn limits per logical port and GLAG. | per port and<br>GLAG (11+8<br>instances) | | ANA_L2:PORT_LIMIT:PORT_LIMIT_<br>STATUS | Status for port limits. | per port and<br>GLAG (11+8<br>instances) | | ANA_L2:LRN_LIMIT:FID_LIMIT_CTRL | Controls automatic learn limits per FID. | per FID (4,224 instances) | | ANA_L2:LRN_LIMIT:FID_LIMIT_<br>STATUS | Status for FID limits. | per FID (4,224 instances) | The device learns addresses from each received frame's SMAC field, so that subsequently forwarded frames whose destination addresses have been learned can be used to restrict transmission to the port or ports necessary to reach their destination. The analyzer performs source lookup of the received {SMAC, IFID} in the MAC table to determine if the source station is known or unknown. For more information, see Figure 40, page 176. If the source station is known, a port move detection is performed by checking that the frame was received at the expected port as specified by the ADDR\_TYPE and ADDR stored in the source entry. The expected port can be a logical port (represented as UPSID, UPSPN) or a global aggregated port (represented as GLAGID) as described in the following. Failing source checks can trigger a number of associated actions: - Secure forwarding. Disable forwarding from unknown or moved stations. This action can be triggered by two configurations: - VLAN-based Secure forwarding controlled per VLAN (ANA\_L3:VLAN:VLAN\_CFG.VLAN\_SEC\_FWD\_ENA). - Port-based secure forwarding controlled per port (ANA\_L2::LRN\_SECUR\_CFG). - Secure forwarding from locked entries. Disable forwarding from known but moved stations with locked MAC table entry (ANA L2:COMMON:LRN SECUR LOCKED CFG). - Automatic learning enabled per port (ANA\_L2::AUTO\_LRN\_CFG). Automatic learning of traffic received from an unknown source station will cause the MAC table to be updated with a new entry. Traffic received from a known source station with changed port will cause the known MAC table entry ADDR\_TYPE and ADDR to be updated. - CPU copy enabled per port (ANA\_L2::LRN\_COPY\_CFG and ANA\_L2::LRN\_CFG.CPU\_LRN\_QU). A learn copy is sent to CPU. These actions are controlled independently. In other words, it is possible to send a CPU copy as well as disable normal forwarding. Figure 40 • Source Check The source lookup is also used to clear an Age flag (used as activity indication) in the MAC table to allow inactive MAC table entries to be pruned. Port move detection is not performed for locked MAC table entries unless enabled (ANA\_L2::LRN\_CFG.LOCKED\_PORTMOVE\_DETECT\_ENA). Frames failing locked port move detection can be copied to CPU queue (ANA\_L2::LRN\_CFG.CPU\_LRN\_QU and ANA\_L2::LRN\_CFG.LOCKED\_PORTMOVE\_COPY\_ENA). ## 3.20.6.1 Automatic Learning The device can automatically add or update entries in the MAC table. New entries added by automatic learning are formatted as follows. - VLD is set - · MAC is set to the frame's SMAC address - FID set to the frame's REQ.FID - ADDR\_TYPE, ADDR is set to: UPSID\_PN if received on a non aggregated port GLAG if received on a global aggregated port - MAC\_CPU\_COPY (LRN::AUTO\_LRN\_CFG.AUTO\_LRN\_CPU\_COPY) - MAC\_CPU\_QU (LRN::AUTO\_LRN\_CFG.AUTO\_LRN\_CPU\_QU) - SRC KILL (LRN::AUTO LRN CFG.AUTO LRN SRC KILL FWD) - IGNORE VLAN (LRN::AUTO LRN CFG.AUTO LRN IGNORE VLAN) - MIRROR (LRN::AUTO LRN CFG.AUTO LRN MIRROR) - AGE\_INTERVAL (LRN::AUTO\_LRN\_CFG.AUTO\_AGE\_INTERVAL) - · All other fields are cleared When a frame is received from a known station, that is, the MAC table already contains an entry for the received frame's (SMAC, VID/FID), the analyzer clears the AGED\_FLAG for unlocked entries (LOCKED flag cleared) and optionally, locked entries (ANA\_L2:COMMON:LRN\_CFG.AGE\_LOCKED\_ENA). A cleared AGE\_FLAG implies that the station is active. For more information, Automated Aging (AUTOAGE), page 178. For unlocked entries, ADDR\_TYPE and ADDR fields are compared against the following: - UPSID PN if received on a non aggregated port - GLAG if received on a global aggregated port If there is a difference, the source entry ADDR\_TYPE and ADDR is updated, which implies the station has moved to a new port. Source check for entries stored with ADDR\_TYPE=MC\_IDX (=3) can be ignored (ANA L2::LRN CFG.IGNORE MCIDX PORTMOVE ENA). ## **3.20.6.2 Port Move Log** A port move occurs when an existing MAC table entry for (MAC, FID) is updated with new port information (ADDR\_TYPE and ADDR). Such an event is logged and reported (in ANA L2::MOVELOG STICKY) by setting the bit corresponding to the new port. If port moves continuously occurs, it may indicate a loop in the network or a faulty link aggregation configuration. Port moves for locked entries can be detected in ANA\_L2::LRN\_CFG.LOCKED\_PORTMOVE\_DETECT\_ENA. #### 3.20.6.3 Port Learn Limits It is possible to specify the maximum number of entries in the MAC table per port. Port limits can be specified per logical port (local link aggregated port) and per global link aggregated port (GLAG) (ANA\_L2:PORT\_LIMIT:PORT\_LIMIT\_CTRL.PORT\_LRN\_CNT\_LIMIT). These limits do not take multicast into account. The current number of learned entries are always available in ANA\_L2:PORT\_LIMIT\_STATUS.PORT\_LRN\_CNT and are updated whenever either an automatic learn operation or a CPU access is performed. After a limit is reached, both automatic learning and CPU-based learning of unlocked entries are denied. A learn frame to be learned when the limit is reached can selectively be discarded, redirected to CPU, or copied to CPU (controlled in ANA\_L2:PORT\_LIMIT:PORT\_LIMIT\_CTRL.PORT\_LIMIT\_EXCEED\_SEL). Trying to exceed the configured limit can also trigger interrupt (ANA\_L2:PORT\_LIMIT:PORT\_LIMIT\_CTRL.PORT\_LIMIT\_EXCEED\_IRQ\_ENA). When learn limits are exceeded, a corresponding sticky bit is set (ANA L2:PORT LIMIT:PORT LIMIT STATUS.PORT LRN LIMIT EXCEEDED STICKY). If a MAC table entry interrupt moves from one port to another port, it is also reflected in the current number of learned entries. ## 3.20.6.4 Filtering Identifier Learn Limits It is possible to specify the maximum number of entries to be used per FID (ANA\_L2:LRN\_LIMIT:FID\_LIMIT\_CTRL.FID\_LRN\_CNT\_LIMIT). These limits do not take multicast into account. The current number of learned entries are always available in ANA L2:LRN LIMIT:FID LIMIT STATUS.FID LRN CNT. After a limit is reached, both automatic learning and CPU-based learning of unlocked entries are denied. A learn frame to be learned when the limit is reached can selectively be discarded, redirected to CPU, or copied to CPU (controlled by ANA\_L2:LRN\_LIMIT:FID\_LIMIT\_CTRL.FID\_LIMIT\_EXCEED\_SEL). Attempts to exceed the configured limit can also trigger interrupt (ANA L2:LRN LIMIT:FID LIMIT CTRL.FID LIMIT EXCEED IRQ ENA). When the learn limits are exceeded, a corresponding sticky bit is set (ANA\_L2:LRN\_LIMIT:FID\_LIMIT\_STATUS.FID\_LRN\_LIMIT\_EXCEEDED\_STICKY). ## 3.20.6.5 Shared or Independent VLAN Learning in MAC Table The device can be set up to do a mix of Independent VLAN Learning (IVL), where MAC addresses are learned separately on each VLAN and Shared VLAN Learning (SVL), where a MAC table entry is shared among a group of VLANs. For shared VLAN learning, a MAC address and a filtering identifier (FID) define each MAC table entry. A set of VIDs used for Shared VLAN learning maps to the same FID. Shared VLAN learning is only applicable for unicast traffic. Addresses learned from frames with one VLAN Identifier (VID) may or may not be used to filter frames with the same SMAC but another VID, depending on management controls. If learned information is shared for two or more given VIDs those VIDs map to a single Filtering Identifier (FID) and the term Shared VLAN Learning (SVL) is used to describe their relationship. If the information is not shared, the VIDs map to different FIDs and Independent VLAN Learning (IVL) is being used. FID is configured per VLAN (ANA\_L3:VLAN:VLAN\_CFG.VLAN\_FID). For example, if VID 16 and VID 17 use SVL and share FID 16, then a MAC entry (MAC #X, FID 16) is known for both VID 16 and VID 17. If VID 16 and VID 17 use IVL and use FID 16 and FID 17, a MAC entry (MAC #X, FID 16) is only known for VID 16; that is, the MAC address will be unknown for VID 17 (FID = 17). In a VLAN-unaware operation, the device is set up to do SVL; that is, MAC addresses are learned for all VLANs. Protocol-based VLAN, where traffic is classified into multiple VLANs based on protocol, requires SVL # 3.20.7 Automated Aging (AUTOAGE) This section describes how to configure automated age scanning. The following table lists the applicable registers. Table 101 • Automated Age Scan Registers Overview | Target::Register.Field | Description | Replication | |--------------------------------------------------|--------------------------------------------------------------------------------|-------------| | LRN::AUTOAGE_CFG | Configures automated age scan of MAC table for each of the four AGE_INTERVALs. | 4 | | LRN::AUTOAGE_CFG_1 | Configures automated age scan of MAC table. | 1 | | LRN::AUTOAGE_CFG_2 | Configures automated age scan of MAC table. | 1 | | LRN::EVENT_STICKY. AUTOAGE_SCAN_COMPLETED_STICKY | Signals completion of an automatic scan. | 1 | | LRN::EVENT_STICKY. AUTOAGE_SCAN_STARTED_STICKY | Signals start of an automatic scan. | 1 | | LRN::EVENT_STICKY. AUTOAGE_AGED_STICKY | Signals entries aged due to automatic aging. | 1 | | LRN::EVENT_STICKY. AUTOAGE_REMOVE_STICKY | Signals entries removed due to automatic aging. | 1 | | ANA_L2::FILTER_LOCAL_CTRL | Configures front port filters to be used by automatic aging and CPU scan. | 1 | | ANA_L2::FILTER_OTHER_CTRL | Configures remote scan filter to be used by automatic aging and CPU scan. | 1 | | ANA_L2::LRN_CFG.AGE_SIZE | Configures the AGE_FLAG size. | 1 | Entry AGE\_FLAG is used to detect inactive sources. The AGE\_FLAG field is cleared upon receiving traffic from a given source station and is periodically incremented by hardware to detect and delete inactive source entries. The automated age scan scans the MAC table and checks age candidates (entries with LOCK flag set to 0) for activity. If an entry's AGE\_FLAG is set to maximum value (configured in ANA\_L2::LRN\_CFG.AGE\_SIZE), the entry is deemed inactive and removed. If an entry's AGE\_FLAG is less than the maximum value, the AGE\_FLAG is incremented. The flag is cleared when receiving frames from the station identified by the MAC table entry. It is possible to configure and forget AUTOAGE, which means that once configured automated aging is performed without any further CPU assistance. The interval between automatic aging can be controlled by specifying AGE\_FLAG size (ANA\_L2::LRN\_CFG.AGE\_SIZE), unit size (LRN::AUTOAGE\_CFG.UNIT\_SIZE), and the number of units between aging (LRN::AUTOAGE\_CFG.PERIOD\_VAL). Setting LRN::AUTOAGE CFG.UNIT SIZE different from 0 to start the automatic aging. To temporarily disable automatic aging, set LRN::AUTOAGE\_CFG. PAUSE\_AUTO\_AGE\_ENA to 1. Additional control of automatic aging allows for instantaneously start and stop of current age scan (LRN::AUTOAGE\_CFG\_1.FORCE\_HW\_SCAN\_SHOT and LRN::AUTOAGE\_CFG\_1.FORCE\_HW\_SCAN\_STOP\_SHOT). It is also possible to do a controlled stopping of current age scan after it completes (LRN::AUTOAGE CFG 1.FORCE IDLE ENA). It is possible to selectively do age filtering of local ports specified in ANA\_L2::FILTER\_LOCAL\_CTRL.FILTER\_FRONTPORT\_ENA or selectively do age filtering of entries learned on remote devices in a multichip configuration (ANA\_L2::FILTER\_OTHER\_CTRL.FILTER\_REMOTE\_ENA). Both types must be enabled (LRN::AUTOAGE\_CFG\_1.USE\_PORT\_FILTER\_ENA). The state of automatic aging can be monitored (LRN::AUTOAGE CFG 2.NEXT ROW, LRN::AUTOAGE CFG 2.SCAN ONGOING STATUS, LRN::EVENT STICKY.AUTOAGE SCAN COMPLETED STICKY and LRN::EVENT STICKY.AUTOAGE SCAN STARTED STICKY). It is possible to observe whether entries are affected by a sticky event (LRN::EVENT\_STICKY.AUTOAGE\_AGED\_STICKY and LRN::EVENT\_STICKY.AUTOAGE\_REMOVE\_STICKY). ## Example For a 300-second age time, set four age periods of 75 seconds each: - 1. Set ANA\_L2::LRN\_CFG.AGE\_SIZE to 1. - 2. Set LRN::AUTOAGE\_CFG[0]. AUTOAGE\_UNIT\_SIZE to 3. - 3. Set LRN::AUTOAGE\_CFG[0]. AUTOAGE\_PERIOD\_VAL to 75. ## 3.20.8 Interrupt Handling The following table lists the interrupt handling registers. Table 102 • Analyzer Interrupt Handling Registers Overview | Target::Register.Field | Description | Replication | |------------------------|----------------------------|-------------| | ANA_L2::INTR | Status of interrupt source | 1 | | ANA_L2::INTR_ENA | Mask interrupt | 1 | | ANA_L2::INTR_IDENT | Status of interrupt | 1 | A sticky status of all interrupt sources in the analyzer is available (ANA\_L2::INTR.VCAP\_S2\_INTR), and all interrupt source can individually be configured to trigger CPU interrupt (ANA\_L2::INTR\_ENA). The current CPU interrupt status is available (ANA\_L2::INTR\_IDENT). The following analyzer interrupt sources exist: VCAP IS2 can be setup to trigger CPU interrupt (VCAP\_S2\_INTR) when an entry with enabled interrupt is hit (VCAP IS2 action INTR\_ENA). It is possible to trigger interrupt (PORT\_LRN\_LIMIT\_INTR) when learning on a port attempt to exceed a configured port learn limit (configured in ANA L2:PORT LIMIT:PORT LIMIT CTRL.PORT LIMIT EXCEED IRQ ENA). It is possible to trigger interrupt (FID\_LRN\_LIMIT\_INTR) when learning on a FID attempt to exceed a configured limit (configured in ANA L2:LRN LIMIT:FID LIMIT CTRL.FID LIMIT EXCEED IRQ ENA). LRN access to the MAC table can be configured to trigger interrupt (LRN\_ACCESS\_COMPLETE\_INTR) after completion. This is useful when multiple CPU scans must be performed as fast as possible, for example, when sorting the MAC addresses extracted from the entire MAC table using SCAN commands. For more information about using the SCAN command, see SCAN Command, page 171. # 3.21 Analyzer Access Control Forwarding, Policing, and Statistics This section provides information about analyzer access control (ANA\_AC) forwarding, policing, and statistics. ## 3.21.1 Mask Handling This section describes how a number of port masks are applied to ensure correct forwarding. - VLAN port mask from ANA\_L3:VLAN. This mask is used to ensure frames are only forwarded within a dedicated VLAN (or VSI if service forwarded). The VLAN mask handle protection by means of hardware assisted updates. For more information, see VLAN Table Update Engine, page 124. The VLAN mask can be modified by VCAP CLM full action MASK\_MODE and by VCAP IS2 action MASK\_MODE. - PGID port mask from ANA\_AC:PGID. This mask is based on the DMAC lookup in the PGID table. One of the six flood PGID entries is used if the DMAC is unknown. For DMAC known in the MAC table, the associated address is used to select the used PGID entry. - Source port mask from ANA\_AC:SRC. This mask is used to ensure frames are never forwarded to the port it was received on and the used entry is found by looking up the source port. - Global source port mask from ANA\_AC:SRC. This mask is used to ensure frames are never forwarded to the global port it was received on and the used entry is found by looking up the global stacking source port. - Aggregation port mask from ANA\_AC:AGGR. This mask is used to ensure frames are forwarded to one port within each aggregate destination port. - REQ.port\_mask and REQ.mask\_mode. This mask is special in the sense that it is a general purpose mask that can be used for various security features and protection. The mask is controlled by VCAP CLM and VCAP IS2. The following sections provide more information about the different port masks. ## 3.21.1.1 **PGID Lookup** The following table lists the registers associated with PGID lookup. Table 103 • PGID Registers Overview | Target::Register.Field | Description | Replication | |---------------------------|-----------------------------------------------------------------------------------------|-------------| | ANA_AC:PGID:PGID_MISC_CFG | Configures how to interpret PGID_CFG and configures CPU copy with associated CPU queue. | per PGID | | ANA_AC:PGID:PGID_CFG | Configures destination port mask or destination {UPSID,PN}. | per PGID | The PGID table is organized as shown in the following illustration. Figure 41 • PGID Layout The forwarding process generates a forwarding decision that is used to perform a lookup in the PGID table. The following forwarding decisions are possible. - Flood forwarding to one of the six flood masks located from address 11 to address 16 in the PGID table is used as destination mask. - Unicast forwarding to {UPSID,UPSPN}. UPSID is checked against ANA\_AC::COMMON\_VSTAX\_CFG.OWN\_UPSID: If identical, destination mask is found based on lookup of UPSPN within the front port destinations of the PGID table (address 0 to 10). If not identical, destination mask is found based on lookup of UPSID in ANA AC:UPSID:UPSID CFG. Multicast forwarding: mc\_idx is looked up in the PGID table with an offset of 11. Based on the returned entry stack bit: If cleared, the returned entry mask is interpreted as a destination mask. If set, the returned entry mask is {UPSID,UPSPN} and the destination mask is found based on lookup of UPSID in ANA AC:UPSID:UPSID CFG. - REQ destination set (REQ.COMMON.PORT\_MASK when REQ.COMMON.MASK\_MODE=REPLACE\_PGID). Destination set (REQ.COMMON.PORT\_MASK from VCAP CLM or VCAP IS2 is directly used as destination mask without PGID lookup. - REQ.L2 FWD cleared. Frame is discarded. It is possible to generate a CPU copy can be generated when using the PGID lookup. If ANA\_AC:PGID:PGID\_MISC\_CFG.PGID\_CPU\_COPY\_ENA is set in the used PGID entry, a copy is sent to CPU queue specified by ANA\_AC:PGID:PGID\_MISC\_CFG.PGID\_CPU\_QU. The following illustration depicts the PGID lookup decision. Figure 42 • PGID Lookup Decision Forwarding ## Select PGID entry The following debug events can be used to observe current forwarding: ANA\_AC:PS\_STICKY:STICKY.PGID\_CPU\_MASK\_STICKY, ANA\_AC:PS\_STICKY:STICKY.NO\_L2\_L3\_FWD\_STICKY, ANA\_AC:PS\_STICKY:STICKY.IP6\_MC\_CTRL\_FLOOD\_STICKY, ANA\_AC:PS\_STICKY:STICKY.IP6\_MC\_DATA\_FLOOD\_STICKY, ANA\_AC:PS\_STICKY:STICKY.IP4\_MC\_CTRL\_FLOOD\_STICKY, ANA\_AC:PS\_STICKY:STICKY.IP4\_MC\_DATA\_FLOOD\_STICKY, ANA\_AC:PS\_STICKY:STICKY.L2\_MC\_FLOOD\_STICKY and ANA\_AC:PS\_STICKY:STICKY.UC\_FLOOD\_STICKY The events can be counted in the port statistics block by setting the corresponding counter mask:ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK ## 3.21.1.2 Source Lookup This section describes how to configure source port filtering. The following table lists the applicable registers. Table 104 • Source Table Registers Overview | Target::Register.Field | Description | Replication | |------------------------|----------------------------------|-------------| | ANA_AC:SRC:SRC_CFG | Configures source port filtering | 23 | Source port filtering for each ingress port can be configured to ensure that frames are not bridged back to the port it was received on (ANA\_AC:SRC[0-14]:SRC\_CFG). Ports part of a link aggregation group (LAG) are configured with identical source masks, with all member ports removed (bits corresponding to the member ports are cleared). If a port is part of a global link aggregation group, a filter is applied to ensure that frames received at this port are not bridged back to any of the ports in the global link aggregation group of which the source port is part (ANA\_AC:SRC[15-22]:SRC\_CFG). Local device ports part of a global link aggregation group must be cleared in the global aggregation source mask (via ANA\_AC:SRC[15-22]:SRC\_CFG). Source port filtering can be disabled when VCAP IS2 action MASK\_MODE is set to 4 (= REDIR\_PGID). Source port filtering is not applied when a frame is routed. ## 3.21.1.3 Aggregation Group Port Selection This section describes how to configure the aggregation table. The following table lists the applicable registers. Table 105 • Aggregation Table Registers Overview | Target::Register.Field | Description | Replication | |------------------------|----------------------------------------|-------------| | ANA_AC:AGGR:AGGR_CFG | Configures aggregation port filtering. | 16 | The purpose of the aggregation table is to ensure that when a frame is destined for an aggregation group, it is forwarded to exactly one of the group's member ports. The aggregation code REQ.AGGR\_CODE generated in the classifier is used to look up an aggregation mask in the aggregation table. Aggregation mask is configured in ANA\_AC:AGGR:AGGR\_CFG. For non-aggregated ports, there is a one-to-one correspondence between logical port (ANA\_CL:PORT: PORT\_ID\_CFG.LPORT\_NUM) and physical port, and the aggregation table does not change the forwarding decision. For aggregated ports, all physical ports in the aggregation group map to the same logical port, and destination entries for a logical port in the PGID table must include all physical ports, which are members of the aggregation group. Therefore, all but one LAG member port must be removed from the destination port set. For more information about link aggregation, see Link Aggregation Code Generation, page 108 ## 3.21.1.4 Global Link Aggregation Forwarding This section describes how to configure forwarding to a GLAG. The following table lists the applicable registers. Table 106 • GLAG Forward Registers Overview | Target::Register.Field | Description | Replication | |--------------------------|-----------------------------|-------------| | ANA_AC::COMMON_VSTAX_CFC | G Configures VSTAX handles. | 1 | Table 106 • GLAG Forward Registers Overview (continued) | Target::Register.Field | Description | Replication | |-------------------------|----------------------------------------|-------------| | ANA_AC:GLAG:MBR_CNT_CFG | Configures number of members per GLAG. | 8 | The device performs a final port of exit (POE) calculation in ingress device when destination is a global aggregated port. GLAG POE calculation must be enabled (ANA\_AC::COMMON\_VSTAX\_CFG.VSTAX2\_GLAG\_ENA). When enabled, GLAG forwarding uses a portion of the PGID table (addresses 75 to 138). These addresses must use UPSID, UPSPN encoding by setting the stack interpret bit. POE calculation, which selects one of the global aggregated as destination port, is shown in the following illustration. Figure 43 • GLAG Port of Exit Calculation The total number of ports part of a GLAG must be specified in ANA\_AC:GLAG:MBR\_CNT\_CFG. The corresponding destination must be configured in PGID table for each GLAG member. ## 3.21.1.5 Port Mask Operation The final destination port mask is deducted as shown in the following illustration. Figure 44 • Port Mask Operation Done selecting destination port mask # 3.21.2 Policing This section describes the functions of the policers. The following table lists the applicable registers. Table 107 • Policer Control Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------|-------------------------------------------------|-------------| | ANA_AC_POL::POL_ALL_CFG | Configures general control settings. | 1 | | ANA_AC_POL::POL_ACL_CTRL | Configures VCAP policer's mode of operation. | 32 | | ANA_AC_POL::POL_ACL_RATE_CFG | Configures VCAP policer's peak information rate | 32 | | ANA_AC_POL::POL_ACL_THRES_CFG | Configures VCAP policer's burst capacity. | 32 | Table 107 • Policer Control Registers Overview (continued) | Target::Register.Field | Description | Replication | |---------------------------------------|---------------------------------------------------------------------|---------------------------------| | ANA_AC_POL::POL_STORM_CTRL | Configures storm policer's mode of operation. | 8 | | ANA_AC_POL::POL_STORM_RATE_CFG | Configures storm policer's peak information rate | 8 | | ANA_AC_POL::POL_STORM_THRES_CFG | Configures Storm policer's burst capacity. | 8 | | ANA_AC_POL::POL_PORT_RATE_CFG | Configures port policer's peak information rate. | Per port per port policer | | ANA_AC_POL::POL_PORT_THRES_CFG_0 | Configures port policer's burst capacity. | Per port per port policer | | ANA_AC_POL::POL_PORT_THRES_CFG_1 | Configures port policer's hysteresis when used for flowcontrol. | Per port per port policer | | ANA_AC_POL:POL_PORT_CTRL:POL_PORT_CFG | Configures port policer's mode of operation. | Per port per port policer | | ANA_AC_POL:POL_PORT_CTRL:POL_PORT_GAP | Configures port policer's gap value used to correct size per frame. | Per port | | ANA_AC_POL::POL_STICKY | Captures various policer events for diagnostic purposes. | 1 | | ANA_AC_POL:COMMON_SDLB:DLB_CTRL | Configures common SDLB policer's mode of operation. | 1 | | ANA_AC_POL:COMMON_SDLB:DLB_STICKY | Captures various SDLB policer events for diagnostic purposes. | 1 | | ANA_AC_POL:SDLB:DLB_CFG | Configures SDLB policer's mode of operation. | Per SDLB | | ANA_AC_POL:SDLB:LB_CFG | Configures SDLB policer's committed and peak leaky buckets | Per SDLB<br>per leaky<br>bucket | # 3.21.2.1 Policer Hierarchy There are multiple levels of policing, which operate in configurable hierarchies, as shown in the following illustration. Figure 45 • Policer Hierarchy At most, each frame can see one ACL policing. ACL policing can occur as either outer or inner ACL-based. VCAP IS2 action IS\_INNER\_ACL allows ACL policing to occur before or after service DLB policing and service statistics. The VCAP, port, broadcast/unicast/multicast (BUM), and storm policers are single leaky bucket (SLB) policers, whereas the service and bundle policers are MEF 10.2 compliant dual leaky bucket (DLB) policers. The BUM policers group the leaky buckets into sets of three, covering broadcast, unicast, and multicast traffic. The VCAP, port and storm policers are configurable in steps of 25,040 bits per second, with a minimum of 25,040 bits per second. The BUM, service, and bundle policers can cover bandwidth in the interval between 0 Gbps and 32 Mbps, with 16 kbps granularity and between 0 Gbps and 10 Gbps with 8 Mbps granularity. The granularity scaling can be configured using the TIMESCALE\_VAL configuration parameters. The service policers can be used as queue policers for non-service traffic when ISDX is zero and ISDX\_SDLB index is zero. The queue policer operation is controlled through ANA\_L2:COMMON:FWD\_CFG.QUEUE\_DEFAULT\_SDLB\_ENA and ANA L2:COMMON:PORT\_DLB\_CFG.QUEUE\_DLB\_IDX. The bundle policers are only available for services. The index is controlled through ANA\_L2:ISDX:MISC\_CFG.BDLB\_IDX. However, it is possible to use the bundle policers as port policers for non-service traffic when ISDX is zero. The port policer operation is controlled through ANA\_L2:COMMON:FWD\_CFG.PORT\_DEFAULT\_BDLB\_ENA and ANA\_L2:COMMON:PORT\_DLB\_CFG.PORT\_DLB\_IDX. It is possible to specify a pipeline point for the service policers (ANA\_L2:ISDX:MISC\_CFG.PIPELINE\_PT). This can be used to specify where in the processing flow BUM, SDLB, and BDLB policers are active (default set to NONE, which disables any pipeline effect). The service statistics reflect the decisions made by the service policer. This implies that if a service policer marks a frame yellow, then the yellow service counter is incremented even though the frame might be discarded by one of the subsequent policers. All policers can be configured to add between –64 and 63 bytes per frame to adjust the counted frame size for inter-frame gap and/or encapsulation. ## 3.21.2.2 Service and Bundle Dual Leaky Bucket Policing Each entry in the service and bundle dual leaky bucket tables contains the fields listed in the following table. In this section, "xDLB" is used to reference register groups for both service policers (SDLB) and bundle policers (BDLB). Table 108 • Service and Bundle Dual Leaky Bucket Table Entries | Field | Bits | Description | |-------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ANA_AC_POL:xDLB:DLB_CFG.TIMESCALE_<br>VAL | _ 2 | Configures DLB policer granularity. | | ANA_AC_POL:xDLB:DLB_CFG.COLOR_AWARE_LVL | . 2 | Corresponds to MEF color mode. Specifies the highest DP level that is treated as green (that is, service frames with DP level above COLOR_AWARE_LVL are considered yellow). COLOR_AWARE_LVL == 3 corresponds to color-blind. | | ANA_AC_POL:xDLB:DLB_CFG.COUPLING_MODE | 1 | MEF Coupling Flag (CF). Depending on the setting of COUPLING_MODE, LB_CFG[0] and LB_CFG[1] must be configured as follows: If COUPLING_MODE = 0: LB_CFG[0].RATE_VAL must be configured to MEF CIR. LB_CFG[0].THRES_VAL must be configured to MEF CBS. LB_CFG[1].RATE_VAL must be configured to MEF EIR. LB_CFG[1].THRES_VAL must be configured to MEF EBS. If COUPLING_MODE = 1: LB_CFG[0].RATE_VAL must be configured to MEF CIR. LB_CFG[0].THRES_VAL must be configured to MEF CBS. LB_CFG[1].RATE_VAL must be configured to MEF CBS. LB_CFG[1].RATE_VAL must be configured to MEF EIR + MEF CIR. LB_CFG[1].THRES_VAL must be configured to MEF EBS + MEF CBS. | | ANA_AC_POL:xDLB:DLB_CFG.CIR_INC_DP _VAL | 2 | Controls how much drop precedence (DP) is incremented for excess traffic. | | ANA_AC_POL:xDLB:DLB_CFG.GAP_VAL | 7 | Configures the leaky bucket calculation to include or exclude preamble, inter-frame gap and optional encapsulation through configuration. | | ANA_AC_POL:xDLB:LB_CFG[0].THRES_VAL | . 7 | Configures committed burst size (CBS). | | ANA_AC_POL:xDLB:LB_CFG[1].THRES_VAL | . 7 | Configures DLB's second threshold. See COUPLING_MODE. | | ANA_AC_POL:xDLB:LB_CFG[0].RATE_VAL | 11 | Configures DLB's second rate. See COUPLING_MODE. | Each MEF DLB policer supports the following configurations. - Two rates. Specified in 2048 steps (ANA\_AC\_POL:xDLB:LB\_CFG[0-1].RATE\_VAL). - Two burst sizes. Specified in steps of 2 kilobytes (up to 254 kilobytes) (ANA\_AC\_POL:xDLB:LB\_CFG[0-1].THRES\_VAL). - Color mode: Color-blind or color-aware. Specifies a DP level to separate traffic as green or yellow (ANA\_AC\_POL:xDLB:DLB\_CFG.COLOR\_AWARE\_LVL). Frames classified with REQ.DP below or equal to COLOR\_AWARE\_LVL are treated as green. Frames with REQ.DP above COLOR\_AWARE\_LVL are treated as yellow. A policer is color-blind if configured with a COLOR\_AWARE\_LVL of 3. - Coupling flag. Coupled or uncoupled (ANA\_AC\_POL:xDLB:DLB\_CFG.COUPLING\_MODE). - Change DP level. The increase to REQ.DP level when CIR rate is exceeded (ANA\_AC\_POL:xDLB:DLB\_CFG.CIR\_INC\_DP\_VAL). In addition, the following parameters can also be configured per policer: - Leaky bucket calculations can be configured to include or exclude preamble, inter-frame gap and an optional encapsulation (ANA AC POL:SDLB:DLB CFG.GAP VAL). - Policers can be configured to police CPU traffic, front port forwarded traffic, or both (ANA\_AC\_POL:xDLB:DLB\_CFG.TRAFFIC\_TYPE\_MASK). The DLB policers must also be enabled (ANA\_AC\_POL:COMMON\_xDLB:DLB\_CTRL.LEAK\_ENA and ANA AC POL:COMMON xDLB:DLB CTRL.DLB ADD ENA). The DLB policer unit size can be adjusted (ANA\_AC\_POL:COMMON\_xDLB: DLB CTRL.BASE TICK CNT) to configure various base units (= smallest rate granularity). The following DLB policer debug events are available: - Dropping traffic due to DLB policer can be identified (ANA\_AC\_POL:POL\_ALL\_CFG: POL\_STICKY.POL\_DLB\_DROP\_STICKY). - Traffic received without triggering CIR and PIR policing (ANA AC POL:COMMON xDLB:DLB STICKY.CIR PIR OPEN STICKY). - Committed information rate exceeded (ANA AC POL:COMMON xDLB:DLB STICKY.CIR EXCEEDED STICKY). - Peak information rate exceeded (ANA\_AC\_POL:COMMON\_xDLB:DLB\_STICKY.PIR\_EXCEEDED\_STICKY). ## 3.21.2.3 BUM Policing Each entry in the BUM single leaky bucket table contains the following fields. Table 109 • BUM Single Leaky Bucket Table Entries | Field | Bits | Description | |---------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------| | ANA_AC_POL:BUM_SLB:SLB_CFG.TIMESCALE_VAL | 2 | Configures policer rate granularity. | | ANA_AC_POL:BUM_SLB:SLB_CFG.CIR_INC_DP_VAL | 2 | Controls how much drop precedence (DP) is incremented for excess traffic. | | ANA_AC_POL:BUM_SLB:SLB_CFG.GAP_VAL | 7 | Configures the leaky bucket calculation to include or exclude preamble, inter-frame gap and optional encapsulation through configuration. | | ANA_AC_POL:BUM_SLB:LB_CFG[2:0].THRES_VAL | 3 x 7 | Configures burst size. | | ANA_AC_POL:BUM_SLB:LB_CFG[2:0].RATE_VAL | 3 x 11 | Configures rate. | | ANA_AC_POL:BUM_SLB:SLB_CFG.ENCAP_DATA_DIS | 1 | Configures if stripped encapsulation data (normalized data) is policed by the policer. | | ANA_AC_POL:BUM_SLB:MISC_CFG.FRAME_RATE_E NA | 1 | Configures frame rate operation. | The BUM policers are indexed through the VLAN table (ANA\_L3:VLAN:BUM\_CFG.BUM\_SLB\_IDX). This indexing can be overruled for services through the ISDX table (ANA\_L2:ISDX:MISC\_CFG.BUM\_SLB\_IDX and ANA\_L2:ISDX:MISC\_CFG.BUM\_SLB\_ENA). Each BUM policer contains three leaky buckets. Rates and thresholds are configured through ANA\_AC\_POL:BUM\_SLB:LB\_CFG). Traffic for the three BUM leaky buckets is configurable in ANA\_AC\_POL:COMMON\_BUM\_SLB:TRAFFIC\_MASK\_CFG. This provides a flexible allocation of traffic for the policers. For example, it is possible to have BUM configured as: - Leaky bucket 0: Broadcast traffic (ANA AC POL:COMMON BUM\_SLB:TRAFFIC\_MASK\_CFG[0].TRAFFIC\_TYPE\_MASK = 1) - Leaky bucket 1: Unknown unicast traffic (ANA AC POL:COMMON BUM SLB:TRAFFIC MASK CFG[1].TRAFFIC TYPE MASK = 4) - Leaky bucket 2: Unknown multicast traffic (ANA\_AC\_POL:COMMON\_BUM\_SLB:TRAFFIC\_MASK\_CFG[2]. TRAFFIC\_TYPE\_MASK = 2) BUM policers can be configured as frame-based policers (ANA\_AC\_POL:BUM\_SLB:MISC\_CFG.FRAME\_RATE\_ENA). The BUM statistics count on the following events (configured through ANA\_AC:STAT\_GLOBAL\_CFG\_BUM:STAT\_GLOBAL\_EVENT\_MASK): - · Bit 0: Count Broadcast traffic discarded by BUM policer - · Bit 1: Count Multicast traffic discarded by BUM policer - Bit 2: Count Unicast traffic discarded by BUM policer - Bit 3: Count Broadcast traffic applicable for BUM policer, but not discarded - Bit 4: Count Multicast traffic applicable for BUM policer, but not discarded - Bit 5: Count Unicast traffic applicable for BUM policer, but not discarded. ## 3.21.2.4 ACL Policing Each ACL policer entry contains the fields listed in the following table. Table 110 • ACL Policer Table Entries | Field | Bits | Description | |-----------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------| | ACL_TRAFFIC_TYPE_MASK | 2 | Configures the traffic types to be taken into account by the policer. | | FRAME_RATE_ENA | 1 | Configures frame rate mode for the ACL policer, where rates are measured in frames per second instead of bytes per second. | | DP_BYPASS_LVL | 2 | Controls the lowest DP level that is taken into account. That is, traffic with DP below this value is ignored and not policed. | | GAP_VALUE | 7 | Configures the leaky bucket calculation to include or exclude preamble, inter-frame gap and optional encapsulation through configuration. | | ACL_THRES | 6 | Configures ACL policer burst capacity. | | ACL_RATE | 17 | Configures ACL policer rate. | At most, a frame can trigger one ACL policer. ACL policers are enabled by specifying a rate in ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_RATE\_CFG.ACL\_RATE and also enabled by a VCAP IS2 hit. For more information, see VCAP IS2, page 56. The policer burst capacity can be specified with 4K granularity (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_THRES\_CFG.ACL\_THRES). The following parameters can also be configured per policer. - The leaky bucket calculation can be configured to include or exclude preamble, inter-frame gap and an optional encapsulation (ANA AC POL:POL ALL CFG:POL ACL CTRL.GAP VALUE). - Traffic with DP level below a certain level can be configured to bypass the policers (ANA AC POL:POL ALL CFG:POL ACL CTRL.DP BYPASS LVL). - Each policer can be configured to measure frame rates instead of bit rates (ANA AC POL:POL ALL CFG:POL ACL CTRL.FRAME RATE ENA). - Each policer can be configured to operate on frames towards CPU and/or front ports (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_CTRL.ACL\_TRAFFIC\_TYPE\_MASK). Traffic dropped by an ACL policer can be counted in the ACL statistics block and optionally also in the port statistic block. For more information, see Analyzer Statistics, page 194. The following ACL policer debug events are available: - Bypass of policer due to pipeline handling can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_ACL\_PT\_BYPASS\_STICKY). - Bypass of policer due to bypass level can be identified (ANA AC POL:POL ALL CFG:POL STICKY.POL ACL BYPASS STICKY). - Dropping of traffic due to ACL policer can be identified (ANA AC POL:POL ALL CFG:POL STICKY.POL ACL DROP STICKY). - Policers that are active but not closed can be identified (ANA AC POL:POL ALL CFG:POL STICKY.POL ACL ACTIVE STICKY). For example, to use ACL policers to limit traffic to CPU only, the following configuration is required: - Set up a VCAP S2 rule to enable ACL policer 5. - Configure ACL policer 5 to only allow 100 frames per second towards CPU: # the rate is 10 times the configured value ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_RATE\_CFG[5].ACL\_RATE = 10 ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_CTRL[5].FRAME\_RATE\_ENA = 1 - Do not accept burst: ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_THRES\_CFG[5].ACL\_THRES = 0 - Only police traffic towards CPU: ANA\_AC\_POL:POL\_ALL\_CFG:POL\_ACL\_CTRL[5].ACL\_TRAFFIC\_TYPE\_MASK = 2 ## 3.21.2.5 Priority Policing The configuration parameters for priority policing are listed in the following table. Table 111 • Priority Policer Table Entry | Field | Description | |----------------------------------------|--------------------------------------------------------------| | ANA_L2::FWD.QUEUE_DEFAULT_SDLB_ENA | Enables priority policers for non-service frames. | | ANA_L2:PORT:PORT_DLB_CFG.QUEUE_DLB_IDX | Specifies which DLB policers are used for priority policing. | Non-service frames (which ISDX = 0 and ANA\_L2:ISDX:DLB\_CFG.DLB\_IDX = 0) can use the service policers as priority policers. This is enabled in ANA\_L2::FWD\_CFG.QUEUE\_DEFAULT\_SDLB\_ENA. The frame's ingress port and classified QoS class select the priority policer. The configuration of the priority policer follows the configuration of the service policers. For more information, see Service and Bundle Dual Leaky Bucket Policing, page 188. Note that a DLB policer index enabled by VCAP IS2 action ACL\_MAC[16] takes precedence over the priority policing. In that case, the frame is policed by the VCAP selected policer and not the priority policer. ## 3.21.2.6 Port Policing Each port policer entry contains the fields listed in the following table. Table 112 • Port Policer Table Entry | Field | Bits | Description | |--------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------| | TRAFFIC_TYPE_MASK | 8 | Configures the traffic types to be taken into account by the policer. | | FRAME_RATE_ENA | 1 | Configures frame rate mode for the port policer, where rates are measured in frames per second instead of bytes per second. | | LIMIT_NONCPU_TRAFFIC_ENA | 1 | Configures how policing affects traffic towards front ports. | | LIMIT_CPU_TRAFFIC_ENA | 1 | Configures how policing affects traffic towards CPU. | | CPU_QU_MASK | 8 | Configures policing of frames to the individual CPU queues for the port policer (see TRAFFIC_TYPE_MASK). | | FC_ENA | 1 | Configures port policer to trigger flow control. | | FC_STATE | 1 | Current flow control state. | | DP_BYPASS_LVL | 2 | Controls the lowest DP level that is taken into account. That is, traffic with DP below this value is ignored and not policed. | | GAP_VALUE | 7 | Configures the leaky bucket calculation to include or exclude preamble, inter-frame gap and optional encapsulation through configuration. | | PORT_THRES0 | 6 | Configures port policer burst capacity. | | PORT_THRES1 | 6 | Configures port policer hysteresis size when a port policer is in flow control mode (see FC_ENA). | | PORT_RATE | 17 | Configures port policer rate. | Frames applicable for policing are any frames received by the MAC and forwarded to the classifier. Short frames (less than 148 bytes) with errors, pause frames, or MAC control frames are not forwarded by the MAC and therefore not accounted for in the policers, That is, they are not policed and do not add to the rate measured by the policers. Port policers are enabled by configuring the traffic type to be policed (ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_CFG.TRAFFIC\_TYPE\_MASK) and specifying a corresponding rate (ANA\_AC\_POL:POL\_PORT\_CFG:POL\_PORT\_RATE\_CFG.PORT\_RATE). The policer burst capacity can be specified with 4K granularity (ANA\_AC\_POL:POL\_PORT\_CFG:POL\_PORT\_THRES\_CFG\_0.PORT\_THRES0). Policing of traffic destined for CPU port or ports can be controlled (in ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_CFG.TRAFFIC\_TYPE\_MASK(7) = 0 and CPU bypass mask in ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_CFG.CPU\_QU\_MASK). Port policers can individually be configured to affect frames towards CPU ports (ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_CFG.LIMIT\_CPU\_TRAFFIC\_ENA) or front ports (ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_CFG.LIMIT\_NONCPU\_TRAFFIC\_ENA). The port policers can be configured for either serial or parallel operation (ANA\_AC\_POL::POL\_ALL\_CFG.PORT\_POL\_IN\_PARALLEL\_ENA): - Serial. The policers are checked one after another. If a policer is closed, the frame is discarded and the subsequent policer buckets are not updated with the frame. - Parallel. The policers are working in parallel independently of each other. Each frame is added to a policer bucket if the policer is open, otherwise the frame is discarded. A frame may be added to one policer although another policer is closed. The following parameters can also be configured per policer. - The leaky bucket calculation can be configured to include or exclude preamble, inter-frame gap and an optional encapsulation (ANA\_AC\_POL:POL\_PORT\_CTRL:POL\_PORT\_GAP.GAP\_VALUE). - Each policer can be configured to measure frame rates instead of bit rates (ANA AC POL:POL PORT CTRL:POL PORT CFG.FRAME RATE ENA). - Traffic with DP level below a certain level can be configured to bypass the policers (ANA AC POL:POL PORT CTRL:POL PORT CFG.DP BYPASS LVL). By default, a policer discards frames (to the affected port type: CPU and/or front port or ports) while the policer is closed. A discarded frame is not forwarded to any ports (including the CPU). However, each port policer has the option to run in flow control where the policer instead of discarding frames instructs the MAC to issue flow control pause frames (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_PORT\_FC\_CFG.FC\_ENA). When operating in Flow control mode it is possible to specify a hysteresis, which controls when the policer can re-open after having closed (ANA\_AC\_POL:POL\_PORT\_CFG:POL\_PORT\_THRES\_CFG\_1. PORT\_THRES1). The current flow control state is accessible (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_PORT\_FC\_CFG.FC\_STATE). **Note:** Flow control signaling out of ANA\_AC must be enabled (ANA\_AC\_POL::POL\_ALL\_CFG.PORT\_FC\_ENA). To improve fairness between small and large frames being policed by the same policer a hysteresis can be specified for drop mode (ANA AC POL:POL PORT CFG: POL\_PORT\_THRES\_CFG\_1.PORT\_THRES1), which controls when the policer can re-open after having closed. By setting it to a value larger than the maximum transmission unit, it can be guaranteed that when the policer opens again, all frames have the same chance of being accepted. Port policers can be configured operate on logical ports instead of physical ports (ANA\_AC\_POL::POL\_ALL\_CFG.LPORT\_POLICE\_ENA) and thereby allow policing of aggregated port bandwidth. Traffic dropped by a policer can be counted by the port statistic block. The following port policer debug events are available. - Bypass of policer due to pipeline handling can be identified (ANA AC POL:POL ALL CFG:POL STICKY.POL PORT PT BYPASS STICKY). - Bypass of policer due to DP bypass level can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_BYPASS\_STICKY). - Dropping of traffic towards CPU due to policer can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_DROP\_CPU\_STICKY). - Dropping of traffic towards front port due to policer can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_DROP\_FWD\_STICKY). - Policers that are active but not closed can be identified per policer (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_ACTIVE\_STICKY). - Policer triggering flow control can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_FC\_STICKY). - Policer leaving flow control state can be identified (ANA\_AC\_POL:POL\_ALL\_CFG:POL\_STICKY.POL\_PORT\_FC\_CLEAR\_STICKY). ## 3.21.2.7 Storm Policing Each storm policer entry contains the fields in the following table. The fields are all located within the ANA AC POL:POL ALL CFG register group. Table 113 • Storm Policer Table Entry | Field | Bits | Description | |--------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------| | STORM_TRAFFIC_TYPE_MASK | 8 | Configures the traffic types to be taken into account by the policer. | | STORM_FRAME_RATE_ENA | 1 | Configures frame rate mode for the ACL policer, where rates are measured in frames per second instead of bytes per second. | | STORM_LIMIT_NONCPU_TRAFFIC_ENA | 1 | Configures how policing affects traffic towards front ports. | | STORM_LIMIT_CPU_TRAFFIC_ENA | 1 | Configures how policing affects traffic towards CPU. | | STORM_CPU_QU_MASK | 8 | Configures policing of frames to the individual CPU queues for the port policer (see TRAFFIC_TYPE_MASK). | | STORM_GAP_VALUE | 7 | Configures the leaky bucket calculation to include or exclude preamble, inter-frame gap and optional encapsulation through configuration | | STORM_THRES | 6 | Configures storm policer burst capacity. | | STORM_RATE | 17 | Configures storm policer rate. | Frames applicable for policing are any frame received by the MAC and forwarded to the classifier. Short frames (less than 148 bytes) with errors, pause frames, or MAC control frames are not forwarded by the MAC and therefore not accounted for in the policers. That is, they are not policed and do not add to the rate measured by the policers. Storm policers are enabled by configuring the traffic type to be policed (POL\_STORM\_CTRL.STORM\_TRAFFIC\_TYPE\_MASK) and specifying a corresponding rate (POL\_STORM\_RATE\_CFG.STORM\_RATE). The policer burst capacity can be specified with 4K granularity (POL STORM THRES CFG). Policing of traffic destined for CPU port or ports can be controlled (POL\_STORM\_CTRL.STORM\_TRAFFIC\_TYPE\_MASK(7) = 0 and CPU bypass mask in POL\_STORM\_CTRL.STORM\_CPU\_QU\_MASK). Storm policers can be configured individually to affect frames towards CPU ports (POL\_STORM\_CTRL.STORM\_LIMIT\_CPU\_TRAFFIC\_ENA) or front ports (POL\_STORM\_CTRL.STORM\_LIMIT\_NONCPU\_TRAFFIC\_ENA). The following parameters can also be configured per policer. - Leaky bucket calculation can be configured to include or exclude preamble, inter-frame gap, and an optional encapsulation (POL ALL CFG.STORM GAP VALUE). - Each policer can be configured to measure frame rates instead of bit rates (POL\_STORM\_CTRL.STORM\_FRAME\_RATE\_ENA). Traffic dropped by a storm policer can be counted by the port statistic block. The following storm policer debug events are available. - Dropping of traffic towards CPU due to policer can be identified (POL STICKY.POL STORM DROP CPU STICKY). - Dropping of traffic towards front port due to policer can be identified (POL\_STICKY.POL\_STORM\_DROP\_FWD\_STICKY). - Policers that are active but not closed can be identified per policer (POL STICKY.POL STORM ACTIVE STICKY). ## 3.21.3 Analyzer Statistics This section describes how to configure and collect statistics. There are five statistics counter blocks in the analyzer: - · Port statistics: Four 40-bit counters available are for each port. - Queue statistics: Two 40-bit counters are available for each queue. - BUM policer statistics: Six 40-bit counters are available for each BUM policer. - ACL policer statistics: Two 40-bit counters are available for each ACL policer. - Ingress router leg statistics: Eight IPv4 40-bit counters and eight IPv6 40-bit counters are available for each ingress router leg. - Egress router leg statistics: Eight IPv4 40-bit counters and eight IPv6 40-bit counters are available for each egress router leg. Counters can be set up to count frames or bytes based on configurable criteria. This is described in the following sections. ## 3.21.3.1 Port Statistics The following table lists the applicable port statistics registers. Table 114 • Analyzer Port Statistics Register Overview | Target::Register.Field | Description | Replication | |--------------------------------------------------------|-------------------------------------------------------------------|--------------| | ANA_AC:STAT_GLOBAL_CFG_PORT.<br>STAT_GLOBAL_EVENT_MASK | Configures global event mask per counter. | 4 | | ANA_AC:STAT_GLOBAL_CFG_PORT:S<br>TAT_RESET.RESET | Initializes or resets all statistic counters and the sticky bits. | 1 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_<br>CFG. CFG_PRIO_MASK | Configures counting of frames with certain priorities. | per port × 4 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_CFG. CFG_CNT_FRM_TYPE | Configures the frame type to be counted. | per port× 4 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_CFG. CFG_CNT_BYTE | Configures counting of bytes or frames. | per port × 4 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_<br>LSB_CNT | Least significant 32 bits. | per port × 4 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_<br>MSB_CNT | Most significant 8 bits. | per port × 4 | | ANA_AC:STAT_CNT_CFG_PORT.STAT_<br>EVENTS_STICKY | Sticky bits for counter events. | per port | The port statistics block allows counting of a wide variety of frame events. These are represented by a 12-bit event mask: - Bits 0–3 represent any stick bit contribution from preceding blocks in ANA. - Bits 4–7 represent port policer events. - Bits 8-11 represent storm and ACL policer events and loopback frames. The propagation of the event mask from the preceding blocks in the analyzer to ANA\_AC is shown in the following illustration, except for bits 8–11. See ANA AC:STAT GLOBAL CFG PORT:STAT GLOBAL EVENT MASK.GLOBAL EVENT MASK. Figure 46 • Sticky Events Available as Global Events The global events [3:0] are typically allocated for detected control frames, frames dropped due to wrong configuration, frames dropped due to VLAN filtering, and so on. As an example, a particular event that is normally only of interest during debug, ANA\_L2: STICKY.VLAN\_IGNORE\_STICKY can be configured to be the global event 0 in ANA L2:STICKY MASK.VLAN IGNORE STICKY MASK(0). The following illustration shows the configuration and status available for each port statistics counter. Figure 47 • Port Statistics Counters Before the statistic counters can be used, they must be initialized to clear all counter values and sticky bits (ANA AC:STAT GLOBAL CFG PORT:STAT RESET.RESET). For each counter the type of frames that are counted must be configured (ANA\_AC:STAT\_CNT\_CFG\_PORT.STAT\_CFG.CFG\_CNT\_FRM\_TYPE). Note: Frames without any destination are seen by the port statistics block as aborted. Each counter must be configured whether frames or bytes are counted. (ANA\_AC:STAT\_CNT\_CFG\_PORT.STAT\_CFG.CFG\_CNT\_BYTE). It is possible to limit counting to certain priorities (ANA\_AC:STAT\_CNT\_CFG\_PORT.STAT\_CFG.CFG\_PRIO\_MASK). Counter events that can trigger counting can be selected among the global events (ANA\_AC:STAT\_GLOBAL\_CFG\_PORT. STAT\_GLOBAL\_EVENT\_MASK). There is one common event mask for each of the four counter sets. Each 40-bit counter consists of an MSB part and an LSB part (ANA\_AC:STAT\_CNT\_CFG\_PORT. STAT\_MSB\_CNT and ANA\_AC:STAT\_CNT\_CFG\_PORT.STAT\_LSB\_CNT). The MSB part of the counter is latched to a shadow register when the LSB part is read. As a result, the LSB part must always be read first, and the MSB part must be read immediately after the LSB part. When writing to the counter, the LSB part must be written first, followed by the MSB part. The following pseudo code shows the port statistics functionality. ``` for (port_counter_idx = 0; port_counter_idx < 4; port_counter_idx++) {</pre> if (STAT_CNT_CFG_PORT[frame.igr_port].STAT_CFG[port_counter_idx].CFG_PRIO_MASK[ frame.prio]) { count = FALSE; global_event_mask = STAT_GLOBAL_EVENT_MASK[port_counter_idx].GLOBAL_EVENT_MASK; event_match = (STAT_GLOBAL_EVENT_MASK[port_counter_idx].GLOBAL_EVENT_MASK δ frame.event_mask); switch (STAT_CNT_CFG_PORT[frame.igr_port].STAT_CFG[port_counter_idx].CFG_CNT_FRM_TY PE) { case 0x0: if (!frame.error && !event_match) count = 1; break; case 0x1: if (!frame.error && event_match) count = 1; case 0x2: if (frame.error && event_match) count = 1; break; case 0x3: if (event_match) count = 1; break; case 0x4: if (frame.error && !event_match) count = 1; break; case 0x5: if (frame.error) count = 1; break; if (count) { (STAT_CNT_CFG_PORT[frame.igr_port].STAT_CFG[port_counter_idx].CFG_CNT_BYTE) { STAT_xSB_CNT[port_counter_idx] += frame.bytes; } else { STAT_xSB_CNT[port_counter_idx]++; } } } ``` Example: To set up port counter 3 to count bytes filtered by VLAN ingress filter, the following configuration is required. - Enable VLAN drop events as global event 3: - Set - ANA\_L3:L3\_STICKY\_MASK:VLAN\_MSTP\_STICKY\_MASK[3].VLAN\_IGR\_FILTER\_STICKY\_MASK = 1. - Initialize counters: - Set ANA AC:STAT GLOBAL CFG PORT:STAT RESET.RESET = 1. - Set up port counters. For each active Ethernet port: Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[3].CFG\_CNT\_FRM\_TYPE = 3. Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[3].CFG\_CNT\_BYTE = 1. Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[3].CFG\_PRIO\_MASK = 0xFF. - Enable global event 3 as trigger: Set ANA\_AC:STAT\_GLOBAL\_CFG\_PORT[3]. STAT\_GLOBAL\_EVENT\_MASK = 8. Example: To set up port counter 0 to count frames dropped by port policer, the following configuration is required. - Set up port counters. For each active Ethernet port: Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[0].CFG\_CNT\_FRM\_TYPE = 3. Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[0].CFG\_CNT\_BYTE = 0. Set ANA\_AC:STAT\_CNT\_CFG\_PORT[port].STAT\_CFG[0].CFG\_PRIO\_MASK = 0xFF. - Enable global event 4 to 7 as trigger: Set ANA AC:STAT GLOBAL CFG PORT[0]. STAT GLOBAL EVENT MASK = 0xF0. ### 3.21.3.2 Queue Statistics The following table lists the applicable queue statistics registers. Table 115 • Queue Statistics Registers Overview | Target::Register.Field | Description | Replication | |---------------------------------------------------------|------------------------------------------------------------------------|---------------| | ANA_AC:STAT_GLOBAL_CFG_QUEUE:<br>STAT_GLOBAL_CFG | Configures counting of bytes or frames per queue (= port × 8 + iprio). | 2 | | ANA_AC:STAT_GLOBAL_CFG_QUEUE:<br>STAT_GLOBAL_EVENT_MASK | Configures global event mask per queue (= port × 8 + iprio). | 2 | | ANA_AC:STAT_CNT_CFG_QUEUE.STAT_LSB_CNT | Least significant 32 bits of counters per queue. | per queue × 2 | | ANA_AC:STAT_CNT_CFG_QUEUE.STAT_MSB_CNT | Most significant 8 bits of counters per queue. | per queue × 2 | The following illustration shows the configuration and status available for each queue statistics counter. Figure 48 • Queue Statistics Each counter type must be configured to count either bytes or frames (ANA AC:STAT GLOBAL CFG QUEUE: STAT GLOBAL CFG.CFG CNT BYTE). ACL events that can trigger counting can be selected among the following events: - · Count traffic applicable for queue policer, but not discarded - Count traffic discarded by queue policer There is one common event mask for each of the two queue counter types (ANA\_AC:STAT\_GLOBAL\_CFG\_QUEUE:STAT\_GLOBAL\_EVENT\_MASK). Each 40-bit counter consists of an MSB part and an LSB part (ANA\_AC:STAT\_CNT\_CFG\_QUEUE.STAT\_MSB\_CNT and ANA\_AC:STAT\_CNT\_CFG\_QUEUE.STAT\_LSB\_CNT). The MSB part of the counter is latched to a shadow register when the LSB part is read. As a result, the LSB part must always be read first, and the MSB part must be read immediately after the LSB part. When writing to the counter, the MSB part must be written first, followed by the LSB part. ## 3.21.3.3 Broadcast, Unicast, Multicast (BUM) Policer Statistics The following table lists the applicable BUM policer statistics registers. Table 116 • BUM Policer Statistics Registers Overview | Target::Register.Field | Description | Replication | |--------------------------------------------------------|--------------------------------------------------------------|---------------------------| | ANA_AC:STAT_GLOBAL_CFG_BUM<br>: STAT_GLOBAL_CFG | Configures counting bytes or frames per BUM policer index. | 2 | | ANA_AC:STAT_GLOBAL_CFG_BUM<br>: STAT_GLOBAL_EVENT_MASK | Configures global event mask per BUM policer index. | 2 | | ANA_AC:STAT_CNT_CFG_BUM.ST<br>AT_LSB_CNT | Least significant 32 bits of counters per BUM policer index. | per BUM policer index × 2 | | ANA_AC:STAT_CNT_CFG_BUM.ST<br>AT_MSB_CNT | Most significant 8 bits of counters per BUM policer index. | per BUM policer index × 2 | The following illustration shows the configuration and status available for each BUM policer. Figure 49 • BUM Policer Statistics Each of the two counters in a counter set can be configured to which frames are counted and if bytes or frames are counted. This configuration is shared among all counter sets. The BUM event mask supports counting the following frame types: - · Broadcast traffic discarded by BUM policer - Multicast traffic discarded by BUM policer - · Unicast traffic discarded by BUM policer - · Broadcast traffic applicable for BUM policer but not discarded - Multicast traffic applicable for BUM policer but not discarded - Unicast traffic applicable for BUM policer but not discarded The event mask is configured in ANA\_AC:STAT\_GLOBAL\_CFG\_BUM:STAT\_GLOBAL\_EVENT\_MASK. Each 40-bit counter consists of an MSB part and an LSB part (ANA\_AC:STAT\_CNT\_CFG\_BUM.STAT\_MSB\_CNT and ANA\_AC:STAT\_CNT\_CFG\_BUM.STAT\_LSB\_CNT). The MSB part of the counter is latched to a shadow register when the LSB part is read. As a result, the LSB part must always be read first, and the MSB part must be read immediately after the LSB part. When writing to the counter, the MSB part must be written first, followed by the LSB part. #### 3.21.3.4 ACL Policer Statistics The following table lists the applicable ACL policer statistics registers. Table 117 • ACL Policer Statistics Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------------------------------|---------------------------------------------------------------|------------------------------| | ANA_AC:STAT_GLOBAL_CFG_ACL:<br>STAT_GLOBAL_CFG | Configures counting of bytes or frames per ACL policer index. | 2 | | ANA_AC:STAT_GLOBAL_CFG_ACL:<br>STAT_GLOBAL_EVENT_MASK | Configures global event mask per ACL policer index. | 2 | | ANA_AC:STAT_CNT_CFG_ACL.STAT_LSB_CNT | Least significant 32 bits of counters per ACL policer index. | per ACL policer<br>index × 2 | | ANA_AC:STAT_CNT_CFG_ACL.STAT_MSB_CNT | Most significant 8 bits of counters per ACL policer index. | per ACL policer<br>index × 2 | The following illustration shows the configuration and status available for each ACL policer statistics counter. Figure 50 • ACL Policer Statistics Each counter type must be configured whether bytes or frames are counted (ANA\_AC:STAT\_GLOBAL\_CFG\_ACL: STAT\_GLOBAL\_CFG.CFG\_CNT\_BYTE). ACL events that can trigger counting can be selected among the following events. If an ACL policer is triggered by an IS2 action, with IS INNER ACL = 1, it is termed "inner". Otherwise, it is termed "outer". - · Count CPU traffic applicable for outer ACL policer, but not discarded - · Count front port traffic applicable for outer ACL policer, but not discarded - Count CPU traffic discarded by outer ACL policer - · Count front port traffic discarded by outer ACL policer - Count CPU traffic applicable for inner ACL policer, but not discarded - · Count front port traffic applicable for inner ACL policer, but not discarded - · Count CPU traffic discarded by inner ACL policer - · Count front port traffic discarded by inner ACL policer There is one common event mask for each of the two ACL policer counter types (ANA\_AC:STAT\_GLOBAL\_CFG\_ACL:STAT\_GLOBAL\_EVENT\_MASK). Each 40-bit counter consists of an MSB part and an LSB part (ANA AC:STAT CNT CFG ACL.STAT MSB CNT and ANA\_AC:STAT\_CNT\_CFG\_ACL.STAT\_LSB\_CNT). The MSB part of the counter is latched to a shadow register when the LSB part is read. As a result, the LSB part must always be read first, and the MSB part must be read immediately after the LSB part. When writing to the counter, the MSB part must be written first, followed by the LSB part. ### 3.21.3.5 Routing Statistics The following table lists the applicable routing statistics registers. Table 118 • Analyzer Routing Statistics Registers Overview | Target::Register.Field | Description | Replication | |---------------------------------------------------------|------------------------------------------------------------------------|-----------------------------| | ANA_AC:STAT_GLOBAL_CFG_IRLEG:<br>STAT_GLOBAL_CFG | Configures counting of bytes or frames per ingress router leg counter. | 8 | | ANA_AC:STAT_GLOBAL_CFG_IRLEG:<br>STAT_GLOBAL_EVENT_MASK | Configures global event mask per ingress router leg counter. | 8 | | ANA_AC:STAT_CNT_CFG_IRLEG.STAT_LSB_CNT | Least significant 32 bits of ingress router leg counters. | Per RLEG per IP_version × 8 | | ANA_AC:STAT_CNT_CFG_IRLEG.STAT_MSB_CNT | Most significant 8 bits of ingress router leg counters. | Per RLEG per IP_version × 8 | | ANA_AC:STAT_GLOBAL_CFG_ERLEG:<br>STAT_GLOBAL_CFG | Configures counting of bytes or frames per egress router leg counter. | 8 | | ANA_AC:STAT_GLOBAL_CFG_ERLEG:<br>STAT_GLOBAL_EVENT_MASK | Configures global event mask per egress router leg counter. | 8 | | ANA_AC:STAT_CNT_CFG_ERLEG.STAT_LSB _CNT | Least significant 32 bits of egress router leg counters. | Per RLEG per IP_version × 8 | | ANA_AC:STAT_CNT_CFG_ERLEG.STAT_MSB<br>_CNT | Most significant 8 bits of egress router leg counters. | Per RLEG per IP_version × 8 | The following illustration shows the configuration and status available for ingress router leg and egress router leg statistics counter sets. For this device, RLEG\_CNT is 64. Figure 51 • Ingress and Egress Routing Statistics per Router Leg per IP Version Each counter type must be configured if bytes or frames are counted (ANA\_AC:STAT\_GLOBAL\_CFG\_IRLEG: STAT\_GLOBAL\_CFG\_CNT\_BYTE and ANA\_AC:STAT\_GLOBAL\_CFG\_ERLEG: STAT\_GLOBAL\_CFG\_CNT\_BYTE) Ingress router leg counter events that can trigger counting can be selected among the following events: - acl\_discarded frame applicable for routing but discarded due to VCAP IS2 ingress discard action (first VCAP IS2 lookup with action RT\_ENA cleared). - received IP unicast traffic frame applicable for routing (hitting a router leg). - received IP multicast traffic frame applicable for routing (hitting a router leg). - unicast routed frame is unicast routed. - · multicast routed frame is multicast routed - ip\_multicast\_rpf\_discarded frame discarded due to failed Reverse Path Forwarding check (frame not received from configured interface) - ip TTL discarded frame discarded due to TTL <2.</li> There is one common event mask for each of the eight IRLEG counter types (ANA\_AC:STAT\_GLOBAL\_CFG\_IRLEG:STAT\_GLOBAL\_EVENT\_MASK). Egress router leg counter events that can trigger counting can be selected among the following events: - acl\_discarded frame applicable for routing but discarded due to VCAP IS2 egress discard action (second VCAP IS2 lookup with action RT\_ENA cleared). - unicast routed traffic frame is unicast routed. - multicast routed traffic frame is multicast routed. - ip multicast switched traffic frame is bridged within ingress VLAN. - ip multicast TTL discarded frame discarded due to TTL less than ERLEG configured TTL value. There is a common event mask for each of the eight ERLEG counter types (ANA AC:STAT GLOBAL CFG ERLEG:STAT GLOBAL EVENT MASK). Each 40-bit counter consists of an MSB part (ANA\_AC:STAT\_CNT\_CFG\_IRLEG.STAT\_MSB\_CNT or ANA\_AC:STAT\_CNT\_CFG\_ERLEG.STAT\_MSB\_CNT) and an LSB part (ANA\_AC:STAT\_CNT\_CFG\_IRLEG.STAT\_LSB\_CNT or ANA\_AC:STAT\_CNT\_CFG\_ERLEG.STAT\_LSB\_CNT). The MSB part of the counter is latched to a shadow register when the LSB part is read. As a result, the LSB part must always be read first, and the MSB part must be read immediately after the LSB part. When writing to the counter, the MSB part must be written first, followed by the LSB part. ## 3.21.4 Analyzer sFlow Sampling This section describes sFlow sampling. The applicable registers are listed in the following table. Table 119 • Analyzer sFlow Registers Overview | Target::Register.Field | Description | Replication | |------------------------------------------------------|-------------------------------------------------------------------------|-------------| | ANA_AC::PS_COMMON_CFG.SFLOW_ENA | Controls sFlow operation. | 1 | | ANA_AC::PS_COMMON_CFG.SFLOW_SMPL_ID<br>_IN_STAMP_ENA | Configures sFlow sampler ID (port number) as part of stamp sent to CPU. | 1 | | ANA_AC::SFLOW_CFG.SFLOW_CPU_QU | Configures CPU extraction queue for sFlow sampled frames. | 1 | | ANA_AC::SFLOW_CTRL | Configures sFlow samplers (rate and type). | Per port | | ANA_AC::SFLOW_CNT | Current sFlow sampler count values. | Per port | | ANA_AC:PS_STICKY:STICKY | Various sticky debug events. | 1 | | ANA_AC:PS_STICKY_MASK:STICKY_MASK | Mask to allow debug events to be counted in port stat block. | 1 | sFlow is a standard for monitoring-high speed switched networks through statistical sampling of incoming and outgoing frames. Each port in the device can be set up as an sFlow agent monitoring the particular link and generating sFlow data. If a frame is sFlow sampled, it is copied to the sFlow CPU extraction queue (ANA\_AC::SFLOW\_CFG.SFLOW\_CPU\_QU). An sFlow agent is configured through ANA AC::SFLOW CFG with the following options: - SFLOW\_SAMPLE\_RATE specifies the probability that the sampler copies a frame to the CPU. Each frame being candidate for the sampler has the same probability of being sampled. The probability is set in steps of 1/32768. - SFLOW DIR SEL(0) enables incoming frames on the port as candidates for the sampler. SFLOW\_DIR\_SEL(1) enables outgoing frames on the port as candidates for the sampler. When Tx sampling is used, the Sample ID must be set in the sFlow stamp to enable the CPU to determine the sFlow sampler sampled by the frame (ANA\_AC::PS\_COMMON\_CFG.SFLOW\_SMPLE\_ID\_IN\_STAMP\_ENA). Rx and Tx sampling can be enabled independently. If both are enabled, all incoming and outgoing traffic on the port is subject to the statistical sampling given by the rate in SFLOW SAMPLE RATE. sFlow sample candidate sent to the CPU is sent with IFH.FWD.SFLOW\_MARKING set and with FCS updated as shown in the following illustration. Figure 52 • sFlow Stamp Format in FCS Without sample ID in stamp With sample ID in stamp | | SAMPLE<br>ID | FRAME_FWD_CNT | | SAMPLE<br>CNT | | |---|--------------|---------------|---|---------------|--------------| | 3 | 1 26 | 8 | 3 | 0 | :bit positio | SAMPLE CNT is incremented for each sample sent to CPU by the sFlow sampler. FRAME FWD CNT is incremented whenever the frames are applicable for an sFlow sampler. A variety of sticky events allows debug of the sFlow setup. These events can furthermore be counted in the port statistics block by enabling the corresponding \*\_MASK. The following events are reported (in ANA AC:PS STICKY:STICKY). - sFlow candidate was found (ANA\_AC:PS\_STICKY:STICKY.SFLOW\_CAND\_STICKY). - sFlow source sample was sent to CPU (ANA AC:PS STICKY:STICKY:SFLOW SRC SAMPLE STICKY). - sFlow destination sample was sent to CPU (ANA\_AC:PS\_STICKY:STICKY.SFLOW\_DST\_SAMPLE\_STICKY). Current sample count and sample candidate count numbers are available (ANA\_AC::SFLOW\_CNT.SFLOW\_SAMPLE\_CNT and ANA AC::SFLOW CNT.SFLOW FRAME FWD CNT). These events can all be counted in the statistics block by enabling the corresponding \*STICKY\_MASK found in register group ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK[x]. (ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK.SFLOW\_CAND\_STICKY\_MASK, ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK.SFLOW\_DST\_SAMPLE\_STICKY\_MASK, ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK.SFLOW\_SRC\_SAMPLE\_STICKY\_MASK and ANA\_AC:PS\_STICKY\_MASK:STICKY\_MASK.SFLOW\_SAMPLE\_STICKY\_MASK). # 3.21.5 Mirroring This section describes how to configure mirroring. The following table lists the applicable registers. Table 120 • ANA\_AC Mirror Registers Overview | Target::Register.Field | Description | Replication | |---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------| | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_DIRECTION | Configures whether to probe ingress traffic, egress traffic, or both. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_MAC_MODE | Configures MAC address filtering i.e. only traffic to and/or from hosts known in to MAC table with the mirror bit set are mirrored. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_VLAN_MODE | Configures VLAN filtering. That is, only traffic with a specific VID or with VLAN entry mirror bit set are mirrored. | 3 | Table 120 • ANA\_AC Mirror Registers Overview (continued) | Target::Register.Field | Description | Replication | |-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------| | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_VID | Configures VID when PROBE_VLAN_MODE is set to probe VID. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_CPU_SET | Configures mirroring of traffic to specific CPU ports. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_PHYS_RX_PORT | Configures if Rx mirroring mirrors physical or masqueraded port. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_CFG.PROBE_RX_CPU_AND_VD | Configures Rx mirror mask for CPU ports and VD ports. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_PORT_CFG | Configures mirroring of the ingress ports for PROBE_DIRECTION = RX_MIRROR and/or the set of egress ports for PROBE_DIRECTION = TX_MIRROR. | 3 | | ANA_AC:MIRROR_PROBE:PROBE<br>_PORT_CFG1 | See PROBE_PORT_CFG. | 3 | | QFWD:SYSTEM:FRAME_COPY_<br>CFG[9-11] | Configures forwarding options per probe. | 3 | To debug network problems, selected traffic can be mirrored using configurable probes, to a mirror port where a frame analyzer can be attached to analyze the frame flow. The device has three independent mirroring probes. Each probe can be configured with a separate set of filtering conditions that must be fulfilled before traffic is mirrored. If multiple filtering conditions are enabled for a given probe they must all be fulfilled before mirroring occurs. For example, mirror probe 1 can be set up to only Rx mirror traffic from a given host in a specific VLAN, whereas probe 2 can be set up to mirror frames matching criteria in VCAP IS2. If a frame is mirrored by more than one mirror probe, the highest numbered probe is selected. This implies that only one mirror copy is made per frame, even if multiple probes are active. The following traffic mirror conditions can be configured per probe: - All frames received on a given port, also known as ingress mirroring (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_DIRECTION(1) = 1 and ports to be RX mirrored set in ANA\_AC:MIRROR\_PROBE[x].PROBE\_PORT\_CFG) - All frames transmitted on a given port, also known as egress mirroring (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_DIRECTION(0) = 1 and ports to be TX mirrored set in ANA\_AC:MIRROR\_PROBE[x].PROBE\_PORT\_CFG) - All frames sent to a specific CPU port (may be useful for software debugging) (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_DIRECTION(0) = 1 and CPU ports to be mirrored set in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_CPU\_SET) - All frames classified to specific a VID (enabled in ANA\_AC:MIRROR\_PROBE[x]. PROBE\_CFG. PROBE\_VLAN\_MODE == 2 and VID set in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_VID) - All frames classified to VLANs with VLAN->VLAN\_MIRROR\_ENA set (enabled in ANA AC:MIRROR PROBE[x].PROBE CFG.PROBE VLAN MODE== 1). - All frames received from a known station with MAC->MIRROR set (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_MAC\_MODE(1)= 1). - All frames send to a known station with MAC->MIRROR set (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG. PROBE\_MAC\_MODE(0) = 1). This can also be flooded traffic (enabled via ANA\_L2::FWD\_CFG.FLOOD\_MIRROR\_ENA). - Frames selected through configured VCAP entries (enabled by VCAP IS2 action MIRROR\_PROBE). For such frames, the only other applicable mirror criteria is PROBE DIRECTION. - All frames received from CPU, also known as CPU ingress mirroring (enabled in ANA\_AC:MIRROR\_PROBE[x].PROBE\_CFG.PROBE\_DIRECTION(1) = 1 and CPU ports to be RX mirrored set in ANA\_AC:MIRROR\_PROBE[x].PROBE\_RX\_CPU\_AND\_VD). The mirror port configured per probe (QFWD:SYSTEM:FRAME\_COPY\_CFG[8-11]) can be any port on the device, including the CPU. Rx-mirrored traffic sent to the mirror port is sent as received optionally with an additional Q-tag (enabled in REW::MIRROR\_PROBE\_CFG.REMOTE\_MIRROR\_CFG). Tx-mirrored traffic sent to the mirror port is modified according to a configured Tx port (REW:COMMON:MIRROR\_PROBE\_CFG.MIRROR\_TX\_PORT) optionally with an additional Q-tag (enabled in REW::MIRROR\_PROBE\_CFG.REMOTE\_MIRROR\_CFG). For information about possible rewriter options for mirrored frames, see Mirror Frames, page 265. Example: Ingress port mirroring in specific VLAN All traffic only in VLAN 3 from host B on port 3 (the probe port) is mirrored to port 11 (the mirror port) using probe 1, as shown in the following illustration. Figure 53 • Ingress Mirroring in Specific VLAN The following configuration is required: - Enable RX mirroring on port 3: ANA\_AC:MIRROR\_PROBE[1].PROBE\_CFG.PROBE\_DIRECTION = 2 (= Rx only) ANA AC:MIRROR\_PROBE[1].PROBE\_PORT\_CFG = 0x8 (port 3) - Enable VID filtering: ANA\_AC:MIRROR\_PROBE[1].PROBE\_CFG.PROBE\_VLAN\_MODE = 2 ANA\_AC:MIRROR\_PROBE[1].PROBE\_CFG. PROBE\_VID = 3 - Setup mirror port: QFWD:SYSTEM:FRAME COPY CFG[10].FRMC PORT VAL 11 # 3.22 Shared Queue System and Hierarchical Scheduler The device includes a shared queue system with a per-port ingress queue and 3,358 shared egress queues. The shared queue system has 8 megabits of buffer. It receives frames from 15 ports, stores them in a shared packet memory, and transmits them towards 15 destination ports. The first 11 ports are assigned directly to a specific front port, whereas the last four ports are internal ports. Table 121 • Port Definitions in Shared Queue System | Ports | Connection | |---------|-----------------------------------------------------------------------------------------------------------------| | 8 – 0 | Front port, maximum bandwidth is 1 Gbps or 2.5 Gbps. | | 9 – 10 | Front port, maximum bandwidth is 10 Gbps. | | 11 – 12 | Frame injection and extraction CPU ports. The CPU connects these ports to DMA logic or to a register interface. | Table 121 • Port Definitions in Shared Queue System (continued) | Ports | Connection | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | IP multicast loopback port (VD0). When the queue system is requested to transmit to VD0, it generates multiple copies. All copies are, outside the queue system, looped back into the analyzer. The rewriter changes the ingress port number to VD0 before the loop. The analyzer generates a routed version of each of the frame copies coming from VD0. | | 14 | AFI loopback port (VD1). When the queue system is requested to send to VD1, it sends the request to the AFI. The AFI stores the request and can be configured to transmit the frame to any port in a programmed schedule. The AFI can transmit the frame to any of the egress ports. If VD1 is selected as destination by the AFI, the frame is looped back into the analyzer. | The following illustration provides an overview of shared queue system. Figure 54 • Shared Queue System Block Diagram Frames are stored in the packet memory and linked into the ingress queue for the logical source port along with the analyzer result. The analyzer result is then processed by a frame forwarder, frame by frame. Each of the frame transmission requests are added to an egress queue in the queue system attached to a specific egress port. A transmission request can be a normal switching request to another port, a mirror copy, for stacking updates, and for a CPU connected to one of the egress ports. For VD0, it can do multiple copies of the request. The frame forwarder can also request that a specific frame copy be discarded. The frame forwarder is efficient, because only frame references are switched, giving a forwarding bandwidth in the range of 67 Gbps (64 byte frames) to 2 terabits (Tbps) (1,518 byte frames). The frame data itself is not moved within the queue system. The forwarding request is passed through a queue mapper, which then selects an egress queue based on the classified properties of the frame. For example, a simple switch may use the classified QoS class only and an advanced carrier switch may use MPLS-classified traffic class (TC). A congestion control system can decide to discard some or all copies of the frame. This decision is based on consumption per QoS level. The queue mapper can be configured to change the drop decision using a congestion control mechanism based on queue sizes rather than only QoS class. Each destination port has a part of the total shared queue pool attached. Transmission is scheduled towards the destination ports through a hierarchical scheduling system, where all queues belonging to each port are arbitrated. On the way out, frames pass through the rewriter where the frame data can be modified due to, for instance, routing, MPLS encapsulation, or tagging. The queue system does not change the original frame data. An ingress port operates in one of three basic modes: drop mode, port flow control, or priority-based flow control. The following table lists the modes and flow definitions. Table 122 • Ingress Port Modes | Mode | Flow | |-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Drop mode (DROP) | The link partner is unaware of congestion and all frames received by the port are evaluated by the congestion control function where copies of the frame can be discarded. | | Port flow control (FC) | The link partner is informed through pause frames (full-duplex) or collisions (half-duplex) that the port cannot accept more data. If the link partner obeys the pause requests, no incoming data is discarded by the port. If the pause frames are disobeyed by the link partner, the buffer control function in the queue system discards data before it reaches the ingress queues. | | Priority-based flow control (PFC) | The link partner is informed about which QoS classes in the queue system are congested and the link partner should stop scheduling more frames belonging to these QoS classes. If the pause frames are disobeyed by the link partner, the buffer control function in the queue system discards data before it reaches the ingress queues. | ## 3.22.1 Analyzer Result The analyzer provides required information for switching frames in the shared queue system. The following table lists the information provided and a general description of the purpose. Table 123 • Analyzer Result | Group | Field | Function | |-----------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | Destination selection | Destination set | Set of ports to receive a normal switched copy. | | Destination selection | CPU queue mask | Set of CPU queues to receive a copy. | | Destination selection | Mirror | Requests mirror copy. | | Destination selection | Learn all | Requests learn copy to stack ports. | | Congestion control | Drop mode | This particular frame can be dropped even if ingress port is setup for flow control. | | Congestion control | DP | Drop precedence level. | | Congestion control | Priorities | Ingress resource priority of the frame. Four classified classes are provided from the analyzer: QoS, PCP, COSID, and TC. All values between 0 and 7. | | Queue mapping | SP | Super priority frame. | | Queue mapping | QGRP | Queue group for service-based egress queuing. | | Statistics | OAM type | Service counters can be configured to only count certain OAM frame types. | ### 3.22.2 Buffer Control Frames are stored in a shared packet memory bank, which contains 5,952 words of 176 bytes each. A memory manager controls which words the packet writer uses to store a frame. With proper configuration, the packet memory bank always has a free word available for incoming frames. There are configurable thresholds for triggering pause frame requests on ports enabled for flow control and for discarding frames due to too large memory use when for instance pause frames are disobeyed by the link partner. Frames discarded at this stage are discarded without considering the frame's destination ports. This kind of discarding is called tail dropping. It is an indication of head-of-line blocking and is not usually desired. For information about how it can be avoided by properly configuring the congestion control system, see Congestion Control, page 210. The pause frame and discard mechanisms are activated when a threshold for the individual port's memory use is reached and when a threshold for the total use of memory is reached. The following table lists the configuration registers involved in the buffer control. Table 124 • Buffer Control Registers Overview | Register | Description | Replication | |------------------------|------------------------------------------------------------------------------------------|-------------| | QSYS::ATOP | Maximum allowed memory use for a port before tail dropping is activated. | Per port | | QSYS::ATOP_TOT_CFG | Total memory use before tail dropping can be activated. | None | | QSYS::PAUSE_CFG | Thresholds for when to start and stop port flow control based on memory use by the port. | Per port | | QSYS::PAUSE_TOT_CFG | Total memory use before flow control is activated. | None | | QFWD::SWITCH_PORT_MODE | Enable drop mode for a port. | Per port | The following table lists available status information. Table 125 • Buffer Status Registers Overview | Register | Description | Replication | |----------------------|-----------------------------------------|-------------| | QSYS::MMGT_PORT_USE | Current consumption for a specific port | None | | QSYS::MMGT_PORT_VIEW | Selection of port to show usage for | None | | QSYS::MMGT | Number of free words in packet memory | None | # 3.22.3 Forwarding The frame forwarder processes frames at the head of the per-port ingress queues by adding references to the egress queues for each of the frames' destination ports. The references points from the egress queues to the stored frames. The forwarder can add from 78 million to 156 million references per second. The ingress queues are selected by a weighted round-robin search, where the weights are configured in QFWD::SWITCH\_PORT\_MODE.FWD\_URGENCY. Each frame is processed as either a drop-mode frame or a flow control frame, which influences how the congestion control works. For a drop-mode frame, the congestion control can discard frame copies while for a flow control frame, it lets the frame stay at the head of the ingress queue blocking further processing of frames from the port until the congestion situation is over. A frame is processed as a drop-mode frame if one of the following conditions is met: - The ingress port is configured to be an ingress drop port. - · The egress port is configured to be an egress drop port. - The frame itself is analyzed to be a drop frame. In terms of discarding frames, the forwarder can work in an ingress-focused statistics mode or an egress-focused statistics mode. The mode is configured per ingress port in QFWD::STAT\_CNT\_CFG. In the ingress-focused mode, a frame can be discarded towards multiple destinations simultaneously. The discard statistics is only incremented if the frame is discarded towards all destinations. In the egress-focused mode, the discard statistics is incremented for each copy of the frame being discarded at the expense of the forwarder only discarding one frame copy per cycle. As a result, the forwarder can become oversubscribed. For example, if two 10G ports are multicasting 64-byte frames at wire-speed to ten destinations, the total amount of frame copies per second is $20 \times 10$ frames/(8 × (64 + 20) ns) = 1,523 million frames per second. The forwarder can at maximum process 156 million frames per second. As a consequence, the ingress queues fill up and tail dropping is inevitable. The highlights of the modes are listed in the following table. Table 126 • Statistics Modes | Statistics Mode | Operation | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ingress-focused | A frame switched to N ports and discarded to M ports will update the discard statistics for the ingress port by one, only if $N = 0$ and $M > 0$ . The forwarder will use N cycles to process the frame. | | Egress-focused | A frame switched to N ports and discarded to M ports will update the discard statistics for the M egress ports by one. The forwarder will use N+M cycles to process the frame. | #### 3.22.3.1 Forward Pressure The worst-case switching capacity in the frame forwarder is 78 million frames per second. This corresponds to 52 Gbps line rate with minimum-sized frames. However, if a large share of these frames have multiple destinations, and are all close to the 64 byte minimum frame size, the processing speed is insufficient to process the destination copy one at a time. The consequence is that the ingress queues start to fill. The ingress queues contain both high and low priority traffic, unicast, and multicast frames. To avoid head-of-line blocking effects from the ingress queues filling up and eventually leading to tail dropping, a forward pressure system is in place. It can discard frame copies based on the size of the ingress queues. Forward pressure is configured in the QSYS::FWD\_PRESSURE registers, where each port is allowed only a certain number of copies per frame if the number of pending transmit-requests in the port's ingress queue exceeds a threshold. The following table lists the registers associated with configuring forward pressure. Table 127 • Forward Pressure Configuration Registers Overview | Register | Description | Replication | |----------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------| | QSYS::FWD_PRESSURE.FWD_PRESSURE | Configures forwarding pressure limits per port. | Per port | | QSYS::MMGT_IQ_STAT | Returns current ingress queue size. | Per port | | QFWD::FWD_PRESSURE.FWD_PRESS_DROP _CNT | Counts number of frame copies discarded due to this feature. Value is total discards for all ports in common. | None | #### 3.22.3.2 Destination Selection The forwarder adds references to the egress queues by evaluating the destination selection information shown in the following table from the analyzer. Table 128 • Analyzer Destination Selection | Field | Function | |-----------------|--------------------------------------------------------------------------------------------------------------------------| | Destination set | Set of ports to receive a normal switched copy. All ports except the internal extraction ports have a bit in this mask. | | CPUQ | Set of CPU queues to receive a copy. | | Mirror | Request mirror copy. | | Learn all | Request learn copy to stack ports. | The destination set selects specific egress ports, and the CPUQ, mirror, and learn-all fields are indirect frame destinations and must be translated to transmit requests through the frame copy configuration table. The table provides a specific egress port and QoS class to use in congestion control. The table is accessed through the QFWD::FRAME\_COPY\_CFG register. The following illustration shows the translation of transmit requests. Figure 55 • Translation of Transmit Requests The CPUQ field instructs which of the eight CPU extraction queues should get a copy of this frame. Each queue in the queue system is translated into either one of the two internal CPU ports or to a front port. The egress QoS class can be set to the same value as the ingress QoS class or to a specific value per CPU extraction queue. A super priority can also be used. For more information, see Super Priorities, page 225. The mirror field is the mirror probe number, which is set by the analyzer if the frame must be mirrored. There are three mirror probes available, and for each of the probes, associated egress port and egress QoS class can be set by the translation table. Finally, if the learn-all field is set, the frame should also be forwarded to the stacking links. It is selectable to forward the frame to either of the two stacking links or to both, depending on the stacking topology. The following table lists the configuration registers associated with the forwarding function. Table 129 • Frame Forwarder Registers Overview | Register | Description | Replication | |------------------------|-------------------------------------------------------------------------------------|-------------| | QFWD::SWITCH_PORT_MODE | Enables forwarding to/from port. Forwarding speed configuration. Drop mode setting. | Per port | | QFWD::FRAME_COPY_CFG | Translates CPUQ/mirror/learn all to enqueuing requests. | 12 | | QFWD::FRAME_COPY_LRNA | Learn All frame copy extra port. | None | | QFWD::CPUQ_DISCARD | Disables enqueuing to specific CPU queues. | None | | QSYS::FWD_PRESSURE | Configures forwarding pressure limits per port. | Per port | Table 129 • Frame Forwarder Registers Overview (continued) | Register | Description | Replication | |------------------|--------------------------------------------------------------------------|-------------| | QFWD::MIRROR_CFG | Configures whether discarded copies should still generate a mirror copy. | None | ## 3.22.4 Congestion Control The buffer control can only guarantee that no ingress port consumes more than a certain amount of memory. Discards made by the buffer control are tail drops. The congestion control is more advanced in that it facilitates intelligent discard where only frames belonging to a congested flow are discarded. If the forwarder finds that some frame copies are made to a congested flow, it discards the copies (drop-mode frames) or lets the copies block further processing of the ingress queue (flow control ports). The congestion control information from the analyzer result involved in the congestion control is listed in the following table. Table 130 • Analyzer Congestion Results | Field | Function | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Drop mode | This frame can be dropped even if port is setup for flow control. This function is mainly used by the analyzer for stacking use where the ingress unit's source port determines how congestion should be handled. | | DP | Drop precedence level. A value 0-3, telling how yellow the frame is. | | QoS class | Frame's ingress QoS class | The current consumption of resources in the congestion controller is updated when a reference is added to one of the egress queues. The congestion controller tracks four different resources: - Ingress packet memory consumption. Each frame uses a number of 176-byte words. - Egress packet memory consumption. Each frame uses a number of 176-byte words. - Ingress frame reference consumption. Each frame uses one frame reference per frame copy. - Egress frame reference consumption. Each uses one frame reference per frame copy. There are 5,952 memory words and 5,952 frame references in total. The accounting is done based on QoS classes and port numbers. Each account has a threshold specifying how many resources the account is permitted to consume. The accounts are as follows: - Consumption per port per QoS class. This is a reservation account. - Consumption per port. A frame does not consume resources from this account before the resources belonging to the previous account are consumed. This is a reservation account. - Consumption per QoS class. A frame does not consume resources from this account before the resources belonging to the previous two accounts are consumed. This is a sharing account. - Consumption in addition to the above. A frame does not consume from this account before the resources belonging to the previous three accounts are consumed. This is a sharing account. The congestion controller updates an accounting sheet with the listed accounts for each of the tracked resources. The following illustration shows reservation accounts for the packet memory accounting sheets when a 700-byte frame from port 0 forwarded to ports 1 and 5 with QoS class 2 is added. The frame size requires the use of five words in the packet memory. The account for ingress port 0, QoS class 2 is reserved three words. Before the frame is added, it is checked if the account was fully utilized. If the account was not fully used, the frame is allowed into the queue system. After the frame is added, the account is updated with the five words and therefore uses two more than was reserved. These are consumed from the port account. The port account is reserved 0 words and the added two words therefore also close the port account. This affects further frame reception. In the egress side, there are no words reserved for the account per port, per QoS class. The port account for port 1 is reserved 8 words and 0 for port 5. Figure 56 • Accounting Sheet Example Packet memory, ingress user | Priority | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Р | |----------|---|---|----------|---|---|---|---|---|----------| | Port | | | | | | | | | | | 0 | | | 5/<br>/3 | | | | | | 2/<br>/0 | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Packet memory, egress user For PFC purposes, the congestion controller contains an additional accounting sheet of the ingress memory consumption. The sheet has its own set of thresholds. The result of the accounting is whether to send PFC pause frames towards the link partner. The combined rule for allowing a frame copy is if both of the following are true: - Either ingress or egress memory evaluation must allow the frame copy. - Either the ingress or egress reference evaluation must allow the frame copy. When the reserved accounts are closed, the shared accounts spanning multiple ports are checked. There are various rules for regarding these accounts as open or closed. These rules are explained in the following through three major resource modes, which the congestion controller is intended to be used in. Figure 57 • Reserved and Shared Resource Overview Packet Memory The resource modes are defined by the way the shared resources are distributed between classes of frames. Note, that there are many options for configuring a different resource mode than the modes described in the following. This is outside the scope of this document. ### 3.22.4.1 Strict Priority Sharing This resource mode considers higher QoS classes as more important than lower QoS classes. The shared area is one big pool shared between all QoS classes. Eight thresholds define the limit for each of the eight QoS classes. If the total consumption by all QoS classes exceeds one of the thresholds, the account associated with the particular QoS class is closed. Figure 58 • Strict Priority Sharing One important property of this mode is that higher QoS classes can block lower QoS classes. A congested flow with a high QoS class uses all of the shared resources up to its threshold setting and frame with lower QoS classes are thus affected (lower burst capacity). The following table shows the configuration settings for strict priority sharing mode. Table 131 • Strict Priority Sharing Configuration Settings | Configuration | Setting | |--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reservation thresholds | These can be set to any desired value. The amount set aside for each account should be subtracted from the overall resource size, before the sharing thresholds are set up. | | Ingress QoS class thresholds | Levels at which each QoS class should start to reject further enqueuing. Frames with multiple destinations are only accounted once because they are physically only stored once. | | Ingress color thresholds | Set to their maximum value to disable. The color is not considered in this mode. | | WRED group memberships | Disable all. | | Egress sharing thresholds | Set all to 0, because only use ingress sharing control is . Egress would account for multiple copies, which is not intended. | | QoS reservation (QRES::RES_QOS_MODE) | Disable for all. No shared resources are set aside per QoS class. | ## 3.22.4.2 Per Priority Sharing This mode sets aside some memory for each QoS class and can in addition have an amount of memory reserved for green traffic only. This mode operates on ingress resources, in order to utilize that frames with multiple destinations are only stored once. Figure 59 • Per Priority Sharing The following table shows the configuration settings for per priority sharing mode. Table 132 • Per Priority Sharing Configuration Settings | Configuration | Setting | |--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reservation thresholds | These can be set to any desired value, except for ingress per port reservation. The algorithm requires these to be zeroed. | | Ingress QoS class thresholds | Set to amount of shared memory which should be set aside for each QoS class. The sum of all these should not exceed the amount of memory left after all the reservations has been subtracted. | | Ingress color thresholds | Subtracting all reservations including QoS class shared areas may end up in some unused memory. Set the color thresholds to various levels to guarantee more space the greener. | | WRED group memberships | Disable all. | | Egress sharing thresholds | Set all to 0, as we only use ingress sharing control. Egress would account for multiple copies, which is not intended. | | QoS reservation (QRES::RES_QOS_MODE) | Enable for all. | ## 3.22.4.3 Weighted Random Early Discard (WRED) Sharing In this mode, the shared resource accounts close at random. A high consumption gives a high probability of discarding a frame. This sharing method only operates on the egress memory consumption. There are three WRED groups, each having a number of ports assigned to it. Each WRED group contains 24 WRED profiles; one per QoS class and per DP = 1, 2, 3. Each WRED profile defines a threshold for drop probability 0% and a threshold for drop probability 100%. Frames with DP = 0 value are considered green and have no WRED profile. Green frames should always be allowed. Memory consumptions within a WRED group are tracked per QoS class, but across DP levels, however, green frames affect the drop probability of yellow frames. The WRED groups with each eight QoS classes are shown in the following illustration. It is also possible to use fewer groups or different sizes for each QoS classes. Figure 60 • WRED Sharing The following illustration shows an example of the WRED profiles for a QoS class within a WRED group. Thresholds are shown for DP = 2 only. Figure 61 • WRED Profiles The WRED sharing is operating as an egress algorithm. The following table shows the configuration setting. Table 133 • WRED Sharing Configuration | Configuration | Setting | |--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reservation thresholds | These can be set to any desired value, except for ingress per port reservation. The algorithm requires these to be zeroed. | | Ingress priority thresholds | Set to their maximum value, as the QoS classes should not have any sharing across WRED groups. | | Ingress color thresholds | Set to their maximum. | | WRED group memberships | Set to define the WRED groups. For each group, define as well the up to 24 WRED profiles (per QoS class and DP level) | | Egress sharing thresholds | Set the QoS class thresholds to the highest possible consumption before any profile hits 100% probability. The color thresholds can then operate on the remainder of the resource in control and can all be set to the same value, allowing use of all the remaining. A discard due to the WRED profile takes precedence over other sharing states, so the area outside the group sections is only available for green traffic. | | QoS reservation (QRES::RES_QOS_MODE) | Disable for all. | ## 3.22.4.4 Priority-Based Flow Control There is a fifth accounting scheme for the pending frames. It operates on ingress memory use, but has the same set of thresholds as the other account systems. The output from that system is however not used for stopping/discarding frame copies, but for requesting the port to transmit pause flow control frames for the involved priorities. The threshold levels here should be configured in a way so that the blocking thresholds cannot be reached during the trailing amount of data. ## 3.22.4.5 Threshold Configuration There is a large number of thresholds for the reservations described. They are all found in the QRES::RES\_CFG register, which is replicated approximately 5,120 times. Table 134 • Threshold Configuration Overview | QRES::RES_CFG Replication | Description | |---------------------------|------------------------------------------------------------------------------------| | 0 – 119 | Ingress memory reservation for port P priority Q accessed at index 8P + Q. | | 496 – 503 | Ingress memory shared priority threshold for priority Q accessed at index 496 + Q. | | 508 – 511 | Ingress memory shared threshold for DP levels 1, 2, 3, and 0. | Table 134 • Threshold Configuration Overview (continued) | QRES::RES_CFG Replication | Description | | | |---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 512 – 526 | Ingress memory reservation for port P, shared between priorities, accessed at index 512 + P. | | | | 1,024 – 2,047 | Ingress reference thresholds. Same organization as for ingress memory, but added offset 1,024. | | | | 2,048 – 3,071 | Egress memory thresholds. Same organization as for ingress memory, but added offset 2,048. | | | | 3,072 – 4,095 | Egress reference thresholds. Same organization as for ingress memory, but added offset 3,072. | | | | 4,096 – 5,119 | PFC memory thresholds, operating on ingress memory use. PFC is activated when no memory left according to these thresholds. Same organization as the ingress stop thresholds, but added offset 4,096. | | | The following table lists other registers involved in congestion control. Table 135 • Congestion Control Registers Overview | Register | Description | |-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | QRES::RES_STAT (replicated same way as RES_CFG) | Returns maximum value the corresponding threshold has been compared with. | | QRES::RES_STAT_CUR (replicated as RES_CFG) | Returns current value this threshold is being compared with. | | QRES::WRED_PROFILE (72 profiles) | Profile description. There are 3 (grp) × 3 (DP) × 8 (prio) profiles. | | QRES::WRED_GROUP | WRED group membership configuration per port. | | QRES::PFC_CFG | Enable PFC per port. | | QRES::RES_QOS_MODE | Enable QoS reservation for QoS classes. | | QFWD::SWITCH_PORT_MODE | Controls whether yellow traffic can use reserved space (YEL_RSVD). Allows ports to use shared space (IGR_NO_SHARING, EGR_NO_SHARING). | ## 3.22.4.6 Frame Forwarder Monitoring The performance of the frame forwarder can be monitored through the registers listed in the following table. Table 136 • Frame Forwarder Monitoring Registers Overview | Register | Description | |--------------------------|-----------------------------------------------------------------------------------------------------------------| | QFWD::FWD_DROP_EVENTS | Sticky bits per port telling if drops from each individual ingress port occurred. | | QFWD::FWD_CPU_DROP_CNT | Counts number of frames not forwarded to the CPU due to congestion. | | QFWD::FWD_STAT_CNT | Counts number of frame copies added to the egress queues in total. | | QFWD::FWD_PRESS_DROP_CNT | Counts number of frame copies discarded due to forward pressure. Value is the total discards across all ports. | | QSYS::MMGT_IQ_STAT | Returns current ingress queue size. | | QSYS::MMGT | Returns number of free references for the egress queues. | ## 3.22.5 Queue Mapping When a frame is forwarded to an egress port, a frame reference is inserted into one of the port's egress queues. The egress queues are read by a programmable scheduler consisting of a number of scheduler elements (SEs). Each SE serves 8 or 16 queues, configurable through the HSCH::HSCH\_LARGE\_ENA registers. Each SE selects the next input to transmit and forwards the decision to a next-layer SE, selecting from which of its inputs to transmit. There are a total of three layers, with layer 0 being the queue connected layer. Connections between the layers are fully configurable in HSCH::L0\_CFG and HSCH::L1\_CFG. For more information about SE functionality, see Scheduling, page 221 and Bandwidth Control, page 222. The scheduler includes a dual leaky bucket shaper to limit the traffic rate from inputs attached to it. To distribute the bandwidth between the inputs, the scheduler also contains a weighted round robin arbiter. The number of queues available in total for all ports is 3,358. The queue mapper must be configured to how these queues are assigned to each egress port. The overall traffic management for each port is the result of the queue mapping and scheduler hierarchy. The following illustration shows an example of the default egress port hierarchy. At layer 0, eight SEs select between data in the same QoS level, with queues from each source port. This forms a basic traffic manager, where all source ports are treated fair between each other, and higher priorities are preferred. This is accomplished by having the layer 0 SEs select input in a round robin fashion, and the mid-layer select strictly higher inputs before lower inputs. In general, all SEs can be configured to various polices on how to select inputs. The illustration also shows the two super-priority queues available in all ports. The scheduler hierarchy configuration must be based on a desired scheme. The hardware default setup is providing a queue per (source, priority) per egress port. All queues with the same QoS level are arbitrated first, in layer 0. Figure 62 • Scheduler Hierarchy (Normal Scheduling Mode) ### 3.22.5.1 Mapping System All queues in the system are referred to as a layer 0 SE number and an input number. For example, the default configuration puts all traffic for port 0 from source 7 in priority 0 into the queue (0,7); SE number 0, input 7. When the forwarder requests a frame to be added to a queue, the queue group—all classified priorities, the source port, and the destination port—are used to find the SE and input on it, through some configurable mapping tables. There are three basic hierarchy types, and the first part of the mapping procedure is to find the hierarchy type in QFWD::QMAP\_PORT\_MODE. The mode is found for frames with classified qgrp = 0 in the QMAP\_MODE\_NONSERVICE field and in QMAP\_MODE\_SERVICE for qgrp >0. Note that service and non-service mappings can be combined at the higher layers, in order to combine the two basic types of traffic in the application. An overview of the queue mapping tables is shown in the following illustration. The drop statistics mode is also found by looking up information in these tables. For more information, see Statistics, page 226. Figure 63 • Queue Mapping Tables Mapping is accomplished by the following steps. - Find queuing class (qc\_cl) qc\_sel = QMAP\_QOS\_TBL (qgrp,dport) qc = (qos, cosid, pcp, tc) (qos\_sel) - Find queue. This mapping depends on which of the following hierarchy modes are configured: Mode 0: Normal mode. This is the default mode on all ports. It is used for arbitrating all frames with the same queuing class, treating all source ports equally. SE = QMAP\_SE\_TBL (128 + qc, dport), inp = source port. **Mode 1: Group mode.** This mode is used for having eight queues per queue group in layer 0. Used in Carrier applications where each service should have its own queues, with a traffic profile per queuing class. $SE = QMAP\_SE\_TBL (qgrp,dstp), inp = qc.$ The following illustration shows the group scheduling mode. Figure 64 • Group Scheduling Mode **Mode 2: Microwave Backhaul (MBH) mode**. This mode is used when many queue groups need to be arbitrated per queuing class, and they share a common outgoing quality of service policy. For example, it may be possible to have 100 queues per queuing class arbitrated on level 0 and 1, and class selected on level 2. In this case, the SE table is used by SE = QMAP\_SE\_TBL (qgrp – (qgrp MOD 16) + qc, dport), inp = qgrp MOD 16. The following illustration shows the Mobile Backhaul mode. Figure 65 • Mobile Backhaul Mode The following table lists the registers associated with assigning queues for each egress port. Table 137 • Queue Mapping Registers Overview | Configuration | Description | |----------------|-----------------------------------------------------------------------| | QMAP_PORT_MODE | Selects queue layer hierarchy type | | QMAP_QOS_TBL | Selects per (qgrp,dport) from which queueing QoS it should be derived | | QMAP_SE_TBL | Selects per (qgrp,dport) a scheduling element | #### 3.22.5.2 Service Statistics As shown in the following illustration, drop statistics configuration is also being looked up in the mapping flow. The device has 1,024 service counter sets. On the ingress side, the queue system only counts discarded frames. On the egress side, it counts the amount of frames transmitted. In both cases, there is a counter for green frames and another counter for yellow frames. The egress counter set to count is selected through the rewriter. The ingress counter is selected by looking up drop statistics information when the queuing class is looked up. That returns a base index, which is multiplied by four, and one of the four classified priority parameters is added. If the set is configured for using only four counters, the MSB of the priority is cleared. The resulting index will afterwards be counting drops, with 18 bits of octet counting, and 10 bits of frame counting. Optionally, all 28 bits can be used for frame counting. For more information about drop statistics, see Statistics, page 226. ## 3.22.6 Queue Congestion Control The congestion control system may choose to forward a frame to a specific queue or to discard it. In either case, the decision passes through a queue limitation function, which can alter the decision based on another view of the resources. The following illustration shows the drop decision flow. Figure 66 • Drop Decision Flow The queue limitation function checks the queue size against various configurable and dynamic values and may change a transmit request to a discard by canceling the request to the scheduler. The queue limitation system uses queue sizes (in terms of packet memory usage) of all queues. Each queue is assigned to a share. The share is a configuration parameter for the port, QoS class, and service/non-service type as set in the QLIMIT\_PORT\_CFG register. With this configuration granularity, it also possible to change the queue rights to be shared for the scheduling element to which they are attached, so that one aggressive queue will make other queues on the same element start discarding frames. That is done in the QLIMIT\_SHR\_MODE field. A set of watermarks is afterwards used to control some queue limitation drop mechanisms, trying to discard data for congested queues without affecting well-balanced traffic. The conditions under which a frame is discarded is shown in the following illustration The watermarks shown are defined per shared account and per color. If yellow traffic is present, it can be discarded fairly without affecting the green traffic. Figure 67 • Queue Limitation Share The following table provides descriptions of the queue limitation conditions. Table 138 • Queue Limitation Conditions | State | Description | Traffic Condition | |-------------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | Queue is active | The queue size exceeds the watermark in QLIMIT_QUE_ACT | The queue is not idle. When the filling gets very high, only non-active queues are allowed further enqueing. | | Queue looks congested | The queue size exceeds the watermark in QLIMIT_QUE_CONG | The queue seems to be growing.<br>When the share filling is high, it can<br>be chosen to discard further data<br>into the queue. | | Queue consumes too much | The queue size exceeds DYN_WM, which is the QLIMIT_SHR_CTOP watermark divided by the number of queues looking congested. | The queue seems to be one of the reasons for the growing memory consumption, and further additions to the queue can be avoided. | The following table lists the queue limitation registers. Table 139 • Queue Limitation Registers | Register Groups | Description | |-----------------|----------------------------------------------------------------------------| | QLIMIT_QUEUE | Reads current queue size | | QLIMIT_PORT | Assigns ports to shares | | QLIMIT_SHR | Configures watermarks for share and monitor filling and dynamic watermarks | | QLIMIT_MON | Reads the status for each of the logical shares. | ## 3.22.7 Scheduling All egress queues are combined in a tree structure where the root is connected to an egress port. The scheduling capabilities consist of the following three aspects. - Structure of the hierarchy - Bandwidth limitation (shaping) - Bandwidth distribution (arbitration between inputs) ## 3.22.7.1 Hierarchy Structure The hierarchy consists of three layers: queue, middle, and outer. - Layer 0 is the queue level. All inputs to scheduler elements are connected to a specific egress queue, as described in the previous section. This layer has 416 elements with eight inputs each. A number of those can be reconfigured to have 16 inputs, in which case they are called "large elements". Only elements in multiples of two can become large, so the one following cannot be used. - Layer 1 is the middle layer. There are 64 elements in this layer, all having 32 inputs. These inputs are connected to outputs of the layer 0 elements, through the HSCH::L0 CFG table. - Layer 2 is the output layer. There is one scheduler element per egress port (15 elements). All elements have 64 inputs connected to outputs from layer 1 elements. Input *n* on the layer 2 elements can only be connected to layer 1 element *n*, configured in HSCH::L1\_CFG. ### 3.22.7.2 Default Hierarchy The initialization engine in the scheduler builds a default hierarchy for all ports, and no further configuration of it is needed. It sets all ports into normal mode, using eight large elements on layer 0, and one element on each of the two other layers. The layer 0 elements are all configured for frame based round robin selection, and the layer 1 elements for strict selection of highest available input. Port n uses elements 16n, 16n + 2, 16n + 14,... for layer 0. The example in the following illustration is for port 7. Figure 68 • Default Scheduling Hierarchy #### 3.22.7.3 Bandwidth Control Each scheduler element has a dual leaky bucket shaper on its output, which may block further transmissions from that scheduler element. It is controlled through a leaky bucket system, filling the bucket when data is transmitted, and leaking it at the configured rate. The bucket is closed when more data than the configured burst capacity has been filled into it. The shaper has three rate modes that define what is added to a bucket: - · Bits transmitted excluding IFG - Bits transmitted including IFG - · Frames transmitted Each of the three layers have four linked lists configured. All scheduling elements with active shapers must be members of one of those. Each linked list is processed once every configurable interval. When a list is processed, all shapers in it will leak its configured rate setting. Examples: - Data rate shapers are connected in a linked list, which is traversed every 10 μs. The shaper rate granularity becomes 100 kbps. - Frame rate shapers are connected in a linked list, which is traversed every 1 ms. The shaper rate granularity becomes 1 kilo frames per second. Each scheduler element includes two leaky buckets to support DLB shaping. The committed information rate (CIR) bucket is open when the filling is below the configured limit. The excess information rate (EIR) shaper is always closed, unless the congestion control reports that a threshold is reached. Which congestion thresholds to react on are configurable for each shaper and should depend on the traffic groups the particular element is a part of. The effect of the DLB shaper is that the rate out of the shaper is CIR or CIR plus EIR, depending of the accumulation of data in the queue system. The following table lists the registers associated with shaping. Table 140 • Shaper Registers Overview | Register | Description | |----------------------|--------------------------------------------------------| | HSCH::SE_CFG | Selects filling mode | | HSCH::CIR_CFG | Configures leak rate and burst capacity for CIR bucket | | HSCH::EIR_CFG | Configures leak rate and burst capacity for EIR bucket | | HSCH::SE_DLB_SENSE | Selects thresholds to control EIR with. | | HSCH::HSCH_LEAK_LIST | Configures leak list periods and starting index | | HSCH::SE_CONNECT | Links to next in leaking lists | | HSCH::CIR_STATE | Returns current CIR bucket filling | | HSCH::EIR_STATE | Returns current EIR bucket filling | | HSCH::SE_STATE | Returns whether or not the shaper is open | #### 3.22.7.4 Bandwidth Distribution Each scheduler element is selecting one of its inputs as the next source of transmission if a scheduling process passes through it. A number of different options are available for how this arbitration takes place. A configured value for the scheduler element tells how many of the lower indexed inputs should be arbitrated with the DWRR method. Inputs with higher indexes are preferred and arbitrated strict. Figure 69 • Scheduler The lower indexes are arbitrated in the effort to achieve a bandwidth ratio between them. In this regard, the bandwidth can be measured in frames, data bits, or line bits (including IFG). Each input is configured with a cost setting, and the algorithm strives to give *n* times more bandwidth to input A than B, if the cost configuration for A is *n* times lower than B. The following are two cost configuration examples. - Input 4 has cost 7, and input 6 has cost 11. If the total bandwidth shaped out of the scheduler element is 180 Mbps, input 4 will get 110 Mbps of it. - All inputs have cost 1, and the element is configured for frames per second arbitration. Algorithm will by this strive to send an equal number of frames from each input. Configuring costs is done indirectly by setting the HSCH\_CFG\_CFG.DWRR\_IDX first (pointing to the scheduler element to configure), after which the costs are accessible through the HSCH\_DWRR registers. The following table lists the registers associated with the arbitration algorithm. Table 141 • Scheduler Arbitration Registers Overview | Register | Description | |------------------|------------------------------------------------------------------------------| | HSCH::SE_CFG | Selects arbitration mode (data/line/frame) and number of inputs running DWRR | | HSCH::CFG_CFG | Selects for which element to configure/monitor DWRR algorithm | | HSCH::DWRR_ENTRY | Configures costs for each input | | HSCH::INP_STATE | Returns input states for a scheduler element | #### 3.22.7.5 Queue Shapers In addition to the shaping capabilities at the output of each scheduling element, it is also possible to shape individual queues. These shapers are single leaky bucket based. The devices contain 832 such shapers that can be assigned to any of the 3,328 queues. The assignment of queue shapers is done through the HSCH::QSHP\_ALLOC\_CFG register. This is replicated per scheduling elements in layer 0, and defines the range of inputs on the element that should have queue shapers assigned, and the index of the first of the 832 shapers to allocate to it. The shapers must be linked together for the leaking process in HSCH::QSHP\_CONNECT For example, to configure queue shapers on inputs 5 to 7 on elements 100 to 120, use the queue shapers from 400 to 462. ``` For I in 100 to 120 loop HSCH:QSHP_ALLOC_CFG[I]:QSHP_ALLOC_CFG.QSHP_MIN := 5 HSCH:QSHP_ALLOC_CFG[I]:QSHP_ALLOC_CFG.QSHP_MAX := 7 HSCH:QSHP_ALLOC_CFG[I]:QSHP_ALLOC_CFG.QSHP_BASE := 3*(I-100)+400 HSCH:QSHP_ALLOC_CFG[I]:QSHP_CONNECT.SE_LEAK_LINK := I+1; Endloop (terminate chain) HSCH:QSHP_ALLOC_CFG[120]:QSHP_CONNECT.SE_LEAK_LINK := 120 ``` The leak process operates as for the SE shapers and must be configured in HSCH:HSCH\_LEAK\_LISTS[3]. The indexes of shapers allocated to a set of queues are only used in the QSHP\_BASE settings. The shapers are accessed afterwards through the QSHP\_CFG and QSHP\_STATUS registers, accessed indirectly after setting HSCH\_CFG\_CFG\_SE\_IDX to the desired scheduling element. For example, to configure the shaper on input 6 of element 118 to shape to 1.2 Mbps, set HSCH::HSCH\_CFG\_CFG.CFG\_SE\_IDX := 118 and HSCH:QSHP\_CFG[6].QSHP\_CIR\_CFG.CIR\_RATE := 12 (assuming the leak chain is configured for unit 100 kbps). #### 3.22.7.6 Miscellaneous Scheduler Features The following table lists some features that might be useful. Table 142 • Miscellaneous Scheduler Registers Overview | Field | Description | |----------------|--------------------------------------------------------------------------------------| | SE_CONNECT_VLD | Stops the whole scheduler operation. Can be useful when reconfiguring the hierarchy. | | LEAK_DIS | Disables leaking process. | | FRM_ADJ | Sets the byte difference between line and data rate calculations. | | DEQUEUE_DIS | Disables transmissions per port. | ## 3.22.8 Queue System Initialization The queue system automatically initializes all tables and data structures when setting RAM\_CTRL.RAM\_ENA to 1, followed by setting RAM\_CTRL.RAM\_INIT to 1. Software should afterwards wait for 150 µs or wait for the RAM\_INIT bit to be cleared by hardware. After that the RESET\_CFG.CORE\_ENA must be raised, and the queue system is ready to operate. All thresholds and queue mappings are prepared with operational values. Configuration can afterwards be modified. The only per-port setting required to change in the queue system for initial bring-up of the queue system is the SWITCH\_PORT\_MODE.PORT\_ENA, which must be set to one allowing switching of frames to and from the port. ## 3.22.9 Miscellaneous Features This section provides information about other miscellaneous features of the queue system. ## **3.22.9.1 Frame Aging** The queue system supports discarding of frames pending in the queue system for too long time. This is known as frame aging. The frame aging period is configured in FRM\_AGING.MAX\_AGE, which controls the generation of a periodical aging tick. The packet memory manager marks frames pending in the queue system when the aging tick occurs. Frames pending for more than two aging ticks are subject to frame aging and are discarded by the queue system when scheduled for transmission. As a consequence, frames can be discarded after pending between one or two aging periods in the queue system. The following table lists the configuration registers associated with frame aging. Table 143 • Frame Aging Registers Overview | Field | Description | Replication | |---------------------------|-----------------------------------------|-------------| | QSYS::FRM_AGING.MAX_AGE | Sets the aging period | None | | HSCH::PORT_MODE.AGE_DIS | Disables aging checks per egress port | Per port | | HSCH::PORT_MODE.FLUSH_ENA | Regards various frames as being too old | None | #### 3.22.9.2 Super Priorities There are two special queues available in each egress port: super priority queue 0 and super priority queue 1. For more information, see Figure 62, page 216. These queues are selected before any other queues. They are intended for urgent protocol traffic injected by the CPU system. Frames in super priority queue 0 disregard the output shaper state and are not counted in the shaper's buckets. Frames in super priority queue 1 obey the output shaper state and are counted in the shaper's buckets. The following frames can be added to the super priority queues: - AFI injected frames: The AFI can be configured to inject into either of the super priority queues. For more information, see Adding Injection Frame, page 240. - CPU injected frames: Frames injected with an IFH with the SP flag set are inserted into the super priority queue as being set in the drop precedence (DP) IFH field. - CPU extracted, mirror, learn all frames: Frames subject to the translation in QFWD::FRAME\_COPY\_CFG can configure use of either of the super priority queues. ## 3.22.9.3 Frame Modifications in the Queue System The queue system typically passes data completely untouched from the ingress to the egress side, except for a few special cases. Frame copies to the CPU can be sent into the rewriter with two different priority schemes, involving modification of the internal frame header. Either the frame takes the QoS class from the CPU extraction queue number or it takes the QoS class from the configuration in QFWD::FRAME\_COPY\_CFG. This is controlled in PORT\_MODE.CPU\_PRIO\_MODE. Frame copies due to learn-all stack synchronization can be truncated to 64 bytes to save bandwidth on the line. This is enabled in HSCH::PORT MODE.TRUNC ENA. #### **3.22.9.4 Statistics** The queue system counts frame discards and successful transmissions. Each counted event updates a counter instance, counting octets in a 40-bit counter and frames in a 32-bit counter. A frame is counted as discarded when none of the frame's destination ports are reached, excluding mirror and learn-all copies. If a frame is discarded, a counter instance, per ingress port, per QoS class per color, is updated. The color granularity here is only green or yellow, mapped from the analyzed DP value through the QSYS::DP\_MAP settings. A frame transmission is a frame leaving the queue system towards the rewriter. In this direction, a counter instance per egress port, per QoS class per color, is updated. An abort counter instance per egress port counts frames discarded due to frame aging, queue system flushing, or abort requests from the rewriter. There are statistics available per service counter index, which is provided by the analyzer for ingress service discard statistics and from the rewriter for egress service transmission statistics. The service counters are available per counter index, per color. Access to the statistics is indirect. The QSYS::STAT\_CFG configuration register must be set to the port or service counter index to be accessed, and all counters related to this index can afterwards be read in the QSYS::CNT registers. The following table lists the available port counters and how they are mapped. Unused addresses return undefined values. In the expressions, yel = 1 for reading yellow counters and yel = 0 for green. The mapping from classified DP to color is made in the QSYS::DP MAP register. The following table shows the addresses of the frame counters. The equivalent octet counters are found at the frame counter address plus 64 for the 32 least significant bits and at the frame counter address plus 128 for the eight most significant bits. Table 144 • Statistics Address Mapping | Statistics Index | Event | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 – 15 | Frames received on the port viewed. The first eight counters are for green frames, QoS level 0 – 7. The last eight counters are for yellow frames, defined by the QSYS::DP_MAP register. | | 16 – 31 | Frames dropped on the port viewed. Drops will be for the ingress port point of view or egress, depending on the DROP_COUNT_EGRESS option. There are eight green counters and eight yellow counters. | | 32 | Tail drops on the port views. Drops made by the buffer control. | | 256 – 271 | Transmitted frames on the port viewed. Same layout as for the receive set. | | 272 | Transmit aborted frames for the port viewed. This can be due to aging, flushing, or abortion decision by the rewriter. | | 512 + 513 | Green and yellow drops for service counter viewed. | | 768 – 769 | Green and yellow transmissions for service counter viewed. | The service counters are reduced in size; 10 bits for the frame part and 18 bits for the octet part. However, STAT\_CFG.STAT\_SRV\_PKT\_ONLY can be set to use all 28 bits for frame counting. The following table lists the registers associated with statistics access. Table 145 • Statistics Registers Overview | Register | Description | Replication | |----------------|-------------------------------------------------------------|-------------| | QSYS::STAT_CFG | Selects which counter set index to access. Clears counters. | None | | QSYS::CNT | Replicated register with statistics access. | 1,024 | | QSYS::DP_MAP | Maps DP levels to color. | None | Examples: To read number of transmitted yellow frames for service counter 714: - Write 714 to STAT VIEW in QSYS::STAT CFG. - 2. Read QSYS::CNT[385]. To read number of discarded green octets with QoS class 4 on port 9: - 1. Write 9 to STAT VIEW in QSYS::STAT CFG. - Read QSYS::CNT[76] for the least significant bits. - 3. Read QSYS::CNT[140] for the most significant bits. ## 3.22.9.5 Energy Efficient Ethernet (EEE) Control The front ports are able to signal low power idle (LPI) towards the MACs, in case they request the PHYs to enter low power mode. A controller in each port module assures that frames are not transmitted when the PHYs are powered down. This controller powers the PHY down when there is nothing to transmit for a while, and it powers up the PHY when there is either data ready for a configurable time or when the queue system has urgent data ready requiring transmission as soon as possible. The following table lists the registers with configuring EEE. Table 146 • EEE Registers Overview | Register | Description | Replication | |-----------------|--------------------------------------------------------------------------------------------------------------------|-------------| | QSYS::EEE_CFG | Configures the priorities per port which should bring the port alive as fast as possible. | Per port | | QSYS::EEE_THRES | Configures the amount of cells or frames pending for a priority before the port should request immediate power up. | Per port | Example: Configure the device to power up the PHYs when 10 frames are pending. Only ports 3 through 6 should regard their data as urgent and only for priorities 6 and 7. All other data should get transmitted when the EEE controller in the port has seen pending data for the controller configured time. - Write 10 to QSYS::EEE THRES:EEE HIGH FRAMES. - 2. Write 0xC0 to QSYS::EEE CFG[3-6]::EEE FAST QUEUES. ## 3.22.9.6 Calendar Setup There are a number of logical ports, all needing bandwidth into and out of the queue system. This is controlled through a calendar module that grants each port access to internal busses. The following illustration shows an overview of the internal busses. All ports are connected to a port data bus (taxi bus) and granted access to the chip core through a mux obeying the calendar decision. Similarly, on the path towards the transmit interface, a mux controls which port transmits the next time. Figure 70 • Internal Bus The front ports are connected to taxi busses and must be guaranteed bandwidth that corresponds to their line speed. The internal CPU ports and loopback paths can operate up to 10 Gbps (7.5 Gbps for VD0). In any port configuration, a subset of the ports is enabled. The calendar algorithm is the central place where bandwidth is distributed between the ports. The calendar algorithm can be controlled by two methods: automatic or sequenced. In the automatic calendar configuration, a configuration per port defines if the port is granted 0 Gbps, 1 Gbps, 2.5 Gbps, or 10 Gbps bandwidth. For the four internal ports, the bandwidth granted is half of these choices. In other words, internal CPU port 1 can be granted 1.25 Gbps in bandwidth. In the sequenced operation, a specific sequence of port numbers forms the calendar. The port sequence controls which port is granted the cycle, per bus cycle (two system clock periods). The algorithm mode is configured in CAL\_CTRL.CAL\_MODE. It is possible through this register to program a manual sequence, to halt the calendar, and to select between sequenced and automatic calendars. Both calendar modes may leave some slots unallocated and therefore idle on the busses. These idle cycles can be used for configuration access (which will wait for unused cycles) and other slow operations in the system (MAC table scan, for example). Slots allocated for a port and not used due to lack of data to transfer can be used by the internal ports through the HSCH::OUTB\_\* registers, where it is, per internal port, configured how often it will seek granting of an unused cycle. Setting internal CPU port 0 to seek access every five cycles means that it can get up to one frame transfer every 64 ns, or approximately 10 Gbps. In the ingress side, the loopback paths can use idle cycles if enabled in the assembler, which controls the ingress mux. The following table list the registers associated with configuring the calendar function. Table 147 • Calendar Registers Overview | Register | Description | | |--------------------|-------------------------------------------------------------------------------------------|--| | CAL_CTRL | Calendar function mode. Configures auto-grant rate. | | | OUTB_SHARE_ENA | Enables granting unused bus cycles to the internal ports (CPU and VD) on the egress side. | | | OUTB_CPU_SHARE_ENA | Configures bandwidth sharing between the two internal CPU ports. | | | CAL_SEQ | Interface to the sequence memory. See register list. | | | CAL_AUTO | Per port setting with requested bus bandwidth. | | # 3.23 Automatic Frame Injector The automatic frame injector (AFI) provides mechanisms for periodic injection of PDUs such as 1588 PDUs. The following blocks are involved in frame injection. - QSYS. The frames are sent into the queue system by the CPU and stored in the queue system until deleted by software. - AFI. Using timers and other parameters, AFI controls the automatic frame injection. - REW. For outbound data path injections, the REW performs frame modifications. - Loopback path. The loopback path (VD1) between the disassembler and assembler is used to inject frames into the inbound data path. - ANA. For inbound data path injections, the ANA performs modifications of frames. AFI supports two types of automatic frame injection: timer triggered (TTI) and delay triggered (DTI). Timer Triggered Injection (TTI). Frame injection rate is controlled by timers with typical values of approximately 3 ms or higher. Only single-frame injections are supported; injection of sequences of frames is not supported. For each frame, jitter can be enabled for the associated injection timer. Timer triggered injection can be combined with delay triggered injection. Delay Triggered Injection (DTI). A sequence of frames, including configurable delay between frames, is injected. Delay triggered injection can be combined with TTI, such that DTI is used to inject a (high) background load (imitating normal user traffic), and TTI is used to inject OAM PDUs for measuring IR, FLR, FTD, and FDV. AFI supports up to 16 active DTI frame sequences at a time. ## 3.23.1 Injection Tables The main tables used to configure frame injection are frame table, DTI table, and TTI table. Injection frames for both TTI and DTI are configured in the frame table. The frame table itself does not hold the frame, but rather a pointer to where the frame is located in the buffer memory within QSYS. For DTI, frames can be configured into a linked list of frames to be injected. Each frame in the linked list may be configured to be injected multiple times before proceeding with the next frame in the chain. Each frame in the sequence is followed by one or more delay entries, specifying the delay between injections. Timers for each TTI frame are configured in the TTI table. TTIs are always single frame injections, so the injection and next ptr fields in the frame table are unused for TTI. Delay entries are not used for TTI. The TTI calendar controls the frequency with which different parts of the TTI table are serviced. Figure 71 • Injection Tables ## 3.23.2 Frame Table The following table lists the registers associated with configuring parameters for each entry in the frame table. Table 148 • Frame Table Entry Register Overview (2048 entries) | Register | Field | Description | | |-------------------------------------|------------|-----------------------------------------------------------------------------------------------------|--| | FRM_NEXT_AND_TYPE | NEXT_PTR | Next entry in table. Does not apply for TTI. | | | FRM_NEXT_AND_TYPE | ENTRY_TYPE | E Entry type: Frame or Delay entry. Does not apply for TTI. | | | ENTRY_TYPE=Frame<br>FRM_ENTRY_PART0 | INJ_CNT | Number of times to inject frame. Does not apply for TTI. | | | | FRM_RM | Frame removal. See Removing Injection Frames, page 241. | | | | FRM_GONE | Frame removal. | | | | FRM_INFO | Frame information. See MISC:NEW_FRM_INFO.FRM_INFO. | | | ENTRY_TYPE=Delay<br>FRM_ENTRY_PART0 | DELAY | Delay between injection of start of frames. Unit is one system clock cycle. Does not apply for TTI. | | ## 3.23.3 Delay Triggered Injection Delay triggered injection supports up to 16 flows at a time. For each DTI flow, the DTI table holds a pointer to a sequence of frames and delay entries, as well as the queue and port number, into which the frames are injected. The NEXT\_PTR field of the frame table is used to link frames and delay entries together into a sequence. The frame sequence can have any length, only limited by the size of the frame table. Each DTI sequence can be configured to be injected repeatedly until stopped, or injected a specified number of times. For example, if the frame sequence consists of five frames with INJ\_CNT = 1, and the sequence is configured to be injected 1000 times, then a total of 5000 frames will be injected. DTI can be used in conjunction with TTI, for example, using TTI to inject OAM PDUs for measuring performance metrics of the service. The following table lists the registers associated with configuring the parameters for each of the 16 entries in the DTI table. Table 149 • DTI Table Entry Registers Overview | Register | Field | Description | Replication | |-------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------| | DTI_MODE | MODE | Mode of DTI instance. | Per DTI | | DTI_MODE | TRAILING_DELAY_<br>SEQ_CNT | Only applies "trailing delay" for every Nth sequence injection. See Fine Tuning Bandwidth of Multiframe Sequence, page 232. | Per DTI | | DTI_MODE | DTI_NEXT | Used for concatenating DTIs. Next DTI to activate when this DTI completes. | Per DTI | | DTI_FRM | FIRST_FRM_PTR | Pointer to first frame in frame sequence. | Per DTI | | DTI_FRM | NEXT_FRM_PTR | Pointer to next frame in frame sequence. | Per DTI | | DTI_CNT | CNT | Counter (mode dependent). | Per DTI | | DTI_PORT_QU | PORT_NUM | Port number on which injection queue transmits. | Per DTI | Miscellaneous DTI related parameters are shown in the following table. Table 150 • Miscellaneous DTI Parameters | Register | Field | Description | Replication | |----------|-------|----------------------------------------------------|-------------| | DTI_CTRL | BW | Bandwidth of DTI flow<br>0: <5 Gbps<br>1: >=5 Gbps | Per DTI | | DTI_CTRL | ENA | Enables DTI | Per DTI | Frame entries in a DTI sequence may point to the same frame in the queue system's buffer memory. For example, shown in the following illustration, frame A and frame B shown may point to the same frame in the buffer memory. The delay entries in a DTI sequence must be configured such that they are longer than the transmission time (given the port speed) of the preceding frame in the sequence. If a DTI sequence is configured with two consecutive frame entries, then these will be injected with a minimum delay of approximately 14 clock cycles. ## 3.23.3.1 Frame-Delay Sequence A DTI flow typically consists of a sequence of alternating frame/delay entries in the frame table. If a given frame is to be injected multiple times (FRM\_ENTRY\_PART0.INJ\_CNT>1), then the delay of the following entry in the sequence is applied after each injection. If additional delay is required after the last injection, then this can be achieved by an additional delay entry. The use of delay entries is shown in the following illustration. Figure 72 • DTI Frame/Delay Sequence Example ### 3.23.3.2 Bandwidth Fine Tuning The combination of INJ\_CNT and two following delay entries can be used to fine tune the rate generated by a DTI flow. This is shown in the following illustration, where a small delay after the four injections of frame A is used to fine tune the rate of the DTI flow. Figure 73 • Fine Tuning Bandwidth of DTI Sequence By combining the setting of INJ\_CNT and the DELAY value of the last delay depicted, the bandwidth of the DTI sequence can be controlled with high granularity, because the additional (blue) delay will only be applied for every INJ\_CNT injections of frame A. The bandwidth adjustment mechanism shown may be insufficient for controlling the bandwidth of multiframe sequences (sequences with different frames), because the last delay will be applied for every injection of the frame sequence. ### 3.23.3.3 Fine Tuning Bandwidth of Multiframe Sequence For multiframe sequences, additional fine tuning of the bandwidth of the entire sequence can be achieved by configuring the last delay in the sequence, also known as the "trailing delay", to only be applied for every Nth injection of the sequence. This is achieved using the TRAILING DELAY SEQ CNT parameter and is shown in the following illustration. Figure 74 • Fine Tuning Bandwidth of Multiframe DTI Sequence ## 3.23.3.4 Burst Size Test Using Single DTI If a NEXT\_PTR is set to point back to a previous entry in the sequence, then injection will continue forever, that is, until the DTI is stopped. This is depicted in the following illustration. The configuration shown can be used for leaky bucket burst size testing, where the first part of the sequence empties the bucket, followed by a steady frame flow with the rate of the leaky bucket. Figure 75 • DTI Frame/Delay Sequence Using Inject Forever Resulting frame sequence: ## 3.23.3.5 Burst Size Test Using DTI Concatenation Two (or more) DTIs can be concatenated, such that when one DTI completes, another DTI is activated. This is depicted in the following illustration. It can be used for leaky bucket burst size testing, where the first part of the sequence empties the bucket, followed by a steady frame flow with the rate of the leaky bucket. Note that when DTI concatenation is used, the last delay entry in the frame-delay sequence of the first DTI is not awaited before starting the next DTI. That is, the next DTI is started when the first DTI reads an entry with NEXT\_PTR = 0. As shown in the illustration, the delay between the last Frame A and the first Frame B will not be 150 clock cycles, but instead approximately 12 clock cycles. If this is considered problematic, it can be addressed by using an additional DTI with a sequence consisting only of two delay entries. For example, DTI #2 could be inserted between DTI#1, and DTI#3 and DTI#2 could then be configured with a sequence consisting of two delay entries, with the first having delay = 150. Figure 76 • DTI Concatenation #### 3.23.3.6 DTI Bandwidth For 64 bytes frames, AFI can inject up to 10.5 Gbps at 156 MHz clock frequency and up to 3.25 Gbps at 52 MHz clock frequency for a single DTI flow or inject a total bandwidth, across all DTI flows, of up to 26 Gbps at 156 MHz and up to 8 Gbps at 52 MHz. Higher injection bandwidths can be supported for frame sizes larger than 64 bytes. Injections into ingress data path must be forwarded through VD1. For 64 bytes frames, the maximum bandwidth through VD1 is 10.5 Gbps at 156 MHz and up to 3.25 Gbps at 52 MHz. **Note:** Depending on port configuration, cell bus bandwidth may impose additional bandwidth limitations. The bandwidth that a DTI is injecting into a queue must not exceed the bandwidth, that HSCH is transmitting from the queue, because the port's FRM\_OUT\_MAX will then be reached, possibly affecting other DTIs injecting on the same port. For more information, see Port Parameters, page 241. The only exception is if there is only one DTI injecting on the port, because there are no other DTIs that could be affected. ### 3.23.3.7 DTI Sequence Processing Time For high bandwidth DTI flows, the time it takes to process the delays and frames in a DTI sequence must be taken into account: - Processing a frame entry with no succeeding delay entry takes 12 clock cycles. - Processing a frame entry with a succeeding delay entry takes 12 clock cycles. - Processing a delay entry, which does not succeed a frame entry takes 12 clock cycles. For example, a sequence consisting of a frame entry followed by two delay entries will take 24 clock cycles to process. If the frame is a 64-byte frame and the clock period is 4 ns, this will corresponds to a maximum flow bandwidth of approximately 7 Gbps ( $(64 + 20) \times 8$ bits/ $(24 \times 4 \text{ ns}) = 7$ Gbps), regardless of the delay values configured for the two delays. Although it takes 12 clock cycles to process a delay entry, it is valid to configure a delay entry with a delay smaller than 12 clock cycles, because this will be compensated for when generating the delay between later frames in the sequence. For more information, see Figure 74, page 233. For example, the delay between the rightmost frame B and the succeeding frame A will be 150 + 12 clock cycles (instead of 150 + 1). To compensate for this, however, the delay between the succeeding two frames A will be 150 - 11 clock cycles. # 3.23.4 Timer Triggered Injection For TTIs, frame injection is controlled by timers. To control the time between injections, configure the following registers for each TTI: - TTI\_TIMER.TICK\_IDX. For each TTI, one of eight configurable timer ticks shown in the following table must be chosen. - TTI\_TIMER.TIMER\_LEN. The number of timer ticks that must elapse between each injection. That is, the period between each injection becomes tick period × TIMER LEN. The following table lists the registers associated with TTI timer tickers. Table 151 • TTI Timer Ticks Registers Overview | Register | Field | Description | n | | | Replication | |-----------------------------------|----------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------|-------------| | TTI_TICK_LEN_0_3 TTI_TICK_LEN_4_7 | | specified a preceding is the shor longest. | of each of the second s | ck, and timer | of the<br>dx>-1). Timer 0 | 8 | | | | | nfiguration: | Tiel Desig | a. | | | | | tick_idx | tick_len | Tick_Perio | | | | | | 0 | 1 | 52 µs | (1 × 52 µs) | | | | | 1 | 8 | 416 µs | (8 × 52 µs) | | | | | 2 | 8 | 3.3 ms | (8 × 416 µs) | | | | | 3 | 3 | 10 ms | (3 × 3.3 ms) | | | | | 4 | 10 | | (10 × 10 ms) | | | | | 5 | 10 | 1 second | ` , | | | | | 6 | 10 | 10 seconds | (10 × 1 sec) | | | | | 7 | 6 | 1 minute | (6 × 10 sec) | | | TTI_TICK_BASE | BASE_LEN | Length of | ΓΤΙ base ticl | k in system c | lock cycles. | 1 | The following table lists the registers associated with configuring parameters for each of the 2K entries in the TTI table. Table 152 • TTI Parameters (2048 entries) | Register | Field | Description | Replication | |-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | TTI_PORT_QU | PORT_NUM | Port number on which injection queue transmits. | Per TTI | | TTI_TIMER | TICK_IDX | Which of the eight timer ticks is used by the timer controlling the injection of this frame. | Per TTI | | TTI_TIMER | JITTER_MODE | Enables jitter for the number of timer ticks between each injection of this frame. 0: No jitter. 1: Timer is set to a random value in the range [TIMER_LEN*0.75; TIMER_LEN]. 2: Timer is set to a random value in the range [TIMER_LEN*0.50; TIMER_LEN]. 3: Timer is set to a random value in the range [1;TIMER_LEN]. | Per TTI | Table 152 • TTI Parameters (2048 entries) (continued) | Register | Field | Description | Replication | |--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | TTI_TIMER | TIMER_LEN | Number of timer ticks between each injection of this frame. 0: Disables timer. 0xff: Injects frame next time the entry is serviced. After servicing, hardware sets TIMER_LEN to 0. This is intended to be used during removal of frame from buffer memory. See Removing Injection Frames, page 241. | Per TTI | | TTI_FRM | FRM_PTR | Points to the frame (in frame table), which the TTI injects. | Per TTI | | TTI_TICKS | TICK_CNT | Number of ticks until next injection. Should be set to a random value in the range 1-TIMER_LEN before starting TTI. | Per TTI | | TTI_MISC_CFG | INJ_CNT_ENA | Enables counting of injected frames in TTI_MISC:TTI_INJ_CNT.TTI_INJ_CNT. | Per TTI | An entry in the TTI table is checked approximately every two clock cycles. If the TTI's tick (configured through TICK\_IDX) has changed, then the TICK\_CNT is decremented. If it becomes zero, the frame is injected, and TICK\_CNT is set to TIMER\_LEN. ### 3.23.4.1 TTI Calendar In default configuration, TTI table entries are serviced from 0-2047, then restarted again at entry 0. When configuring the TTI table, the following must be considered: - It takes up to 4 clock cycles, worst-case, to service an entry in the TTI table. - A TTI must be serviced more frequently than the frequency of the TTI's tick (see TTI\_TIMER.TICK\_IDX). This means that looping through the entire TTI table may take $2048 \times 4 = 8192$ clock cycles. With a clock period of 4 ns, this corresponds to approximately $66 \mu s$ . In other words, no TTI must use a tick faster than $66 \mu s$ . If TTIs faster than $66 \mu s$ are required, the TTI calendar can be used to have some entries in the TTI table serviced more often than others, meaning the TTI table can be split into sections with TTIs using ticks of different speeds. The TTI calendar consists of four entries, as described in Table 6 Table 153 • TTI Calendar Registers Overview | Register | Field | Description | Replication | |-------------------|--------------------------------|---------------------------------------------------------------------------------------|-------------| | TTI_CAL_SLOT_PTRS | SLOT_START_PTR<br>SLOT_END_PTR | Calendar slot's frame table start and end pointer. | 4 | | TTI_CAL_SLOT_CNT | SLOT_CNT | Number of TTIs to service in slot before moving to next TTI calendar slot. | 4 | | TTI_CTRL | TTI_CAL_LEN | Length of TTI calendar. | 1 | | TTI_CTRL | TTI_INIT | When set, initializes calendar to start at calendar slot 0. Cleared by AFI when done. | 1 | The following illustration shows a configuration for the TTI calendar. In this case, only TTI entry 0-1023 are being used. Figure 77 • TTI Calendar Example In the example, it takes $(256/2) \times (1 + 2) \times 4 = 1536$ clock cycles to service all TTIs in the blue section. With a clock cycle of 4 ns, the TTIs in the blue section must not use ticks faster than $1536 \times 4 = 6144$ ns. Similarly, the 768 TTIs in the red section must not use ticks faster than $(768/1) \times (1+2) \times 4 \times 4$ ns = ~36.9 $\mu$ s ### 3.23.4.2 Other TTI Parameters Other TTI-related parameters are listed in the following table. Table 154 • Miscellaneous TTI Registers Overview | Register | Field | Description | Replication | |-------------|-------------|-----------------------------------------------------------------------------------------|-------------| | TTI_CTRL | TTI_ENA | Enables TTI. Before enabling TTI, TTI_INIT should be used to initialize calendar state. | 1 | | TTI_INJ_CNT | TTI_INJ_CNT | Number of TTI injections. Enabled per TTI using TTI_TBL:TTI_MISC_CFG.INJ_CNT_ENA. | 1 | ## 3.23.4.3 TTI Table Update Engine (AFI TUPE) The AFI Table Update Engine (AFI TUPE) can be used to quickly update a large number of entries in the TTI Table such as disabling or enabling timers in fail-over scenarios. AFI TUPE related parameters are listed in the following table. The parameters prefixed with CRIT are used to specify the criteria, which TTIs fulfill in order for TUPE to apply. Table 155 • AFI TUPE Registers Overview | AFI:TUPE<br>Register | Field | Description | Replication | |----------------------|------------------------|-----------------------------------------------------------|-------------| | TUPE_MISC | TUPE_START | Start TUPE. | 1 | | TUPE_MISC | CRIT_TUPE_CTRL_VAL_ENA | Enable use of CRIT_TUPE_CTRL_VAL and CRIT_TUPE_CTRL_MASK. | 1 | | TUPE_MISC | CRIT_PORT_NUM_ENA | Enable use of CRIT_PORT_NUM_VAL. | 1 | Table 155 • AFI TUPE Registers Overview (continued) | AFI:TUPE<br>Register | Field | Description | Replication | |----------------------|---------------------|------------------------------------------------------------------------|-------------| | TUPE_MISC | CRIT_QU_NUM_ENA | Enable use of CRIT_QU_NUM_VAL. | 1 | | TUPE_MISC | CMD_TIMER_ENA_ENA | Enable use of CMD_TIMER_ENA_VAL. | 1 | | TUPE_MISC | CMD_TIMER_ENA_VAL | TUPE command parameter: New TIMER_ENA value. | 1 | | TUPE_MISC | CMD_PORT_NUM_ENA | Enable use of CMD_PORT_NUM_VAL. | 1 | | TUPE_MISC | CMD_QU_NUM_ENA | Enable use of CMD_QU_NUM_VAL. | 1 | | TUPE_ADDR | TUPE_START_ADDR | First address in TTI table for AFI TUPE to process. | 1 | | TUPE_ADDR | TUPE_END_ADDR | Last address in TTI table for AFI TUPE to process. | 1 | | TUPE_CRIT1 | CRIT_PORT_NUM_VAL | TUPE criteria parameter controlling which TTI table entries to update. | 1 | | TUPE_CRIT1 | CRIT_QU_NUM_VAL | TUPE criteria parameter controlling which TTI table entries to update. | 1 | | TUPE_CRIT2 | CRIT_TUPE_CTRL_MASK | TUPE criteria parameter controlling which TTI table entries to update. | 1 | | TUPE_CRIT3 | CRIT_TUPE_CTRL_VAL | TUPE criteria parameter controlling which TTI table entries to update. | 2 | | TUPE_CMD1 | CMD_PORT_NUM_VAL | TUPE command parameter: New PORT_NUM value. | 1 | | TUPE_CMD1 | CMD_QU_NUM_VAL | TUPE command parameter: New QU_NUM value. | 1 | The following TTI parameters can be used as part of the TUPE criteria: - PORT NUM - QU NUM - TUPE CTRL The parameters prefixed "CMD" specify the commands, which are applied to any TTIs, which fulfill the TUPE criteria. Using the TUPE command parameters, the following TTI parameters can be changed: - TIMER ENA - Timers can be enabled/disabled. - PORT\_NUM - Injections can be moved to a different port. - QU\_NUM - Injections can be moved to a different queue. While TUPE is running no injections will be performed for any TTIs which match the configured TUPE criteria and fall within the configured TUPE address range. The TUPE\_CTRL field in the TTI Table can be used to classify TTIs into different groups, such that a TUPE command can easily address all TTIs within such group. The following illustration depics the AFI TUPE functionality. Figure 78 • AFI TUPE The full algorithm used by AFI TUPE is shown in the following pseudo code. Configuration parameters are prefixed "csr.". ``` // AFI Table UPdate Engine (AFI TUPE) Algorithm bool tupe_ctrl_match; for (addr = csr.tupe_start_addr; addr < csr.tupe_end_addr; addr++) {</pre> tti_tbl_entry = tti_tbl[addr]; tupe_ctrl_match = FALSE; for (i = 0; i < 2; i++) { if ((tti_tbl_entry.tupe_ctrl & csr.crit_tupe_ctrl_mask) == csr.crit_tupe_ctrl_val[i]) { tupe_ctrl_match = TRUE; } if ( (// Check matching TUPE_CTRL value tupe_ctrl_match) (// If enabled, check if TTI's PORT_NUM matches csr.crit_port_num_val !csr.crit_port_num_ena (tti_tbl_entry.port_num == csr.crit_port_num_val)) (// If enabled, check if TTI's QU_NUM matches csr.crit_qu_num_val !csr.crit_qu_num_ena (tti_tbl_entry.qu_num == csr.crit_qu_num_val)) ) { // TTI fulfills criterias => Apply TUPE command to TTI // timer_ena if (csr.cmd_timer_ena_ena) { tti_tbl_entry.timer_ena = csr.cmd_timer_ena_val; ``` ``` } // port_num if (csr.cmd_port_num_ena) { tti_tbl_entry.port_num = csr.cmd_port_num_val; } // qu_num if (csr.cmd_qu_num_ena) { tti_tbl_entry.qu_num = csr.cmd_qu_num_val; } // Write back to TTI table tti_tbl[addr] = tti_tbl_entry; } ``` # 3.23.5 Injection Queues DTI and TTI may inject into any egress queue in the queue system. In injection context, the queues can be divided into the following categories: - Normal queues. These queues are processed by each level of SEs in HSCH. Frames injected into such queues are thus subject to the M-DWRR and shaping algorithms of the SEs. Frames are injected into the tail of the selected queue. - Port injection queue without shaping. These queues, one for each port, inject frames on the port with higher priority than normal queues. The state of the DLB shaper is disregarded and is not updated with the size of the transmitted frame. - Injected frames are injected into the tail of the queue, but due to the high priority, the queue will normally be (almost) empty. - Port injection queue with shaping. These queues, one for each port, inject frames on the port with higher priority than normal queues. The state of the port shaper is respected and is updated with the size of the transmitted frame. Injected frames are injected into the tail of the queue, but due to the high priority, the queue will normally be (almost) empty. The queue into which a TTI or DTI injects frames is controlled by the QU\_NUM parameter. The actual value to be used for these parameters depend on the HSCH configuration. For more information, see Queue Mapping, page 216. For injections into the ingress data path, frames must be looped through VD1 and QU\_NUM must be configured to select a VD1 queue. # 3.23.6 Adding Injection Frame To add a frame for injection by AFI, the CPU must follow this procedure: - 1. Set AFI::MISC CTRL.AFI ENA to 1 before any use of AFI. - Send the frame to AFI. AFI\_INJ must be set in the IFH. For more information, see Frame Headers, page 17. - 3. Poll AFI::NEW FRM CTRL.VLD to await the frame being received by AFI. - 4. When the frame has been received by AFI, then copy frame information from AFI::NEW\_FRM\_INFO to an unused entry in the Frame table. - 5. Clear AFI::NEW\_FRM\_CTRL.VLD. - 6. TTI: Set up the TTI table to have the frame injected with the desired interval and to the desired queue and port. For more information, see Timer Triggered Injection, page 235. - 7. DTI: For injection of a sequence of frames, repeat steps 1 through 4. Set up the DTI Table to inject the frames. For more information, see Table 149, page 231. Configure other DTI parameters. For more information, see Table 150, page 231. ## 3.23.7 Starting Injection TTI is enabled by using TTI\_INIT to initialize and then setting TTI\_ENA = 1. Each TTI is started by setting TIMER LEN a non-zero value. Each DTI is started by setting DTI CTRL.ENA = 1. # 3.23.8 Stopping Injection Each TTI is stopped by setting TIMER\_LEN to 0. All TTIs can be stopped by setting TTI ENA = 0. Each DTI is stopped by setting DTI CTRL.ENA = 0. ## 3.23.9 Removing Injection Frames This section provides information about removing a single frame (TTI) or frame sequence (DTI) from the buffer memory. ### 3.23.9.1 Single Frame (TTI) To remove a single frame from buffer memory, the frame must be injected one more time. This "removal injection" does not result in a frame transmission, but purely serves to remove the frame from the buffer memory. Use the following procedure to remove a single frame from buffer memory. - 1. Set the FRM RM bit for frame in the frame table. - 2. For TTI: Set TIMER LEN to 0x1ff. - 3. Poll the FRM GONE bit until it gets set by AFI. When performing removal injection, injection must be enabled for the corresponding port by setting AFI:PORT\_TBL[<port>]:PORT\_CFG.FRM\_OUT\_MAX != 0. ## 3.23.9.2 Frame Sequence (DTI) Use the following procedure to remove a DTI frame sequence from buffer memory. - 1. Disable the DTI by setting DTI CTRL.ENA = 0. - 2. Set the FRM\_RM bit for each frame to be removed in the frame table. - 3. Set DTI FRM.NEXT FRM PTR to DTI FRM.FIRST FRM PTR. - 4. Set DTI MODE.MODE = 0. - 5. Set DTI CNT.CNT = 1. - 6. Set DTI\_MODE.FRM\_INJ\_CNT to 0. - 7. Optionally, set all delays in sequence to 0 to speed up the removal procedure. - 8. Set DTI\_CNT\_DOWN.CNT\_DOWN to 0. - 9. Enable the DTI by setting DTI CTRL.ENA = 1. - 10. Poll the FRM GONE for the last frame to be removed until the bit gets set by AFI. This procedure causes the frames to be injected one last time and through this, be removed from buffer memory. The frames will not actually be transmitted on the destination port. When performing removal injection, injection must be enabled for the corresponding port by setting AFI:PORT\_TBL[<port>]:PORT\_CFG.FRM\_OUT\_MAX != 0. #### 3.23.10 Port Parameters To ensure that the queue system does not overflow with injected frames, for example, if a port is in flow control, an upper bound on the number of injected, but not yet transmitted, frames per port can be configured in FRM\_OUT\_MAX. If FRM\_OUT\_MAX is reached, then any DTI injections are postponed until the number of outstanding frames falls below FRM\_OUT\_MAX. TTI injections uses a slightly higher limit of FRM\_OUT\_MAX+TTI\_FRM\_OUT\_MAX. This ensures that TTI injection are still possible, even if a DTI flow faster than the port speed has been configured. If PFC is used in conjunction with automatic frame injection, then either all frames must be injected into queues controlled by the same flow control priority, or all frames must be injected into queues that cannot be stopped by PFC. If EEE is used in conjunction with automatic frame injection, then all frames for that port must be injected into queues with the same urgent configuration. Setting FRM OUT MAX = 0 will stop all injections on port. Table 156 • Port Parameters | Register | Field | Description | Replication | |------------------|-----------------|-----------------------------------------------------------------------------------|-------------| | PORT_CFG | FRM_OUT_MAX | Maximum number of injections outstanding for the port at-a-time. | Per port | | PORT_CFG | FRM_RM_ONLY | Only allows frame removal injections. That is, normal injections are not allowed. | Per port | | TTI_PORT_FRM_OUT | TTI_FRM_OUT_MAX | Additional injections that can be outstanding before affecting TTI injection. | Per port | ## 3.24 Rewriter The switch core includes a rewriter (REW) that is common for all ports. The rewriter performs all frame editing prior to frame transmission. Each frame can be handled multiple times by the rewriter - One time per destination port. - One time towards the mirror target port. - One time when copied or redirected to internal and/or external CPU. - One time when looped back to the analyzer. All frames that are input to the rewriter can be modified by previous blocks of the frame processing flow. The internal frame header informs the rewriter what ingress frame manipulations (popping) are performed on any given frame. The same ingress frame manipulation is performed for each copy of a frame, while the rewriter may perform per destination specific egress frame manipulations (pushing) to the frame. The rewriter is the final step in the frame processing flow of the device. # 3.24.1 Rewriter Operation The rewriter supports the following frame operations. - VLAN tag (802.1Q, 802.1ad) editing: tagging of frames and remapping of PCP and DEI. - L3 routing. SMAC/DMAC, VID and TTL modifications for IPv4 and IPv6. - Implement Precision Time Protocol (PTP) time stamping by interfacing to the PTP block. - Interfacing to the loopback block. Loopback frames to ANA based on VCAP\_ES0 actions. Rewriting MACs and IFH of looped frames. - DSCP remarking: rewriting the DSCP value in IPv4 and IPv6 frames based on classified DSCP value. - Insert or update VSTAX headers. - Handling of both Rx and Tx mirror frames. - · Padding of undersize frames to 64 bytes or 76 bytes. - · Frame FCS update control. - · Add preamble to all frames with an external port destination. # 3.24.2 Supported Ports The device operates with up to 11 physical ports, two loopback ports, and two DEVCPU extraction ports as possible frame destinations. These frame destinations are addressed by the rewriter using the egress port number. ## 3.24.3 Supported Frame Formats The rewriter can identify and rewrite both headers and payload of the following frame types. #### **Ethernet Frames** - Ethernet link layer DMAC+SMAC - Maximum of three VLAN Q-tags (802.1Q, 802.1ad) - Payload (IPv4, IPv6, Y.1731 OAM, PTP, and so on) The analyzer places information in the IFH to help the rewriter with frame identification. The IFH fields, IFH.DST.ENCAP.W16 POP CNT and IFH.DST.ENCAP.TYPE AFTER POP, are used for this purpose. ### 3.24.3.1 Maximum Frame Expansion The rewriter can push 60 bytes into a frame when the IFH is popped and when no other frame pop operations are done. The frame preamble will occupy 8 of the 60 bytes that can be pushed. ### 3.24.4 Rewriter Initialization Rewriter initialization comprises two steps: - Set REW::RAM INIT.RAM ENA to 1 - Set REW::RAM INIT.RAM INIT to 1 Before the rewriter can be configured, the RAM-based configuration registers must be initialized by writing a 1 to the above RAM\_INIT registers. The RAM\_INIT.RAM\_INIT register is reset by hardware when the initialization is complete. If VCAP\_ES0 is enabled, it must be initialized. All of the default port actions in VCAP\_ES0 should also be initialized to ensure proper operation. For more information about initializing VCAP\_ES0, see Versatile Content-Aware Processor (VCAP), page 49. # 3.24.5 VCAP\_ES0 Lookup The rewriter performs stage 0 VCAP egress matching (VCAP\_ES0) lookups for each frame when enabled. The following table lists the registers associated with VCAP\_ES0 lookup. Table 157 • ES0 Configuration Registers | Register | Description | Replication | |-----------------------------|------------------------------------------------------------------------------------------------------------------------------|-------------| | ES0_CTRL.<br>ES0_LU_ENA | Enables lookup in VCAP_ES0 to control advanced frame modifications. | None | | ES0_CTRL.<br>ES0_BY_RLEG | Enables ES0 router mode lookup when IFH.FWD.DST_MODE indicates routing. | None | | ES0_CTRL.<br>ES0_BY_RT_FWD | Enables ES0 router mode lookup when IFH.DST.ENCAP.RT_FWD indicates routing. | None | | PORT_CTRL.<br>ES0_LPORT_NUM | Maps the configuration port to a logical port number to be used by ES0 keys. The port used in the lookup can be Tx-mirrored. | Ports | VCAP\_ES0 lookup is enabled by setting REW::ES0\_CTRL.ES0\_LU\_ENA = 1. Frames destined to the DEVCPU cannot be rewritten, and there is no VCAP\_ES0 lookup for these frames. All ES0 actions are ignored when VCAP\_ES0 is disabled. There are two ES0 key types: VID and ISDX. The VID key is always used if: - IFH.FWD.ES0 ISDX KEY ENA = 0 - REW::ES0\_CTRL.ES0\_BY\_RLEG = 1 and (IFH.FWD.DST\_MODE = L3UC\_ROUTING or IFH.FWD.DST\_MODE = L3MC\_ROUTING) - REW::ES0 CTRL.ES0 BY RT FWD = 1 and IFH.DST.ENCAP.RT FWD = 1. The ISDX key is used if a VID key is not used and IFH.FWD.ES0\_ISDX\_KEY\_ENA = 1. Table 158 • VCAP\_ES0 Keys | Key Field | Description | Size | ISDX | VID | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-----| | X1_TYPE | X1 type. 0: ISDX. 1: VID. | 1 | Х | х | | EGR_PORT | Logical egress port number. Configuration port mapped via REW::PORT_CTRL.ES0_LPORT_NUM. The default is no mapping (EGR_PORT = configuration port number). The configuration port is either the physical port or a Tx-mirror port number. | 4 | Х | Х | | PROT_ACTIVE | Protection is active. Value is IFH.ENCAP.PROT_ACTIVE. | 1 | Х | Х | | VSI | Virtual Switch Instance. Default value is VSI = IFH.DST.ENCAP.GEN_IDX if IFH.DST.ENCAP.GEN_IDX_MODE = 1 else 0. The following conditions will change the default: If REW::ES0_CTRL.ES0_BY_RLEG = 1 and (IFH.FWD.DST_MODE = L3UC_ROUTING or IFH.FWD.DST_MODE = L3MC_ROUTING) Force VSI = 0x3ff to identify routing. If REW::ES0_CTRL.ES0_BY_RT_FWD = 1 and IFH.ENCAP.RT_FWD = 1. | 7 | X | x | | | Force VSI = 0x3ff to identify routing. | | | | | COSID | Class of Service Identifier. Value is IFH.VSTAX.MISC.COSID if REW::PORT_CTRL.VSTAX2_MISC_ISDX_ENA = 1 else 0. | 3 | Х | Х | | COLOR | Frame color. Value is IFH.VSTAX.QOS.DP mapped through REW::DP_MAP.DP. | 1 | х | Х | | SERVICE_FRM | Service frame. Set to 1 if IFH.VSTAX.MISC.ISDX > 0 and REW::PORT_CTRL.VSTAX2_MISC_ISDX_ENA = 1 else 0. | 1 | Х | Х | | ISDX | Ingress Service Index. Value is IFH.VSTAX.MISC.ISDX if REW::PORT_CTRL.VSTAX2_MISC_ISDX_ENA = 1 else 0. | 9 | х | | | VID | IEEE VLAN identifier. Default value is VID = IFH.VSTAX.TAG.VID. | 12 | | Х | | | The following conditions will change the default: | | | | | | If REW::ES0_CTRL.ES0_BY_RLEG = 1 and (IFH.FWD.DST_MODE = L3UC_ROUTING or IFH.FWD.DST_MODE = L3MC_ROUTING) VID = IFH.DST.L3[UC MC].ERLEG | | | | | | If REW::ES0_CTRL.ES0_BY_RT_FWD = 1 and IFH.DST.ENCAP.RT_FWD = 1 VID = IFH.DST.ENCAP.GEN_IDX. | | | | The following tables show the actions available in VCAP\_ES0. Default actions are selected by PORT\_CTRL.ES0\_LPORT\_NUM when no ES0 entry is hit. When REW::ES0\_CTRL.ES0\_LU\_ENA = 1, all of the default actions must be initialized to ensure correct frame handling. Table 159 • VCAP\_ES0 Actions | Field Name | Description | Width | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | PUSH_OUTER_TAG | Controls tag A (outer tagging). 0: Port tagging. Push port tag as outer tag if enabled for port. No ES0 tag A. 1: ES0 tag A. Push ES0 tag A as outer tag. No port tag. 2: Forced port tagging. Push port tag as outer tag. No ES0 tag A. 3: Forced untagging. No outer tag pushed (no port tag, no ES0 tag A). | 2 | | PUSH_INNER_TAG | Controls tag B (inner tagging). 0: Do not push ES0 tag B as inner tag. 1: Push ES0 tag B as inner tag. | 1 | | TAG_A_TPID_SEL | Selects TPID for ES0 tag A. 0: 0x8100. 1: 0x88A8. 2: Custom1. 3: Custom2. 4: Custom3. 5: Classified. Selected by ANA in IFH.VSTAX.TAG_TYPE and IFH.DST.ENCAP.TAG_TPID: If IFH.DST.ENCAP.TAG_TPID = STD_TPID: If IFH.VSTAX.TAG.TAG_TYPE = 0, then 0x8100 else 0x88A8 If IFH.DST.ENCAP.TAG_TPID = CUSTOM[n]: REW::TPID_CFG[n]:TPID_VAL. | 3 | | TAG_A_VID_SEL | Selects VID for ES0 tag A. 0: Classified VID + VID_A_VAL. 1: VID_A_VAL. | 1 | | TAG_A_PCP_SEL | Select PCP source for ES0 tag A. 0: Classified PCP. 1: PCP_A_VAL. 2: Reserved. 3: PCP of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED = 1 and num_popped_tags>0) else PCP_A_VAL. 4: Mapped using mapping table 0, otherwise use PCP_A_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use PCP_A_VAL. 7: Mapped using mapping table 3, otherwise use mapping table 2. | 3 | | TAG_A_DEI_SEL | Select DEI source for ES0 tag A. 0: Classified DEI. 1: DEI_A_VAL. 2: REW::DP_MAP.DP [IFH.VSTAX.QOS.DP]. 3: DEI of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED = 1 and num_popped_tags>0) else DEI_A_VAL. 4: Mapped using mapping table 0, otherwise use DEI_A_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use mapping table 2. | 3 | Table 159 • VCAP\_ES0 Actions (continued) | Field Name | Description | Width | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | TAG_B_TPID_SEL | Selects TPID for ES0 tag B. 0: 0x8100. 1:0x88A8. 2: Custom 1. 3: Custom 2. 4: Custom 3. 5: See TAG_A_TPID_SEL. | 3 | | TAG_B_VID_SEL | Selects VID for ES0 tag B. 0: Classified VID + VID_B_VAL. 1: VID_B_VAL. | 1 | | TAG_B_PCP_SEL | Selects PCP source for ES0 tag B. 0: Classified PCP. 1: PCP_B_VAL. 2: Reserved. 3: PCP of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED=1 and num_popped_tags>0) else PCP_B_VAL. 4: Mapped using mapping table 0, otherwise use PCP_B_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use PCP_B_VAL. 7: Mapped using mapping table 3, otherwise use mapping table 2. | 3 | | TAG_B_DEI_SEL | Selects DEI source for ES0 tag B. 0: Classified DEI. 1: DEI_B_VAL. 2: REW::DP_MAP.DP [IFH.VSTAX.QOS.DP]. 3: DEI of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED = 1 and num_popped_tags>0) else DEI_B_VAL. 4: Mapped using mapping table 0, otherwise use DEI_B_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use mapping table 2. | 3 | | TAG_C_TPID_SEL | Selects TPID for ES0 tag C. 0: 0x8100. 1:0x88A8. 2: Custom 1. 3: Custom 2. 4: Custom 3. 5: See TAG_A_TPID_SEL. | 3 | | TAG_C_PCP_SEL | Selects PCP source for ES0 tag C. 0: Classified PCP. 1: PCP_C_VAL. 2: Reserved. 3: PCP of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED=1 and num_popped_tags>0) else PCP_C_VAL. 4: Mapped using mapping table 0, otherwise use PCP_C_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use PCP_C_VAL. 7: Mapped using mapping table 3, otherwise use mapping table 2. | 3 | Table 159 • VCAP\_ES0 Actions (continued) | Field Name | Description | Width | |-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | TAG_C_DEI_SEL | Selects DEI source for ES0 tag C. 0: Classified DEI. 1: DEI_C_VAL. 2: REW::DP_MAP.DP [IFH.VSTAX.QOS.DP]. 3: DEI of popped VLAN tag if available (IFH.VSTAX.TAG.WAS_TAGGED = 1 and num_popped_tags>0) else DEI_C_VAL. 4: Mapped using mapping table 0, otherwise use DEI_C_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use DEI_C_VAL. 7: Mapped using mapping table 3, otherwise use mapping table 2. | 3 | | VID_A_VAL | VID used in ES0 tag A. See TAG_A_VID_SEL. | 12 | | PCP_A_VAL | PCP used in ES0 tag A. See TAG_A_PCP_SEL. | 3 | | DEI_A_VAL | DEI used in ES0 tag A. See TAG_A_DEI_SEL. | 1 | | VID_B_VAL | VID used in ES0 tag B. See TAG_B_VID_SEL. | 12 | | PCP_B_VAL | PCP used in ES0 tag B. See TAG_B_PCP_SEL. | 3 | | DEI_B_VAL | DEI used in ES0 tag B. See TAG_B_DEI_SEL. | 1 | | VID_C_VAL | VID used in ES0 tag C. See TAG_C_VID_SEL. | 12 | | PCP_C_VAL | PCP used in ES0 tag C. See TAG_C_PCP_SEL. | 3 | | DEI_C_VAL | DEI used in ES0 tag C. See TAG_C_DEI_SEL. | | | POP_VAL | Pops one additional Q-tag. num_popped_tags = IFH.tagging.pop_cnt + POP_VAL. The rewriter counts the number of Q-tags in the frame and only pops tags that are present in the frame. NUM_POPPED_TAGS is equal to the last available tag. | | | UNTAG_VID_ENA | Controls insertion of tag C. Un-tag or insert mode can be selected. See PUSH_CUSTOMER_TAG. | 1 | | PUSH_CUSTOMER<br>_TAG | | | | TAG_C_VID_SEL | Selects VID for ES0 tag C. The resulting VID is termed C-TAG.VID. 0: Classified VID. 1: VID_C_VAL. | 1 | | DSCP_SEL | Selects source for DSCP. 0: Controlled by port configuration and IFH. 1: Classified DSCP via IFH. 2: DSCP_VAL. 3: Reserved. 4: Mapped using mapping table 0, otherwise use DSCP_VAL. 5: Mapped using mapping table 1, otherwise use mapping table 0. 6: Mapped using mapping table 2, otherwise use DSCP_VAL. 7: Mapped using mapping table 3, otherwise use mapping table 2. | 3 | | DSCP_VAL | DSCP value. | 6 | Table 159 • VCAP\_ES0 Actions (continued) | Field Name | Description | Width | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | PROTECTION_SEL | Change ENCAP_ID, ESDX_BASE and OAM_MEP_IDX based on IFH.DST.ENCAP.PROT_ACTIVE. 0: No protection. Do not use protection index values. 1: Use <index>_P if ifh.encap.prot_active = 1. 2: Use <index>_P if ifh.encap.prot_active = 0. 3: Reserved.</index></index> | 2 | | RESERVED | Must be set to 0. | 41 | | ENCAP_ID | Index into the MPLS encapsulation table (REW::ENCAP). Setting ENCAP_ID to zero disables pushing of MPLS encapsulation. 0: Disables the use of MPLS encapsulation. 1-127: Selects ENCAP ID. | | | ENCAP_ID_P | Index to use when enabled by PROTECTION_SEL. The encoding is equal to ENCAP_ID. | 7 | | POP_CNT | If POP_CNT > 0, then ifh.dst.encap.w16_pop_cnt is overruled with POP_CNT when popping MPLS labels. The encoding is: 0: Use ifh.dst.encap.w16_pop_cnt as word16 (2 bytes) pop count 1: Do not pop any bytes. 2: Pop 2 × 2 = 4 bytes. 21: Pop 2 × 21 = 42 bytes. 22-31: Reserved. If the number of bytes popped by POP_CNT is larger than the value given by ifh.dst.encap.w16 pop cnt, the IFH value is always used. | 5 | | ESDX_BASE | Egress service index. Used to index egress service counter set (REW::CNT_CTRL.STAT_MODE). | 10 | | ESDX_BASE_P | Egress service index to use when enabled by PROTECTION_SEL. | 10 | | ESDX_COSID_<br>OFFSET | Egress counter set, offset per COSID. 2. Stat index = ESDX_BASE + ESDX_COSID_OFFSET[(3 x COSID + 2) : 3 x COSID] | | | MAP_0_IDX | Index 0 into mapping resource A. Index bits 10:3. Index bits 2:0 are controlled by MAP_0_KEY. | | | MAP_1_IDX | Index 1 into mapping resource A. Index bits 10:3. Index bits 2:0 are controlled by MAP_1_KEY. | | | MAP_2_IDX | Index 0 into mapping resource B. Index bits 10:3. Index bits 2:0 are controlled by MAP_2_KEY. | | | MAP_3_IDX | Index 1 into mapping resource B. Index bits 10:3. Index bits 2:0 are controlled by MAP_2_KEY. | 8 | Table 159 • VCAP\_ES0 Actions (continued) | Field Name | Description | Width | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | MAP_0_KEY | Key used when looking up mapping table 0. QoS mappings: 0: QoS (8 entries): IDX = IDX_A + QOS. 1: DP, QoS (32 entries): IDX = IDX_A + IFHDP × 8 + QOS. DSCP mappings: 2: DSCP (64 entries): IDX = IDX_A + IFHDSCP. 3: DP, DSCP (256 entries): IDX = IDX_A + 64 × IFHDP + IFHDSCP. 4: DP, TOS_PRE (32 entries): IDX = IDX_A + IFHDP × 8 + TOS_PRE. PCP mappings: 5: PCP (8 entries): IDX = IDX_A + IFHPCP. 6: DP, PCP (32 entries): IDX = IDX_A + IFHDP × 8 + IFHPCP. 7: DEI, PCP (16 entries): IDX = IDX_A + IFHDEI × 8 + IFHPCP. TC mappings: 8: TC: IDX = IDX_A + IFHTC. 9: DP, TC: IDX = IDX_A + IFHDP × 8 + IFHTC. Popped customer tag mappings: 10: Popped PCP (8 entries): IDX = MAP_0_IDX + pop.PCP 11: DP, popped PCP (32 entries): IDX = MAP_0_IDX + IFHDP × 8 + pop.PCP. 12: Popped DEI, popped PCP (16 entries): IDX = MAP_0_IDX + pop.DEI × 8 + pop.PCP. 12: Popped DEI, popped PCP (16 entries): IDX = MAP_0_IDX + pop.DEI × 8 + pop.PCP. COSID mappings: 13: COSID (8 entries): IDX = IDX_A + IFHDP × 8 IFH | 4 | | MAP_1_KEY | See MAP_0_KEY. | 4 | | MAP_2_KEY | See MAP_0_KEY. | 4 | | MAP_3_KEY | See MAP_0_KEY. | 4 | | RESERVED | Must be set to 0. | 27 | | FWD_SEL | ES0 Forward selector. 0: No action. 1: Copy to loopback interface. 2: Redirect to loopback interface. 3: Discard. | 2 | | CPU_QU | CPU extraction queue. Used when FWD_SEL >0 and PIPELINE_ACT = XTR. | 3 | | PIPELINE_PT | ES0 pipeline point. 0: REW_IN_SW. 1: REW_OU_SW. 2: REW_SAT. 3: Reserved. | 2 | | PIPELINE_ACT | Pipeline action when FWD_SEL >0. 0: XTR. CPU_QU selects CPU extraction queue 1: LBK_ASM. | 1 | | SWAP_MAC_ENA | This setting is only active when FWD_SEL = 1 or FWD_SEL = 2 and PIPELINE_ACT = LBK_ASM. 0: No action. 1: Swap MACs and clear bit 40 in new SMAC. | 1 | Table 159 • VCAP\_ES0 Actions (continued) | Field Name | Description | Width | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | LOOP_ENA | Setting LOOP_ENA overrides the other pipeline control settings. 0: Forward based on PIPELINE_PT and FWD_SEL 1: Force FWD_SEL=REDIR, PIPELINE_ACT = LBK_ASM, PIPELINE_PT = REW_SAT, swap MACs and clear bit 40 in new SMAC. Do not apply CPU_QU. | 1 | ## 3.24.5.1 Rewriter Pipeline Handling In order to achieve the correct statistics and processing of frames, it is important that frames can be extracted, injected, discarded, and looped at specific positions in the processing flow. Based on the position, processing—especially counters, are affected. For information about how pipeline points are used in the processing flow, see Pipeline Points, page 61. Note that a frame is always physically passed through the entire processing. Logically, certain elements of the processing can be disabled or enabled. The following table lists the pipeline points available in the rewriter. Table 160 • Rewriter Pipeline Point Definitions | Pipeline Point | What can set it? | Position in Flow | |----------------|-------------------------------------------|------------------| | NONE | Default | 0 | | REW_IN_MIP | Inner MIP configured in rewriter | 1 | | REW_IN_SW | Inner software MEP controlled by VCAP_ES0 | 2 | | REW_IN_VOE | Service VOE in VOP | 3 | | REW_OU_VOE | Service VOE in VOP | 4 | | REW_OU_SW | Outer software MEP controlled by VCAP_ES0 | 5 | | REW_OU_MIP | Outer software MIP configured in rewriter | 6 | | REW_SAT | SAT software MEP controlled by VCAP_ES0 | 7 | | REW_PORT_VOE | Port VOE in VOP | 8 | | REW_VRAP | Set in VRAP reply frame | 9 | Each point in the flow assigns one of the possible pipeline actions listed in the following table. Table 161 • Pipeline Actions | <b>Action Type</b> | Name | Comment | |--------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Inject | INJ<br>INJ_MASQ<br>INJ_CENTRAL | Injection actions set by ANA are cleared when the frame enters the rewriter by setting the pipeline point and action to NONE. | | Extract | XTR<br>XTR_UPMEP<br>XTR_REW_LATE | XTR is set by ES0 and MIP. XTR_UPMEP is also set by the VOP. XTR_REW_LATE can only be set in ANA. | | Loopback | LBK_ASM<br>LBK_QS | LBK_QS is set in ANA. This action is treated as an injection action in the rewriter. LBK_ASM can be set by ES0 when looping frames back to ANA. This action is treated as an extraction in the rewriter. | | None | NONE | Default. No pipeline point and action is assigned to frame. | Frames looped by the analyzer (PIPELINE\_ACT = LBK\_QS) have their ANA pipeline point changed to a REW pipeline point, which indicates the point in the rewriter flow in REW where they appear again after being looped. The following pipeline point translations are handled. - PIPELINE\_PT = ANA\_PORT\_VOE is changed to REW\_PORT\_VOE - PIPELINE PT = ANA OU VOE is changed to REW OU VOE - PIPELINE PT = ANA IN VOE is changed to REW IN VOE Frame forward and counter updates are done based on the assigned pipeline points and actions. In the rewriter, pipeline points and actions can be assigned by ES0, the MIP, and the VOP. Frames injected by a CPU can also have pipeline point and actions set in the injection IFH. The rules listed in the following table apply when pipeline points are updated. Table 162 • Pipeline Point Updating Rules | Pipeline Action | Rule | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | None | The pipeline point and actions can be updated. | | Inject | If a frame is injected in pipeline point N, the forwarding cannot be changed in pipeline point N-1 and it will not be counted in the N-1 point. Logically the frame does not exist in the N-1 point. Example: A frame is injected in the REW_VRAP pipeline point (Pipeline point = REW_VRAP, Action = INJ). The SW-MEP is configured to loop the same frame in the pipeline point REW_SAT. The frame will not be looped, because it was injected later in the pipeline (REW_VRAP > REW_SAT). The frame will not be counted by the egress service statistics, which has a default location in the REW_PORT_VOE pipeline point for injected frames. | | Extract | If frame is extracted in pipeline point N the forwarding cannot be changed in pipeline point N+1 and it will not be counted in the N+1 point. Logically the frame does not exist in the N+1 point. Example: A frame is extracted in the REW_IN_MIP pipeline point (Pipeline point = REW_IN_MIP, Action = XTR). The SW-MEP is configured to loop the same frame in the pipeline point REW_SAT. The frame will not be looped because it has already been extracted earlier in the pipeline (REW_IN_MIP < REW_SAT). The frame will not be counted by the egress service statistics, which has a default location in the REW_OU_SW pipeline point for extracted frames. | ### 3.24.5.2 Frame Copy, Redirect, or Discard Frame forwarding may be changed by ES0 action FWD\_SEL, the MIP or the VOP. Changing frame forwarding will update the frame pipeline point and action. The following options are available to control frame forwarding. - · No action. Do not change frame forwarding. - Copy frame to CPU via the loopback interface. The frame is looped back to the ANA where it is sent to the CPU. The IFH of the CPU copy is modified to select a CPU queue. The frame is also forwarded as normal to the destination port and can be modified by the normal rewriter operations. - Redirect frame to ANA via loopback interface. When doing frame loopbacks, the destination port of the redirected frame will be left unchanged. The IFH of the frame is modified and the MAC addresses may be swapped. Redirected frames may also be sent to a CPU queue. This can be done as a standalone operation or together with the loopback frame. When redirecting, the frame is only sent to the loopback interface and not to the original destination port. - Discard frame. The frame is terminated before transmission. The following illustrations depicts options for frame forwarding. Figure 79 • Frame Forward Options The following table lists the registers associated with the frame loopback options. Table 163 • Frame Loopback Options | Register | Description | Replication | |------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------| | ES0_CTRL.<br>ES0_FRM_LBK_CFG | Using ES0 it is possible to loop frames back to ANA with the LOOP_ENA action. If this bit is set, a frame can only be looped once by ES0. | None | Frame forwarding is changed if allowed by the current frame pipeline point and action. For more information, see Rewriter Pipeline Handling, page 250. The following table shows the pipeline action when the frame forwarding is changed. Table 164 • Pipeline Action Updates | Forwarding Selection | Pipeline Action Updates | |----------------------|-----------------------------------------------------------| | NONE | Unchanged | | COPY | Unchanged | | REDIR | CPU redirection: XTR / XTR_UPMEP Loopback frames: LBK_ASM | | DISCARD | XTR / XTR_UPMEP | The pipeline updating rules ensures that a REDIR or DISCARD decision cannot be changed at a later pipeline point. A COPY may be changed at a later point to either a REDIR or DISCARD action. - If a copy is changed to a discard, the CPU still receives the frame copy. - If a copy is changed to a redirection, the CPU receives a copy and the frame is looped back or also sent to the redirection queue. When frames are copied or redirected the IFH is updated as described in the following table. Table 165 • Loopback IFH Updates | IFH Field | Updated by | |-------------------|----------------------------------------------------------------------------------| | FWD.SRC_PORT | COPY or REDIR. The frame source port is changed to the current destination port. | | MISC.PIPELINE_PT | COPY or REDIR. The pipeline point in which the frame forwarding was updated. | | MISC.PIPELINE_ACT | COPY or REDIR. The pipeline action assigned to the frame. | | MISC.CPU_MASK | Any operation. A CPU copy may be generated by all forward selections. | Table 165 • Loopback IFH Updates (continued) | IFH Field | Updated by | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | FWD.DO_LBK | Rewriter loopback. This bit is set to indicate that the frame has been looped by the REW. Can optionally be used to prevent multiple loops of the same frame. | | FWD.UPDATE_FCS | VOP. Set by the VOP if a looped frame changed. | | VSTAX.MISC.ISDX | VOP. The frame ISDX can be changed by the VOP. | | VSTAX.QOS.DP | VOP. The DP level can be set to 0 by the VOP. | | ENCAP.MPLS_TTL | VOP. The MPLS_TTL can be set to 1 by the VOP. | ### 3.24.5.3 Egress Statistics Update The rewriter does not have Egress Service Index (ESDX) and port-based counters of its own. Instead, the egress statistic counters in XQS:STAT are used for all frame and byte counting. For more information, see Statistics, page 226. The following counters are available to the rewriter as frame and octet counters. - Per egress port: 2 × 8 + 1 = 17 counters (color × cell bus priority + abort) - ESDX: 2 × 1,024 = 2,048 counters (color × ESDX) Frame and octets are counted simultaneously on each index by two separate counters. The counter widths are 40 bits for octet counters and 32 bits for frame counters. The following table lists the registers associated with ESDX counter configuration. Table 166 • Egress Statistics Control Registers | Register | Description | Replication | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | CNT_CTRL.<br>STAT_MODE | Configures ESDX counter index selection. | Global | | CNT_CTRL. VSTAX_STAT_ESDX_DIS | Configures ESDX counting for stacking ports. If this bit is set and PORT_CTRL.VSTAX_HDR_ENA = 1, all counting based on the ESDX value is disabled regardless of the CNT_CTRL.STAT_MODE configuration. | Global | | CNT_CTRL.<br>STAT_CNT_FRM_ABORT_ENA | Enables counting of frames discarded by the rewriter. This bit only enables counting of frames discarded by ES0 or the SW_MIP. Frame discards done by the VOP are not included. | Global | | PORT_CTRL. XTR_STAT_PIPELINE_PT | Configures the extraction statistics pipeline point. Frames extracted before the configured pipeline point are not counted by the ESDX counters. Configuring the REW_IN_MIP value will cause all extracted frames to be counted. Default is REW_OU_SW. | Port | | PORT_CTRL. INJ_STAT_PIPELINE_PT | Configures the injection statistics pipeline point. Frames injected after the configured pipeline point are not counted by the ESDX counters. Configuring the REW_VRAP value will cause all injected frames to be counted. Default is REW_OU_VOE. | Port | #### 3.24.5.4 Statistics Counter Index Calculation The port counter index is always the physical port number and priority. The frame color is determined in the same manner as the ESDX counter. The ESDX counter index calculation is controlled by the CNT\_CTRL.STAT\_MODE register. Table 167 • ESDX Index Selection | STAT_MODE | Description | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Use ESDX if available: ESDX is available if ES0 lookup is enabled and if ES0.ESDX_BASE is different from 0. Index = ES0.ESDX_BASE + ES0.ESDX_COSID_OFFSET(IFH.VSTAX.MISC.COSID). | | | If ESDX is not available: Index = IFH.VSTAX.MISC.ISDX (4,096 available. The two MSB bits are ignored.) Regardless of the index selection, the frame color is: Color = DP_MAP.DP(IFH.VSTAX.QOS.DP) | | 1 | Similar to STAT_MODE = 0, except counting is disabled if the ESDX is not available. | | 2 | Use ISDX: Index = IFH.VSTAX.MISC.ISDX. The frame color is used to count multicast frames: Color = FRAME.ETH_LINK_LAYER.DMAC (bit 40). | | 3 | Use VID: Index = Classified VID (IFH.VSTAX.TAG.VID), if no tag is pushed Index = VID of outermost pushed tag, if a tag is pushed Index = REW:VMID:RLEG_CTRL.RLEG_EVID (IFH.DSTERLEG) if L3. The frame color is used to count multicast frames: Color = FRAME.ETH_LINK_LAYER.DMAC (bit 40). The two MSB bits of the VID are ignored. 1,024 counter indexes are available. | Both port counters and ESDX counters are updated based on pipeline points and actions. For more information, see Rewriter Pipeline Handling, page 250. The ESDX statistics pipeline points can be configured using the PORT\_CTRL.INJ\_STAT\_PIPELINE\_PT and PORT\_CTRL.XTR\_STAT\_PIPELINE\_PT registers. The following table shows when the counters are updated. Table 168 • Egress Statistics Update | Counter | Is Updated When? | |---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Port | Pipeline action is not Extract (action different from XTR, XTR_LATE_REW, XTR_UPMEP, and LBK_ASM). Frame is transmitted (abort = 0). Updated for all egress port numbers including virtual device (VD) and extraction CPU port numbers. | | ESDX | The egress port is a physical port. The frame matches the parameters configured in CNT_CTRL.STAT_MODE: For extracted frames (Action: XTR, XTR_UPMEP and LBK_ASM): The egress statics is located in the pipeline point, PORT_CTRL.XTR_STAT_PIPELINE_PT. Frames extracted in or after this point are counted. For injected frames (Action: INJ, INJ_x, LBK_QS): The egress statics is located the pipeline point, PORT_CTRL.INJ_STAT_PIPELINE_PT. Frames injected in or before this point are counted. Frame is transmitted (abort = 0). The pipeline action is different from XTR_LATE_REW. | | Abort | A frame is aborted by REW or OQS (abort = 1). Counting of frames aborted by REW must be enabled by setting CNT_CTRL.STAT_CNT_FRM_ABORT_ENA. | ### 3.24.5.5 Protection Active Using ES0, the rewriter is able to change various indexes based on the value of the IFH.DST.ENCAP.PROT ACTIVE field in the IFH. - Use the ES0 key field PROT\_ACTIVE to change all ES0 actions when protection is active. - The numbers of ES0 keys are limited, so the same key can optionally generate two different indexes based on the value of IFH.DST.ENCAP.PROT\_ACTIVE. This is enabled using the ES0 action PROTECTION SEL. - The ENCAP\_ID, ESDX\_BASE and OAM\_MEP\_IDX indexes can be changed. These indexes are used when enabled by PROTECTION\_SEL: ENCAP\_ID\_P, ESDX\_BASE\_P, and OAM\_MEP\_IDX\_P. ## 3.24.6 Mapping Tables The rewriter contains two mapping resources (A and B) that can be used to look up the following fields. - TC value in MPLS labels - · DSCP value in IP frames - DEI in 802.3 VLAN tags - PCP in 802.3 VLAN tags The following table lists the configuration registers associated with the mapping tables. Table 169 • Mapping Table Configuration Registers | Register | Description | Replication | |-----------------------|-------------------------|-------------| | MAP_RES_x (x= A or B) | | | | MAP_VAL_x:TC_VAL | Mapped TC value | 2,048 × 2 | | MAP_VAL_x:DSCP_VAL | Mapped DSCP value | 2,048 × 2 | | MAP_VAL_x:DEI_VAL | Mapped DEI value | 2,048 × 2 | | MAP_VAL_x:PCP_VAL | Mapped PCP value | 2,048 × 2 | | MAP_VAL_x:OAM_COLOR | Mapped OAM Color | 2,048 × 2 | | MAP_VAL_x:OAM_COSID | Mapped OAM Cosid | 2,048 × 2 | | MAP_LBL_x:LBL_VAL | Mapped MPLS label value | 2,048 × 2 | Each of the two resources provide all of the fields listed above. Two lookups are done in each resource for every frame. This generates four mapping results per frame. The four lookups implement mapping table 0 to 3. The address used for each lookup is controlled by the ES0 actions MAP $\,$ n KEY and MAP $\,$ n IDX (n = 0:3). A mapping table address consists of two parts: - A base index: ES0.MAP n IDX. This controls the MSB part of the table address. - One of 15 different keys that use classified frame properties to generate the LSB of the table address. For more information about each key, see ES0 Configuration Registers, page 243. The following illustration depicts the mapping table functionality. Figure 80 • Mapping Tables The mapping tables provide a flexible way to update frame fields. The following example shows how to configure and use mapping table 1. Update PCP in VLAN tag A using mapping table 1. Use frame DSCP as index: - Enable ES0 - Program an ES0 key - Set ES0 action TAG A PCP SEL to 5 for selected key - Set ES0 action PUSH OUTER TAG = 1 - Update PCP by using Table 1: Select a base address in resource A. Base address 256 is used in this example Set ES0 action MAP\_1\_IDX = 256/8 = 32 - Use frame DSCP as key: Set ES0 action MAP\_1\_KEY = 2 - Program the PCP mapping in table 1: Addr = 256 to 256 + 63 (all DSCP values) - Write REW:MAP\_RES\_A:\$Addr/MAP\_VAL\_A PCP\_VAL <New PCP> Frame DSCP is used as key in this example. If the DSCP is not available (frame is non IP), the mapping is considered invalid, and the PCP value is selected using this fallback method: - Use mapping table 1 if key is valid, otherwise use mapping table 0. - Use mapping table 0 if key is valid, otherwise use a fixed value. In the example, a PCP value from table 0 is used instead for non IP frames, if the table 0 key is valid. Otherwise, the ES0 action PCP\_A\_VAL is used. Mapping tables 2 and 3 have the same functionality. Mapping tables 0 and 1 share the 2,048 addresses available in Resource A. Table 2 and 3 share 2,048 addresses in Resource B. # 3.24.7 VLAN Editing The rewriter performs five steps related to VLAN editing for each frame and destination: - ES0 lookup. ES0 is looked up for each frame if enabled by the global configuration. The action from ES0 controls the pushing of VLAN tags. - VLAN popping. Zero to three VLAN tags are popped from the frame. Popping is controlled from the ANA by IFH.TAGGING.POP CNT and by the action ES0.POP VAL. - 3. VLAN push decision. Decides the number of new tags to push and which tag source to use for each tag. Tag sources are port, ES0 (tags A to C), and routing. - Constructs the VLAN tags. The new VLAN tags are constructed based on the tag sources' configuration. - 5. VLAN pushing. The new VLAN tags are pushed. The outermost tag can optionally be controlled by port-based VLAN configuration. Table 170 • Port VLAN Tag Configuration Registers | Register | Description | Replication | |------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | TPID_CFG. TPID_VAL | Configures three custom TPID values. These must be configured identically in ANA_CL::VLAN_STAG_CFG.STAG_ETYPE_VAL. | 3 | | PORT_VLAN_CFG<br>PORT_* | Port VLAN TCI. Port _VID is also used for untagged set. | Ports | | TAG_CTRL:<br>TAG_CFG_OBEY_<br>WAS_TAGGED | Controls how port tags are added. If this bit is set, the IFH field VSTAX.TAG.WAS_TAGGED must be 1 before a port tag is added to a frame. | Ports | | TAG_CTRL:<br>TAG_CFG | Controls port tagging. Four modes are supported. | Ports | | TAG_CTRL:<br>TAG_TPID_CFG | Selects Tag Protocol Identifier (TPID) for port tagging. | Ports | | TAG_CTRL:<br>TAG_VID_CFG | Selects VID in port tag. | Ports | | TAG_CTRL:<br>TAG_PCP_CFG | Selects PCP fields in port tag. | Ports | | TAG_CTRL:<br>TAG_DEI_CFG | Selects DEI fields in port tag. | Ports | | DP_MAP.DP | Maps the four drop precedence levels (DP) to a drop eligible value (DE or COLOR). | Global | | PORT:<br>PCP_MAP_DEx | Mapping table. Maps DP level and QoS class to new PCP values. | Per port per<br>Q per DE | | PORT:<br>DEI_MAP_DEx | Mapping table. Maps DP level and QoS class to new DEI values. | Per port per<br>Q per DE | ### 3.24.7.1 ES0 Lookup For each frame passing through the rewriter, an optional VCAP\_ES0 lookup is done using the appropriate key. The action from ES0 is used in the following to determine the frame's VLAN editing. ## **3.24.7.2 VLAN Popping** The rewriter initially pops the number of VLAN tags specified by the IFH field IFH.TAGGING.POP\_CNT received with the frame. Up to three VLAN tags can be popped via the IFH. The rewriter itself can further influence the number VLAN tags being popped by the ES0 action POP\_VAL. This can increase the pop count by one. The rewriter analyzes the total number of tags in a frame, and this is the maximum number of tags that can be popped regardless of the IFH and ES0 pop values. #### 3.24.7.3 VLAN Push Decision After popping the VLAN tags, the rewriter decides to push zero to three new VLAN tags into the outgoing frame according to the port's tagging configuration in register TAG\_CTRL.TAG\_CFG and the action from a potential VCAP ES0 hit. Two additional tags can be added for mirrored or GCPU frames. These special tags will always be the outermost ones. If MPLS encapsulation is added to a frame, the mirror or GCPU tags are placed after the MPLS link layer SMAC. Figure 81 • VLAN Pushing - Mirror tag is controlled by REW::MIRROR\_PROBE\_CFG.REMOTE\_MIRROR\_CFG GCPU tag is controlled by REW::GCPU\_CFG.GCPU\_TAG\_SEL. - 2. Port tag is controlled by REW:PORT:TAG\_CTRL.TAG\_CFG. The following table lists ES0 VLAN tag actions. Table 171 • ES0 VLAN Tag Actions | ES0_ACTION | TAG_CFG | Tagging Action | |------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No ES0 hit | Controls port<br>tag | The port tag is pushed according to TAG_CTRL.TAG_CFG as outermost tag. The following options are available: - Tag all frames with port tag. - Tag all frames with port tag, except if classified VID = 0 or classified VID=PORT_VLAN_CFG.PORT_VID. - Tag all frames with port tag, except if classified VID = 0. TAG_CTRL.TAG_VID_CFG selects between classified- or fixed-port VID. No inner tag. | | PUSH_OUTER_TAG = 0<br>PUSH_INNER_TAG = 0 | Controls port tag | Same as No ES0 hit action. | | PUSH_OUTER_TAG = 1 PUSH_INNER_TAG = 0 | Don't care | ES0 tag A is pushed as outer tag.<br>No inner tag. | | PUSH_OUTER_TAG = 2<br>PUSH_INNER_TAG = 0 | Don't care | Port tag is pushed as outer tag. This overrules port settings in TAG_CFG. No inner tag. | | PUSH_OUTER_TAG = 3<br>PUSH_INNER_TAG = 0 | Don't care | No tags are pushed. This overrules port settings in TAG_CFG. | Table 171 • ES0 VLAN Tag Actions (continued) | ES0_ACTION | TAG_CFG | Tagging Action | |--------------------------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PUSH_OUTER_TAG = 0 PUSH_INNER_TAG = 1 | Controls port<br>tag | Port tag is pushed according to TAG_CFG as outermost tag. The following options are available: - Tag all frames with port tag. - Tag all frames with port tag, except if classified VID = 0 or classified VID = PORT_TAG_DEFAULT. PORT_TCI_VID. - Tag all frames with port tag, except if classified VID = 0. - No port tag. TAG_CTRL.TAG_VID_CFG select between classified- or fixed-port VID. ES0 tag B is pushed as inner tag. ES0 tag B is effectively the outer tag if the port tag is not pushed. | | PUSH_OUTER_TAG = 1<br>PUSH_INNER_TAG = 1 | Don't care | ES0 tag A is pushed as outer tag. ES0 tag B is pushed as inner tag. | | PUSH_OUTER_TAG = 2<br>PUSH_INNER_TAG = 1 | Don't care | Port tag is pushed as outer tag. This overrules port settings in TAG_CFG. ES0 tag B is pushed as inner tag. | | PUSH_OUTER_TAG = 3<br>PUSH_INNER_TAG = 1 | Don't care | No outer tag is pushed. This overrules port settings in TAG_CFG. ES0 tag B is pushed as inner tag. ES0 tag B is effectively the outer tag, because no outer tag is pushed. | | Tag C is controlled separately a All combinations of tags A to C a | | e the inner most tag. | | PUSH_CUSTOMER_TAG = 0 | Controls port tag | Does not push customer tag (tag C). | | PUSH_CUSTOMER_TAG = 1 | Controls port tag | Push tag C if IFH.VSTAX.TAG.WAS_TAGGED = 1. | | PUSH_CUSTOMER_TAG = 2 | Controls port tag | Push tag C if IFH.VSTAX.TAG.WAS_TAGGED = 0. | | PUSH_CUSTOMER_TAG = 3 | Controls port tag | 3: Push tag C if UNTAG_VID_ENA = 0 or (C-TAG.VID ! = VID_C_VAL). C-TAG.VID is controlled by TAG_C_VID_SEL. | | UNTAG_VID_ENA | Controls port tag | See PUSH_CUSTOMER_TAG = 3. | # 3.24.7.4 Constructing VLAN Tags The contents of the tag header are highly programmable when pushing a VLAN tag. The following illustration shows the VLAN tag construction. Figure 82 • VLAN Tag Construction The port tags (ES0.PUSH\_OUTER\_TAG = [0[2]), the ES0 tags A to C, and the special tags have individual configurations. #### Port Tag: PCP Use REW:PORT:TAG CTRL.TAG PCP CFG to configure the following: - Use the classified PCP. - Use the egress port's port VLAN (PORT\_VLAN\_CFG.PORT\_PCP). - Use the QoS class directly. - Map DE and QoS class to a new PCP value using the per-port table PCP\_MAP\_DEx. - Map DE and COSID to a new PCP value using the per-port table PCP\_MAP\_DEx. - Map DE and classified PCP to a new PCP value using the per-port table PCP\_MAP\_DEx. - · Use the COSID class directly. #### Port Tag: DEI Use REW:PORT TAG CTRL.TAG DEI CFG to configure the following: - Use the classified DEI. - Use the egress port's port VLAN (PORT VLAN CFG.PORT DEI). - Use mapped DP to DE level (color). - Map DE and QoS class to a new DEI value using the per-port table DEI\_MAP\_DEx. - Map DE and COSID to a new DEI value using the per-port table DEI MAP DEx. - Map DE and classified PCP to a new DEI value using the per-port table DEI\_MAP\_DEx. #### Port Tag: VID Use REW:PORT:TAG\_CTRL.TAG\_VID\_CFG to configure the following: - Use the classified VID. - Use the egress port's port VLAN (PORT\_VLAN\_CFG.PORT\_VID). - Use VMID from router leg lookup. When L3 routing is active, the classified VID is overwritten by the VMID. #### Port Tag: TPID Use REW:PORT:TAG\_CTRL.TAG\_TPID\_CFG to configure the following: - Use Ethernet type 0x8100 (C-tag). - Use Ethernet type 0x88A8 (S-tag). - Use one of three custom TPIDs programmed in REW::TPID CFG.TPID VAL. - The TPID is classified by ANA and selected by IFH. Similar options for the ES0 tag A to tag C are available: #### ES0 Tag: PCP Use ES0 action TAG x PCP SEL to configure the following: - Use the classified PCP. - Use ES0 ACTION.PCP x VAL. - Use PCP of popped tag (IFH.VSTAX.TAG.WAS\_TAGGED = 1 and num\_popped\_tags>0) else PCP x VAL. - Use the complex mapping functionality provided by ES0 to lookup a PCP value. #### ES0 Tag: DEI Use ES0 action TAG x DEI SEL to configure the following: - · Use the classified DEI. - Use ES0\_ACTION.DEI\_x\_VAL. - Use the complex mapping functionality provided by ES0 to lookup a DEI value. - Use DEI of popped tag (IFH.VSTAX.TAG.WAS\_TAGGED = 1 and num\_popped\_tags>0) else DEI x VAL. - Use the mapped DP to DE level (color) directly. #### ES0 Tag: VID Use ES0 action TAG\_x\_VID\_SEL to configure the following: - Tag A and B: Use the classified VID incremented with ES0.VID\_x\_VAL. Tag C: Use the classified VID. - Use ES0\_ACTION.VID\_x\_VAL. #### **ES0 Tag: TPID** Use ES0 action TAG x TPID SEL to configure the following: - Use Ethernet type 0x8100 (C-tag). - Use Ethernet type 0x88A8 (S-tag). - Use one of three custom TPIDs programmed in REW::TPID\_CFG.TPID\_VAL. - TPID is classified by ANA and selected via IFH. GCPU or mirror forwarding can optionally insert additional tags. These will always be added as the outermost tags. One or two special tags (A and B) can be added. The tag construction options as follows: #### Special Tag A+B: PCP - Use the classified PCP. - Use fixed value. ### Special Tag A+B: DEI Use fixed value. #### Special Tag A+B: VID Use fixed value. #### Special Tag A+B: TPID - Use Ethernet type 0x8100 (C-tag). - Use Ethernet type 0x88A8 (S-tag). - Use one of three custom TPIDs programmed in REW::TPID CFG.TPID VAL. - TPID is classified by ANA and selected by means of IFH. ## 3.24.8 DSCP Remarking The rewriter supports two DSCP remarking schemes. The first remarking mode is controlled by port and IFH settings. The second remarking mode is controlled by ES0 actions and by the general mapping tables. DSCP actions from ES0 override any remarking done by the port. ### 3.24.8.1 ES0-Based DSCP Remarking ES0 controls DSCP remarking if ES0 lookups are enabled and the DSCP\_SEL action is different from 0. For more information, see Mapping Tables, page 255. ### 3.24.8.2 Legacy Port-Based Mode Simple DSCP remapping can be done using a common table shared by all ports. The following table shows the port-based DSCP editing registers associated with remarking. Table 172 • Port-Based DSCP Editing Registers | Register | Description | Replication | |--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | DP_MAP.DP | Maps the four drop precedence levels to a drop eligible value (DE). DE is also called color. | Global | | DSCP_REMAP.DSCP_REMAP | Full one-to one DSCP remapping table common for all ports. | None | | DSCP_MAP.DSCP_UPDATE_ENA | Selects DSCP from either frame or IFH.QOS.DSCP. If DSCP_MAP.DSCP_UPDATE_ENA = 1 and IFH.QOS.UPDATE_DSCP = 1: Selected DSCP = IFH.QOS.DSCP Else keep frame DSCP: Selected DSCP = Frame DSCP. | Ports | | DSCP_MAP.DSCP_REMAP_ENA | Optionally remaps selected DSCP. If DSCP_MAP.DSCP_REMAP_ENA = 1 and IFH.QOS.TRANSPARENT_DSCP = 0: New DSCP = DSCP_REMAP [Selected DSCP]. Else do no remap: New DSCP = selected DSCP. | Ports | The following remarking options are available. - No DSCP remarking. The DSCP value in the frame is untouched. - Update the DSCP value in the frame with the value received from the analyzer in IFH.QOS.DSCP. - Update the DSCP value in the frame with the frame DSCP mapped through DSCP REMAP.DSCP REMAP. - Update the DSCP value in the frame with the value received from the analyzer (IFH.QOS.DSCP) mapped through DSCP\_REMAP.DSCP\_REMAP. ANA can set IFH.QOS.TRANSPARENT\_DSCP to prevent DSCP mapping even if this is enabled for a port. ANA can also force use of the frame DSCP for mapping by setting IFH.QOS.UPDATE\_DSCP to 0. The IP checksum is updated when changing the DSCP for IPv4 frames. ### 3.24.9 VStaX Header Insertion The rewriter controls insertion of the VStaX header. For more information about the header fields, see VStaX Header, page 24. The following registers are used for configuration of the rewriter specific stacking functionality. Table 173 • Rewriter VStaX Configuration Registers | Register | Description | Replication | |------------------------|-----------------------------------------------|-------------| | COMMON_CTRL. OWN_UPSID | Configures own UPSID to be used for stacking. | None | Table 173 • Rewriter VStaX Configuration Registers (continued) | Register | Description | Replication | |---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | CNT_CTRL. VSTAX_STAT_ESDX_DIS | Configures ESDX counting for stacking ports. If this bit is set and PORT_CTRL.VSTAX_HDR_ENA = 1, all counting based on the ESDX value is disabled regardless of the CNT_CTRL.STAT_MODE configuration. | None | | PORT_CTRL.<br>VSTAX_STACK_GRP_SEL | Selects logical stacking port (or stacking port group) membership. | Ports | | PORT_CTRL.<br>VSTAX_HDR_ENA | Enables insertion of stacking header in frame. | Ports | | PORT_CTRL.<br>VSTAX_PAD_ENA | Enables padding of frames to 76 bytes. Setting this bit will cause all frames on the port to be extended to 76 bytes instead of 64 bytes. This should only optionally be enabled for stacking ports (PORT_CTRL.VSTAX_HDR_ENA = 1). Setting this bit will prevent frames from becoming under sized in a receiving switch, when the VStaX header is removed. See ASM::ERR_STICKY.FRAGMENT_STICKY. | Ports | | PORT_CTRL.VSTAX2_MIRR<br>OR_OBEY_WAS_TAGGED | Configures tagging of frames with VSTAX.GEN.FWD_MODE = VS2_FWD_GMIRROR. Only active on front ports for frames with this FWD_MODE. This is used to control the remote mirror tagging of frames that have been mirrored from one unit in the stack to another unit. | Ports | | PORT_CTRL.<br>VSTAX2_MISC_ISDX_ENA | Configures VSTAX MISC field decoding. Select between MISC- or AC mode. | Ports | | VSTAX_PORT_GRP_CFG.<br>VSTAX_TTL | Link TTL value. | 2 | | VSTAX_PORT_GRP_CFG.<br>VSTAX_LRN_ALL_HP_ENA | Changes priority of learn all frames to the highest priority (IFH.VSTAX.QOS = 7). | 2 | | VSTAX_PORT_GRP_CFG.<br>VSTAX_MODE | Controls whether forwarding modes specific to VStaX AF are translated to BF forwarding modes. If set to 0, the following translation is performed: fwd_logical -> fwd_llookup fwd_mc -> fwd_llookup If set to 1, no translation is performed. Translation is only required for advanced forwarding switches operating in a basic forwarding stack. | 2 | # 3.24.10 Forwarding to GCPU The OQS can redirect CPU frames on selected CPU queues to the external ports instead of sending them to the internal CPU. This is called GCPU forwarding and is typically used if an external CPU is connected to the VSC7415 device through an Ethernet port. GCPU forwarding is controlled per individual CPU queue. Stack ports have additional options for GCPU forwarded frames. Table 174 • GCPU Configuration Registers | Register | Description | Replication | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | GCPU_CFG.<br>GCPU_KEEP_IFH | Used when GCPU frames are forwarded to a front port. Frames are sent with the IFH preserved. The IFH is encapsulated according to the configuration. Setting GCPU_KEEP_IFH to a value different from 0 overrides the GCPU_TAG_SEL and GCPU_DO_NOT_REW settings for front ports. No other rewrites are done to the frame. The GCPU_KEEP_IFH setting is not active if PORT_CTRL.KEEP_IFH_SEL is different from 0 or if PORT_CTRL.VSTAX_HDR_ENA = 1. | Per CPU Q | | GCPU_CFG.<br>GCPU_DO_NOT_REW | Used when GCPU frames are forwarded to a front port. Except for the optional tags configured in GCPU_CFG.GCPU_TAG_SEL, frames are not modified when forwarded to the GCPU. | Per CPU Q | | GCPU_CFG.<br>GCPU_TAG_SEL | The destination port type determines the functionality. When a GCPU frame is forwarded to a stack port: Force a change of the VSTAX.TAG to the configured values in GCPU_TAG_CFG:0. When a GCPU frame is forwarded to a front port: Optionally add one or two Q-tags to the frame. The tags are configured using GCPU_TAG_CFG. | Per CPU Q | | GCPU_CFG.<br>GCPU_FWD_MODE | Used when GCPU frames are forwarded to a stack port. Controls the value of VSTAX.DST.DST_PN. | Per CPU Q | | CPU_CFG.<br>GCPU_UPSPN | Used when GCPU frames are forwarded to a stack port. CPU QUEUE to be used as destination queue for global CPU transmission. The value depends on configuration and the value of GCPU_CFG.GCPU_FWD_MODE. Controls the value of VSTAX.DST.DST_PN. | Per CPU Q | | GCPU_CFG.<br>GCPU_UPSID | Used when GCPU frames are forwarded to a stack port. UPSID to be used as destination in the VStaX header. Sets VSTAX.DST.DST_UPSID to configured value. | Per CPU Q | | GCPU_TAG_CFG.<br>TAG_TPID_SEL | Configuration of Q-Tags for GCPU frames. GCPU frames that are forwarded to a front port can optionally have one or two IEEE 802.3 VLAN tags added. The tags will be placed in the outer most position after the SMAC. GCPU VLAN tag Protocol Identifiers (TPID). | 2 | | GCPU_TAG_CFG. TAG_VID_VAL | GCPU VLAN VID value. | 2 | | GCPU_TAG_CFG.<br>TAG_DEI_VAL | GCPU VLAN DEI values. | 2 | | GCPU_TAG_CFG. TAG_PCP_SEL | Selection of GCPU VLAN PCP values. | 2 | | GCPU_TAG_CFG.<br>TAG_PCP_VAL | GCPU VLAN PCP values. | 2 | The IFH.MISC.CPU\_MASK field is used to select the GCPU forwarding configuration. If multiple bits are set in this mask, the most significant bit is always used to control the GCPU forwarding. The ANA\_AC::CPU\_CFG.ONE\_CPU\_COPY\_ONLY\_MASK register is used to control how the CPU\_MASK is set before the frame enters the rewriter. If the CPU\_MASK field is 0, all GCPU forwarding is disabled. GCPU frame forwarding must be enabled in the OQS per CPU queue using the QFWD::FRAME\_COPY\_CFG.FRMC\_PORT\_VAL registers. ## **3.24.11 Layer 3 Routing** The following registers are associated with routing (Layer 3, or L3). They are used when the analyzer signals routing by setting IFH.FWD.DST MODE = L3UC ROUTING or L3MC ROUTING. The analyzer can also signal routing using IFH.DST.ENCAP.RT\_FWD = 1. In this case, the MAC addresses and VMIDs are controlled directly by the analyzer, and the registers in the rewriter are not used. Table 175 • Routing SMAC Configuration Registers | Register | Description | Replication | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | RLEG_CFG_0.<br>RLEG_MAC_LSB | Router Leg SMAC address used for IP routing (least significant bits). Must be set identical to ANA_L3::RLEG_CFG_0.RLEG_MAC_LSB. | None | | RLEG_CFG_1. RLEG_MAC_TYPE_SEL | Configures how Router Leg MAC addresses are specified. Must be set identical to ANA_L3::RLEG_CFG_1.RLEG_MAC_TYPE_SEL. 0: RLEG_MAC:= RLEG_MAC_MSB(23:0) and (RLEG_MAC_LSB(23:0) + VMID(7:0) mod 2 <sup>24</sup> ) 1: RLEG_MAC:= RLEG_MAC_MSB(23:0) and (RLEG_MAC_LSB(23:0) + VID(11:0) mod 2 <sup>24</sup> Others: RLEG_MAC:= RLEG_MAC_MSB(23:0) and RLEG_MAC_LSB(23:0) number of common address for all VLANs. | None | | RLEG_CFG_1.<br>RLEG_MAC_MSB | MSB part of SMAC used for IP routing. Must be set identical to ANA_L3::RLEG_CFG_1.RLEG_MAC_MSB. | None | The IFH.DST.L3\_[MC|UC]ROUTING.ERLEG fields are used to select the VID of routed frames using the Egress Mapped VLAN (VMID) configuration registers listed in the following table. Table 176 • L3 Routing Egress Mapping VLAN (EVMID) | Register | Description | Replication | |--------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------| | RLEG_CTRL.RLEG_EVID | VID value assigned to this router leg. | 32 | | RLEG_CTRL.<br>RLEG_VSTAX2_WAS_TAGGED | Controls the value of IFH.VSTAX.TAG.WAS_TAGGED field in the stack header for frames that are L3 forwarded to a stack port. | 32 | ### 3.24.12 Mirror Frames The device offers three mirror probe sets that can be individually configured. The following table lists the rewriter configuration registers associated with mirroring. Table 177 • Mirror Probe Configuration Registers | Register | Description | Replication | |--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | MIRROR_PROBE_CFG. MIRROR_TX_PORT | The Tx port for each mirror probe (from where rewrite configuration was taken). | Mirror probes | | MIRROR_PROBE_CFG.<br>REMOTE_ENCAP_ID | Selects encapsulation ID to use for remote mirror frames. | Mirror probes | | MIRROR_PROBE_CFG. REMOTE_MIRROR_CFG | Enables encapsulation of mirrored frames. One or two Q-tags (Q-in-Q) or the encapsulation table can be used. In tag mode, the VLAN tags are added after the outer SMAC. In other words, if an MPLS link layer is added to the frame, the tags are added after the LL-SMAC. In encapsulation mode, an entry in the ENCAP table is used for encapsulation. This overrides any encapsulation selected by ES0 for the frame. | | Table 177 • Mirror Probe Configuration Registers (continued) | Register | Description | Replication | |-------------------------------------|--------------------------------------------------------------------|---------------------| | MIRROR_TAG_x_CFG:<br>TAG_x_PCP_VAL | Mirror Q-tag PCP value. | 2× mirror probes | | MIRROR_TAG_x_CFG:<br>TAG_x_PCP_SEL | Selection of mirror Q-tag PCP values. | 2× mirror<br>probes | | MIRROR_TAG_x_CFG:<br>TAG_x_DEI_VAL | Mirror Q-tag DEI values. | 2× mirror<br>probes | | MIRROR_TAG_x_CFG:<br>TAG_x_VID_VAL | Mirror Q-tag VID values. | 2× mirror probes | | MIRROR_TAG_x_CFG:<br>TAG_x_TPID_SEL | The tag protocol identifier (TPID) for the remote mirror VLAN tag. | 2× mirror probes | The device supports mirroring frames from either Rx ports (ingress mirror) or Tx ports (egress mirror). Frames either received on a port (Rx mirror) or frames sent to a port (Tx mirror) are copied to a mirror destination port. For Tx mirroring, the rewriter rewrites the frame sent to the mirror destination port, exactly as the original frame copy is rewritten when forwarded to the mirror probe port. The mirror probe port number must be configured in the rewriter using register MIRROR TX PORT. For Rx mirroring, the rewriter makes no modifications to the frame, so an exact copy of the original frame as received on the mirror probe port (ingress port) is sent out on the mirror destination port. The analyzer controls both Rx and Tx mirroring. For more information, see Mirroring, page 202. The rewriter obtains mirror information for the frame from the internal frame header. IFH.FWD.MIRROR\_PROBE indicates if the frame is a mirror copy and if so, to which of three mirror probes the frame belongs. Encoding is as follows. - MIRROR PROBE = 0: Frame is not a mirror copy - MIRROR PROBE = 1: Frame is mirrored using mirror probe set 1 - MIRROR PROBE = 2: Frame is mirrored using mirror probe set 2 - MIRROR\_PROBE = 3: Frame is mirrored using mirror probe set 3 In addition, the IFH.FWD.RX\_MIRROR bit indicates if the frame is Rx mirrored (1) or Tx mirrored (0). When mirroring traffic to a device that is not directly attached to the VSC7415 device, it may be required to push one or two VLAN tags to mirrored frame copies as to not violate general VLAN membership for the mirror destination port. These VLAN tags are called "remote mirror VLAN tags" and can be configured individually for each mirror probe. When enabled, the remote mirror VLAN tags are pushed onto all mirrored traffic by the rewriter whether it is an Rx mirrored frame or a Tx mirrored frame. For remote mirroring it is also possible to add MPLS capsulation using the encapsulation table if this is required for forwarding the frame. The REMOTE\_MIRROR\_ENA register configures whether to add one or two remote mirror VLAN tags or MPLS encapsulation. The REMOTE\_ENCAP\_ID bit selects the MPLS encapsulation to be used. For Tx mirroring, care must be taken if maximum frame expansion is already required by the rewriter for the TX mirror probe port. In this case enabling remote mirror VLAN tags or encapsulation would add an extra frame expansion, which can cause frame disruption on the mirror destination port. It is not possible to add remote mirror encapsulation to a frame that already has encapsulation added by ES0. In this case the remote mirror encapsulation ID will replace the ID selected by the ES0.ENCAP\_ID action. #### 3.24.13 Internal Frame Header Insertion The rewriter can be configured to insert the internal frame header (IFH) into the frame upon transmission. For more information about the IFH, Frame Headers, page 17. Insertion of the IFH can be configured on any port, but it is intended for frames forwarded to the internal CPU and the NPI port (external CPU). When IFH insertion is enabled on a given port, all frames leaving that port contain the IFH. The following table lists the registers for configuring the insertion of extraction IFH into the frame. Table 178 • IFH Configuration Registers | Register | Description | Replication | |------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | PORT_CTRL.KEEP_IFH_SEL | Configures the rewriter IFH mode for the port. See also ASM::PORT_CFG.INJ_FORMAT_CFG. 0: Normal mode. 1: Keep IFH without modifications. Frames are not updated. IFH is kept. 2: Encapsulate IFH. The frame's DMAC, SMAC and a fixed TAG with ETYPE = 8880 (Microsemi) and EPID=0x0009 are inserted in front of the IFH: [FRM_DMAC][FRM_SMAC][0x8880][0x0009][IFH][FRAME]. 3: Encapsulate IFH using the ENCAP table. Use ES0 to generate an ENCAP_ID and insert the encapsulation in front of the IFH:[ENCAP][IFH][FRAME]. | Ports | The following illustration shows supported formats using KEEP\_IFH\_SEL. Figure 83 • Supported KEEP\_IFH\_SEL Formats Frames are always formatted using KEEP\_IFH\_SEL = 1 when extracting frames to the internal CPU ports. This cannot be changed. Note that for KEEP\_IFH\_SEL = 1, the frames transmitted on external ports are not valid Ethernet frames, because the extraction IFH precedes the DMAC. As a result, this frame format must be used for direct transmission to another VSC7415 device that understands the format or to a dedicated FPGA or NPU. This format cannot be used for forwarding to a standard Ethernet device. The frame formats using KEEP\_IFH\_SEL = 2 or KEEP\_IFH\_SEL = 3 are primarily used on a port that is directly attached to an external CPU. When the IFH is included using these frame formats, the IFH is included in the frame's FCS calculation and a valid Ethernet frame is transmitted. # 3.24.14 Frame Injection from Internal CPU To instruct the switch core how to process the frame, the internal CPU injects frames to switch core using the internal frame header. The format of injected frames from the internal CPU is similar to the KEEP\_IFH\_SEL = 1 format. On arrival to the rewriter, such injected frames are no different from any other frames. However, the IFH contains information related to rewriter functionality specifically targeting efficient frame injection: Do not rewrite (IFH.FWD.DO\_NOT\_REW): If this injection IFH bit is set, the rewriter forward frames unchanged to the egress port no matter any other rewriter configurations, except IFH.FWD.update\_fcs. - Update frame check sequence (IFH.FWD.UPDATE\_FCS): If this injection IFH bit is set, the rewriter updates the FCS before forwarding a frame to the egress port. By setting this bit in the Injection IFH, the internal CPU can leave it to switch core hardware to make sure the FCS value included with the frame is correct even though no other frame modifications are performed by the switch core. - Swap MACs (IFH.DST.ENCAP.SWAP\_MAC): Swap MACs in the Ethernet link layer and clear bit 40 of the new SMAC before sending the frame to the egress port. Swapping the MACs will also force the frame FCS to be updated. Cannot be used if IFH.FWD.DO NOT REW = 1. ## 3.25 Disassembler This section provides information about the disassembler (DSM) block. The disassembler is mainly responsible for disassembling cells into Taxi words and forwarding them to the port modules. In addition, it has several other responsibilities such as: - MAC Control sublayer PAUSE function with generation of PAUSE frames and stop forwarding traffic on reception of PAUSE frames - · Aging of frames that are stopped by flow control - Controlling transmit data rate according to IEEE802.3ar The following table lists replication terminology. Table 179 • Replication Terminology | Replication Terminology | Description | Replication Value | |-------------------------|--------------------------------------------------------------------------|-------------------| | Per port | Per physical ports. For example, DEV1Gs, DEV2G5s, DEV10Gs and CPU ports. | 15 | # 3.25.1 Setting Up Ports In general, no additional configuration is required to bring up a port in the disassembler. However, the following are some exceptions: - For the 10G capable ports, set DSM::BUF\_CFG.CSC\_STAT\_DIS to 1 when the port is set up for 10 Gbps, because the collection of statistics are handled locally in the DEV10G. For lower speeds, the port uses a DEV2G5. - For 10G capable ports, set DSM::DEV\_TX\_STOP\_WM\_CFG.DEV\_TX\_STOP\_WM to 3 if the port is set up for 2.5 Gbps or 1 Gbps, and set it to 1 for 100 Mbps and 10 Mbps. - For 10G capable ports, set DSM::DEV\_TX\_STOP\_WM\_CFG.DEV10G\_SHADOW\_ENA to 1 when port is set up for speeds below 10 Gbps. - For 2.5G capable ports, the DSM::DEV\_TX\_STOP\_WM\_CFG.DEV\_TX\_STOP\_WM must be set to 1 if the port is set up for 100 Mbps and 10 Mbps. Ports are indexed by 0 - 10 being front ports and 11 - 12 being CPU ports. The following table lists the registers associated with setting up basic ports. Table 180 • Basic Port Setup Configuration Registers Overview | Target::Register.Field | Description | Replication | |-----------------------------------------------|------------------------------------------------------------|-------------| | DSM::BUF_CFG.CSC_STAT_DIS | Disables collection of statistics in the disassembler. | Per port | | DSM::DEV_TX_STOP_WM_CFG.DEV_TX<br>_STOP_WM | Watermark for maximum fill level of port module TX buffer. | Per port | | DSM::DEV_TX_STOP_WM_CFG.DEV10G<br>_SHADOW_ENA | Enable low speeds for 10G capable ports. | Per port | ## 3.25.2 Maintaining the Cell Buffer The cell buffer is responsible for aligning and buffering the cell data received from the rewriter before the data are forwarded on the Taxi bus. The cell buffer can be flushed for each port separately. The following table lists registers associated with configuring buffer maintenance. Table 181 • Buffer Maintenance Configuration Register Overview | Target::Register.Field | Description | Replication | |------------------------|------------------------|-------------| | DSM::CLR_BUF.CLR_BUF | Flush the cell buffer. | Per port | Before a buffer is flushed, ensure that no data is forwarded to this port by stopping the QSYS forwarding and disabling FC/PFC so that frames waiting for transmission will be sent. FC can be disabled in DSM::RX\_PAUSE\_CFG.RX\_PAUSE\_EN. # 3.25.3 Setting Up MAC Control Sublayer PAUSE Function This section provides information about setting up the MAC control sublayer PAUSE function. #### 3.25.3.1 PAUSE Frame Generation The main sources for triggering generation of PAUSE frames are the port level and buffer level watermarks in the queue system. It is also possible to trigger PAUSE generation based on the analyzer policing state. For watermark-based PAUSE generation, a hysteresis is implemented. FC is indicated when the level of used resources exceeds the high watermark and it is released when the level falls below the low watermark. The following table lists the registers associated with configuration PAUSE frame generation. Table 182 • PAUSE Frame Generation Configuration Registers Overview | Target::Register.Field | Description | Replication | |--------------------------------------------|--------------------------------------------------------------------------|-------------| | DSM::ETH_FC_CFG.FC_ANA_ENA | Controls generation of FC based on FC request from the analyzer. | Per port | | DSM::ETH_FC_CFG.FC_QS_ENA | Controls the generation of FC based on FC request from the queue system. | Per port | | DSM::MAC_CFG.TX_PAUSE_VAL | The pause_time as defined by IEEE802.3 Annex 31B2. | Per port | | DSM::MAC_CFG.TX_PAUSE_XON_XOFF | TX PAUSE zero on deassert. | Per port | | DSM::MAC_ADDR_BASE_HIGH_CFG. MAC_ADDR_HIGH | Bits 47-24 of SMAC address used in MAC_Control frames. | Per port | | DSM::MAC_ADDR_BASE_LOW_CFG. MAC_ADDR_LOW | Bits 23-0 of SMAC address used in MAC_Control frames. | Per port | DSM::MAC\_CFG.TX\_PAUSE\_VAL defines the timer value for generated PAUSE frames. If the state does not change by half of the time specified in this bit group, a new PAUSE frame is generated. To generate a zero value pause frame when the reason for pausing has disappeared, set DSM::MAC\_CFG.TX\_PAUSE\_XON\_XOFF to 1. The DMAC of a generated pause frame is always the globally assigned 48-bit multicast address 01 80 C2 00 00 01. The SMAC of a generated pause frame is defined by DSM::MAC\_ADDR\_BASE\_HIGH\_CFG.MAC\_ADDR\_HIGH and DSM::MAC\_ADDR\_BASE\_LOW\_CFG.MAC\_ADDR\_LOW. ### 3.25.3.2 Reaction on Received PAUSE Frame The assembler detects received PAUSE frames and forwards the pause\_time to the disassembler, which stops data transmission (if enabled) for the period defined by pause\_time. If PFC is enabled for a port, then RX\_PAUSE\_EN must be disabled in the disassembler. The following table lists the registers associated with configuring PAUSE frame reception. Table 183 • PAUSE Frame Reception Configuration Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------|--------------------------------------|-------------| | DSM::RX_PAUSE_CFG.RX_PAUSE_EN | Enables flow control in Rx direction | Per port | #### 3.25.3.3 PFC Pause Frame Generation When PFC is enabled for a port, PFC PAUSE frames are generated when requested by the queue system. PFC is enabled on a per port basis in the disassembler. The queue system must also be setup to generate PFC requests towards the disassembler. Regular flow control and PFC cannot operate simultaneously on the same port. The available PFC configurations in the disassembler are listed in the following table. Table 184 • PFC PAUSE Frame Generation Configuration Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | DSM::ETH_PFC_CFG.PFC_MIN_<br>UPDATE_TIME | Minimum time between two PFC PDUs when PFC state changes after transmission of PFC PDU. | Per port | | DSM::ETH_PFC_CFG.PFC_XOFF _MIN_UPDATE_ENA | After sending PFC PDU with flow control deasserted for all priorities, enforces a PFC_MIN_UPDATE_TIME delay before allowing transmission of next PFC PDU. | Per port | | DSM::ETH_PFC_CFG.PFC_ENA | Enables PFC operation for the port. | Per port | # 3.25.4 Setting up Flow Control in Half-Duplex Mode The following table lists the configuration registers for half-duplex mode flow control. For more information about setting up flow control in half-duplex mode, see PAUSE Frame Generation, page 269. Table 185 • Half-Duplex Mode Flow Control Configuration Register Overview | Target::Register.Field | Description | Replication | |-------------------------------|------------------------------------------------------------------|-------------| | DSM::MAC_CFG.HDX_BACKPRESSURE | Enables HDX backpressure instead of FDX FC when FC is generated. | Per port | To enable half-duplex flow control, DSM::MAC\_CFG.HDX\_BACKPRESSURE must be set to 1. In this mode, the disassembler forwards the FC status to the port modules, which then collides incoming frames. # 3.25.5 Setting Up Frame Aging The following tables provide the aging configuration and status register settings. If frame aging is enabled, the disassembler discards frames that are stuck, for example, due to flow control or frames that are received from the queue system with an era value eligible for aging. Frames discarded by aging are counted in DSM::AGED\_FRMS.AGED\_FRMS\_CNT. Table 186 • Aging Configuration Register Overview | Target::Register.Field | Description | Replication | |------------------------|----------------------------------------------------------------------------------|-------------| | DSM::BUF_CFG.AGING_ENA | Enable aging of frames stuck in the disassembler buffer system for long periods. | Per port | Table 187 • Aging Status Register Overview | Target::Register.Field | Description | Replication | |------------------------------|------------------------------|-------------| | DSM::AGED_FRMS.AGED_FRMS_CNT | Count number of aged frames. | Per port | ## 3.25.6 Setting Up Transmit Data Rate Limiting The disassembler can limit the transmit data rate as specified in IEEE802.3ar, which defines the following three rate limiting methods. The disassembler allows enabling of any combination of the following three methods. - · Frame overhead - · Payload data rate - Frame rate The following table lists the registers associated with rating limiting. Table 188 • Rate Limiting Common Configuration Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | DSM::TX_RATE_LIMIT_MODE. TX_RATE_LIMIT_ACCUM_MODE_ENA | Enables for accumulated rate limit mode. | Per port | | DSM::TX_RATE_LIMIT_MODE. PAYLOAD_PREAM_CFG | Defines whether the preamble is counted as payload in txRateLimitPayloadRate and txRateLimitFrameRate mode. | Per port | | DSM::TX_RATE_LIMIT_MODE. PAYLOAD_CFG | Defines if what is configured as header size in TX_RATE_LIMIT_HDR_SIZE:: TX_RATE_LIMIT_HDR_CFG is subtracted form the payload. | Per port | | DSM::TX_RATE_LIMIT_MODE. IPG_SCALE_VAL | Scales the IPG calculated by txRateLimitFrameOverhead and/or txRateLimitPayloadRate by a power of 2. | Per port | | DSM::TX_RATE_LIMIT_HDR_CFG. TX_RATE_LIMIT_HDR_SIZE | Defines how much of the frame is seen as header and not counted as payload. | per port | If more than one of the rate limiting modes previously mentioned are enabled, the additional inter-packet gap is the maximum of each of the values generated by one of the enabled modes. However, if only the frame overhead and the data payload data rate modes are enabled, the additional inter-packet gap can be calculated as the sum of the additional gaps retrieved from each of the two modes. To enable the function, set DSM::TX\_RATE\_LIMIT\_MODE.TX\_RATE\_LIMIT\_ACCUM\_MODE\_ENA to 1. If the preamble of a frame is not to be counted as payload, set DSM::TX RATE LIMIT MODE.PAYLOAD CFG to 0. In addition, if parts of the frame are to be seen as header and not counted as payload, set DSM::TX RATE LIMIT MODE.PAYLOAD CFG to 1. DSM::TX\_RATE\_LIMIT\_HDR\_CFG.TX\_RATE\_LIMIT\_HDR\_SIZE defines how much of the frame that should be considered as header. Note that this register is global for all ports enabled by DSM::TX\_RATE\_LIMIT\_MODE.PAYLOAD\_CFG. The payload configuration applies to Payload Data Rate and Frame Rate mode. To enable bandwidth limiting down to very low data rates, the calculated IPG can be scaled. In other words, multiplied by a power of 2 in the range 2 to 1024. By this it is possible to limit the data rate down to 2.3% (for 1536 byte frames). ### 3.25.6.1 Setting Up Frame Overhead The following table lists the frame overhead configuration registers. Table 189 • Rate Limiting Frame Overhead Configuration Registers Overview | Target::Register.Field | Description | Replication | |-----------------------------------------------------------|---------------------------------------|-------------| | DSM::TX_RATE_LIMIT_MODE. TX_RATE_LIMIT_FRAME_OVERHEAD_ENA | Enable txRateLimitFrameOverhead mode. | Per port | | DSM::RATE_CTRL.FRM_GAP_COMP | Inter-packet gap to be used. | Per port | To increase the minimum inter-packet gap for all packets, set DSM::TX\_RATE\_LIMIT\_MODE.TX\_RATE\_LIMIT\_FRAME\_OVERHEAD\_ENA to 1, and set DSM::RATE\_CTRL.FRM\_GAP\_COMP to a value between 13 to 255. For more information about the scaling feature if the GAP must be above 255, see Setting Up Transmit Data Rate Limiting, page 271. ### 3.25.6.2 Setting Up Payload Data Rate The following table lists the payload data rate configuration registers. Table 190 • Rate Limiting Payload Data Rate Configuration Registers Overview | Target::Register.Field | Description | Replication | |----------------------------------------------------------|-------------------------------------|-------------| | DSM::TX_RATE_LIMIT_MODE. TX_RATE_LIMIT_PAYLOAD_RATE_ENA | Enable txRateLimitPayloadRate mode. | Per port | | DSM::TX_IPG_STRETCH_RATIO_CFG. TX_FINE_IPG_STRETCH_RATIO | Stretch ratio. | Per port | To limit the data rate relative to the transmitted payload, set DSM::TX\_RATE\_LIMIT\_MODE.TX\_RATE\_LIMIT\_PAYLOAD\_RATE\_ENA to 1. The inter-packet gap increase can be expressed as: $\Delta IPG = 2^S \times (256/R) \times L$ Where: S: Scaling factor DSM::TX\_RATE\_LIMIT\_MODE.IPG\_SCALE\_VAL L: Payload length, possibly modified according to DSM::TX\_RATE\_LIMIT\_MODE.PAYLOAD\_PREAM\_CFG and DSM::TX\_RATE\_LIMIT\_MODE.PAYLOAD\_CFG #### Notes Total IPG is 12 byte standard IPG plus IPG. Values for R must not be below 1152 or above 518143. Values for S must not be above 10. Fractional parts of the resulting IPG value are carried forward to the next IPG. Higher values for S allow for finer target accuracy/granularity on the cost of an increased IPG jitter. The utilization can be expressed as: U = L / (L + IPG) or $U = R / (R + 2S \times 256)$ ### 3.25.6.3 Setting Up Frame Rate The following table lists the frame rate configuration registers. Table 191 • Rate Limiting Frame Rate Registers Overview | Target::Register.Field | Description | Replication | |-------------------------------------------------------|------------------------------------|-------------| | DSM::TX_RATE_LIMIT_MODE. TX_RATE_LIMIT_FRAME_RATE_ENA | Enables txRateLimitFrameRate mode. | Per port | | DSM::TX_FRAME_RATE_START_CFG. TX_FRAME_RATE_START | Frame rate start. | Per port | To define a minimum frame spacing, set DSM::TX RATE LIMIT MODE.TX RATE LIMIT FRAME RATE ENA to 1. At start of payload, a counter is loaded with the value stored in DSM::TX FRAME RATE START CFG.TX FRAME RATE START. What is counted as payload is defined by DSM::TX\_RATE\_LIMIT\_MODE.PAYLOAD\_PREAM\_CFG and DSM::TX\_RATE\_LIMIT\_MODE.PAYLOAD\_CFG. With every payload byte transmitted, the counter is decremented by 1. At end of frame, the GAP will be extended by the counter value, if above 12. ### 3.25.7 Error Detection The following table lists the error detection status registers. Table 192 • Error Detection Status Registers Overview | Target::Register.Field | Description | Replication | |----------------------------------------------------|------------------------------------------------------------|-------------| | DSM::BUF_OFLW_STICKY.BUF_OFLW_STICKY | Cell buffer had an overflow. | Per port | | DSM::BUF_UFLW_STICKY.BUF_UFLW_STICKY | Cell buffer had an underrun. | Per port | | DSM::TX_RATE_LIMIT_STICKY.TX_<br>RATE_LIMIT_STICKY | IPG was increased by one of the three rate limiting modes. | Per port. | If one or both of BUF\_OFLW\_STICKY and BUF\_UFLW\_STICKY sticky bits are set, the port module was set up erroneously. TX\_RATE\_LIMIT\_STICKY is set when an IPG of a frame is increased due to one of the three rate limiting modes. # 3.26 Layer 1 Timing There are eight recovered clocks, four outputs that provide timing sources for external timing circuitry in redundant timing implementations, and four internal clocks for the timing-recovery circuit. The following tables list the registers and pins associated with Layer 1 timing. Table 193 • Layer 1 Timing Configuration Registers | Register | Description | |--------------------------|-------------------------------------------------------------------------------| | HSIO::SYNC_ETH_CFG | Configures recovered clocks. Replicated per recovered clock. | | HSIO::SYNC_ETH_PLL_CFG | Additional PLL recovered clock configuration. Replicated per recovered clock. | | HSIO::SYNC_ETH_SD10G_CFG | Additional 10G recovered clock configurations. Replicated per 10G interface. | Table 193 • Layer 1 Timing Configuration Registers (continued) | Register | Description | |----------------------------------|-------------------------------------| | HSIO::PLL5G_CFG3 | Enables high speed clock output. | | PHY[0]:PHY_GP:PHY_RCVD_CLK0_CTRL | Configures PHY0 recovered clock. | | PHY[1]:PHY_GP:PHY_RCVD_CLK1_CTRL | Configuration PHY1 recovered clock. | Table 194 • Layer 1 Timing Recovered Clock Pins | Pin Name | I/O | Description | |------------|-----|----------------------------------------------------------------------------------------------| | RCVRD_CLK0 | 0 | Recovered clock output, configured by SYNC_ETH_CFG[0]. This is an overlaid function on GPIO. | | RCVRD_CLK1 | 0 | Recovered clock output, configured by SYNC_ETH_CFG[1]. This is an overlaid function on GPIO. | | RCVRD_CLK2 | 0 | Recovered clock output, configured by SYNC_ETH_CFG[2]. This is an overlaid function on GPIO. | | RCVRD_CLK3 | 0 | Recovered clock output, configured by SYNC_ETH_CFG[3]. This is an overlaid function on GPIO. | | CLKOUTPLL | 0 | PLL high speed clock output. | | CLKOUTPLL2 | 0 | PLL2 high speed clock output. | It is possible to recover receive timing from any 10/100/1000 Mbps, 2.5 Gbps, or SFI data streams into the device. The recovered clock outputs have individual divider configuration (through SYNC\_ETH\_CFG.SEL\_RCVRD\_CLK\_DIV) to allow division of SerDes receive frequency by 1, 2, 4, 5, 8, 16, or 25. In addition to the output dividers, the SFI 10G sources have local pre-dividers to allow adjustments for the SFI links 64/66 encoding overhead by extending clock cycles through SYNC\_ETH\_SD10G\_CFG.SD10G\_RCVRD\_CLK\_DIV. The recovered clocks are single-ended outputs, and the suggested divider settings in the following tables are selected to make sure to not output too high a frequency via the input and outputs. Ports operating in 1 Gbps or lower speeds allow recovery of either 31.25 MHz or 125 MHz clocks. Configure the ports as shown in the following table. Table 195 • Recovered Clock Settings for 1 Gbps or Lower | Port | Output Frequency | Register Settings for Output n | |--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CuPHY<br>0-1 | 125 MHz | Only for internal clocks (n = 4, 5, 6, and 7). SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=6, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV), PHY_RCVD_CLK[DEV]_CTRL.RCVD_CLK[DEV]_ENA=1, PHY_RCVD_CLK[DEV]_CTRL.CLK_SRC_SEL[DEV]=[DEV], PHY_RCVD_CLK[DEV]_CTRL.CLK_FREQ_SEL[DEV]=1, and PHY_RCVD_CLK[DEV]_CTRL.CLK_SEL_PHY[DEV]=1 | Table 195 • Recovered Clock Settings for 1 Gbps or Lower | Port | Output Frequency | Register Settings for Output n | |---------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CuPHY<br>0-1 | 31.25 MHz | SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV), PHY_RCVD_CLK[DEV]_CTRL.RCVD_CLK[DEV]_ENA=1, PHY_RCVD_CLK[DEV]_CTRL.CLK_SRC_SEL[DEV]=[DEV], PHY_RCVD_CLK[DEV]_CTRL.CLK_FREQ_SEL[DEV]=1, and PHY_RCVD_CLK[DEV]_CTRL.CLK_SEL_PHY[DEV]=1 | | SerDes<br>0-6 | 125 MHz | Only for internal clocks (n = 4, 5, 6, and 7). SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=6, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV+4) | | SerDes<br>0-6 | 31.25 MHz | SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=1, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV+4) | Ports operating in 2.5 Gbps mode allow recovery of a 31.25 MHz clock. The following table shows the configuration settings. Table 196 • Recovered Clock Settings for 2.5 Gbps | Port | Output Frequency | Register Settings for Output n | |------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5-6 | 125 MHz | Only for internal clocks (n = 4, 5, 6, or 7). SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=6, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV+4) | | 5-6 | 31.25 MHz | SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=1, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=(DEV+4) | The frequency of the PLLs can be used as recovered clock. The following table shows the configurations. Table 197 • Recovered Clock Settings for PLL | PLL | Output Frequency | Register Settings for Output n | |------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | PLL | 125 MHz | Only for internal clocks (n = 4, 5, 6, or 7). SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=6, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=12 | | PLL | 31.25 MHz | SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1,<br>SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=1, and<br>SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=12 | | PLL2 | 125 MHz | Only for internal clocks (n = 4, 5, 6, or 7). SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1, SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=6, and SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=21 | | PLL2 | 31.25 MHz | SYNC_ETH_CFG[n].RCVRD_CLK_ENA=1,<br>SYNC_ETH_CFG[n].SEL_RCVRD_CLK_DIV=1, and<br>SYNC_ETH_CFG[n].SEL_RCVRD_CLK_SRC=21 | The recovered clock from PLLs can also be sent directly out on the differential high-speed CLKOUTPLL and CLKOUTPLL2 outputs. The recovered clock frequency must be set to copy the switch core using HSIO::PLL5G\_CFG3.CLKOUT2\_SEL. It is possible to automatically squelch the clock output when the device detects a loss of signal on an incoming data stream. This can be used for failover in external timing recovery solutions. The following table lists how to configure squelch for possible recovered clock sources (configured in SYNC\_ETH\_CFG[n].SEL\_RCVRD\_CLK\_SRC). Table 198 • Squelch Configuration for Sources | SRC | Associated Squelch Configuration | |------|-------------------------------------------------------------------------------------------------------------------------------------| | 4-8 | Set SERDES1G_COMMON_CFG.SE_AUTO_SQUELCH_ENA in SD macro to enable squelch when receive signal is lost. SD1G macro index is (SRC-4). | | 9-10 | Set SERDES6G_COMMON_CFG.SE_AUTO_SQUELCH_ENA in SD macro to enable squelch when receive signal is lost. SD6G macro-index is (SRC-9). | | 12 | Set SYNC_ETH_PLL_CFG[0].PLL_AUTO_SQUELCH_ENA to enable squelch when PLL loses lock. | | 21 | Set SYNC_ETH_PLL_CFG[1].PLL_AUTO_SQUELCH_ENA to enable squelch when PLL2 loses lock. | When squelching, the clock will stop when it detects a loss of signal (or PLL lock). The clock will stop on either on high or low level. # 3.27 Hardware Time Stamping Hardware time stamping provides nanosecond-accurate frame arrival and departure time stamps, which are used to obtain high precision timing synchronization and timing distribution, as well as significantly better accuracy in performance monitoring measurements than what is obtained from pure software implementations. The hardware time stamping functions operate in both standalone devices and in systems where multiple devices are interconnected to form a multichip system. Figure 84 • Supported Time Stamping Flows Hardware time stamping can update PTP frames coming from a standard front port without any 1588 support or from a partner device that does parts of the timing update. Each port is configured according to the partner device attached. The modes defined in the following table comply with commonly used methods of transferring timing information in a multichip system, but are as such not specified in the IEEE 1588 standard. The time of day counters are generated in the DEVCPU block where there are various means of accurately updating the time. For more information, see Time of Day Generation, page 281. The output from the DEVCPU block is a set of timing parameters listed in the following table. Table 199 • Timing Parameters | Parameter | Description | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NSF (32 bit) | Counts number of nanoseconds since PTP was enabled in the device. Wraps at $2^{32}$ . | | TOD_nsec (30 bit) | Counts the number of nanoseconds of current time of day. Wraps at $10^9$ , and will potentially be in synch with the partner devices. | | TOD_secs (48 bit) | Counts number of seconds of current time of day. Wraps at 2 <sup>48</sup> . | | NSX48 | Counts number of nanoseconds. NSX48 always take the value of TOD_nsec + TOD_sec*10 <sup>9</sup> . The parameter is to be used for time stamping transfer to partner devices. | | NSX32/NSX44 | The lower 32 or 44 bits of NSX48. | The PTP frame flow through the device is shown in the following illustration. Figure 85 • Frame Flow The time stamps generated by the ports are samples of the NSF value. The ingress time is the time at which the PCS sees the start of frame, synchronized to the system clock domain. The correct 1588 ingress time is the time at which the first bit of the DMAC is received on the SERDES interface so a preconfigured delay is used to adjust for this in the time stamp calculations. The subtraction of the delay is done by the port modules. Delays due to barrel shifting are adjusted by a manual process, where the barrel shifter state must be read out and used when configuring the port's I/O delays. For more information, see Configuring I/O Delays, page 284. Similarly, in the egress direction, a delay is added to the time stamps in order to move the time stamping point to when the first bit of the DMAC leaves the SerDes. This added delay takes place in the port modules. The analyzer recognizes the PTP frames through VCAP IS2 matching and decides which operation to perform (one-step, two-step, or time-of-day-write) and which delays to add to the correction field (CF) to adjust for instance for asymmetrical path delays. The rewriter modifies the PTP frame and can instruct the egress port module to add a delay to the correction field corresponding to the delay from the rewriting point to the transmission point. Otherwise, it can insert the original time stamp and the egress time stamp in a time stamp FIFO, which can be read by the CPU. The rewriter operation depends on the analyzer decisions and the PTP modes of the frame's ingress and egress ports. The following table lists the PTP configuration available to the rewriter. Table 200 • Rewriter PTP Configuration | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------| | MR | Mode of ingress port | | MT | Mode of egress port | | IDLY(2) | Two ingress delays optionally added to CF. Looked up for the ingress port. Format is 32 bits signed. | | EDLY | One egress delay optionally added to CF. Looked up for the egress port. Only one delay is added per transfer. Format is 32 bits signed. | | UDP_CSUM_DIS(4/6) | Can disable updating the UDP checksums in IPv4 and IPv6 frames. | ## 3.27.1 One-Step Functions The mode of a port determines how timing information is exchanged between the port and its link partner. Only the rewriter uses this information for executing the correct calculations and for deciding the right delta command to be executed in the egress port module. When the analyzer has decided to do a one-step timing update of a frame, the rewriter updates the correction field to the time at which it passes through the rewriter, and it will afterwards either prepare the PDU with timing information for the link partner, or it will ask the port module to add the time delay to the serial transmission onto the correction field. The following sections describe the PTP port modes used by the rewriter when doing one-step updates. #### 3.27.1.1 Front Front ports are ports on the boundary of the local PTP system. Frames received must have their timing information updated to the time at which they left the link partner, and frames transmitted will likewise be updated to the time of transmission. #### 3.27.1.2 RSRV32 In a multichip system, the RSRV32 mode can be used for interconnect links. The ingress unit must update the CF field with the residence time from ingress link to any point in the ingress unit, and in the RSRV field of the PDU set the value of NSX32 at the time of CF update. As the egress unit in a multichip system has synchronized NSX32 (common clock by some means), it will be able to update the CF field with time passed from the ingress rewriter to the time of system departure. #### 3.27.1.3 RSRV30 Similar to the mode RSRV32, but the reference point is moved to the time of departure from the egress unit. The time value to use in the reserved bytes field only is the TOD nsec value instead of NSX32. #### 3.27.1.4 ADDS48 The interconnect link in this mode carries frames where the ingress time in NSX48 format is subtracted from the CF field. Likewise, the egress unit will add the NSX48 at time of departure. This is accomplished by the following steps. - Ingress rewriter: CF is added time from ingress port to rewriter (NSF delta) - · Ingress rewriter: CF is subtracted NSX value when doing the rewrite - Egress rewriter: CF is added NSX value when doing the rewrite - Egress port: CF is added time from rewriter to departure (NSF delta) #### 3.27.1.5 ADDS44 This mode operates as the ADDS48, only NSX44 is used instead. In this mode the egress unit must be able to see that the NSX44 has wrapped since the ingress unit did the subtraction, ie. if the NSX44 at ingress was 0xFFF.FFFF.FFFF, and at egress is 0x000.0000.0132, a larger value was subtracted than added. This is handled by the ingress unit setting CF(46) to the NSX48(44) value, and the egress unit checking the same to see if NSX48(44) has changed. In that case 2<sup>44</sup> is added to CF. #### 3.27.1.6 MONITOR This mode is used for an egress port where we want the frame to be updated to the time of reception only. This is used for CPU ports, where software must be able to compare the frame time with the local time stamp, in order to detect drift. It can also be used for mirroring ports where it is desired to see what time was carried on frames received from an interconnect. When a frame is transmitted on a MONITOR port, the frame will be calculated up to the ingress time stamping point. The frame will be added selected delay (IDLY/EDLY), but will not take any chip internal residence time in as a contributor to the CF. #### 3.27.1.7 **DISABLED** A disabled PTP port is not updating PTP frames at all. This mode only applies to the destination port. If the ingress PTP mode is set to disabled, it is treated as being a FRONT port. #### 3.27.2 Calculation Overview The modes of ingress and egress ports determine which PTP calculations to do. The calculations are split in an ingress half updating the frame to the time at which it passes the central rewriter and an egress half, where residence time from the rewriter is prepared and finalized in the egress port module or on the other side of the link (backplane). In all cases the selected delay is added to CF (IDLY/EDLY). If the ingress port mode is misconfigured as being DISABLED or MONITOR, it will be handled as a FRONT port. The port module is through an internal preamble instructed to either do a delta update of the correction field only (CF), or to do a delta update of both the correction field and the reserved bytes field (CF\_RSRV). In both cases the rewriter NSF value is sent along as a reference for the delta delay calculation in the port. Table 201 • Rewriter Operations for One-Step Operation | Mode | Receiving From | Transmitting To | |--------|--------------------------|----------------------------------------------| | FRONT | CF += (NSF – IFH.STAMP) | Preamble = (CF, NSF) | | RSRV30 | CF += (NSEC – PDU.RSRV) | PDU.RSRV = NSEC<br>Preamble = (CF_RSRV, NSF) | | RSRV32 | CF += (NSX32 – PDU.RSRV) | PDU.RSRV = NSX32 | Table 201 • Rewriter Operations for One-Step Operation (continued) | Mode | Receiving From | Transmitting To | |----------|------------------------------------------------------------------------------------------|--------------------------------| | ADDS44 | CF += (NSX44@rew)<br>CF += (CF_org(46)/=NSX48(44))?2 <sup>44</sup> :0<br>CF(46) = CF(47) | CF -= NSX44 CF(46) = NSX48(44) | | ADDS48 | CF += NSX48 | CF -= NSX48 | | MONITOR | | CF -= (NSF - IFH.TSTAMP) | | DISABLED | | NOP | ## 3.27.3 Detecting Calculation Issues A sticky bit per port informs if frames are received with the reserved bytes field non-zero. This can be used to detect if incoming frames contain unexpected information in the reserved bytes field. If the correction field is outside the valid range $-2^{47}$ to $2^{47}$ –1, another sticky bit is set in the port module indicating the overflow. The port module replaces in this case the final CF with the overflow indication value $2^{47}$ –1. This detection is however disabled when using ADDS48 mode because the correction field in this mode rolls over regularly. ## 3.27.4 Two-Step Functions The two-step PTP mode uses software as a middle stage for informing next hubs about residence times. A FIFO of time stamping events is available for software where ingress and egress time stamps as well as port numbers can be read out. The FIFO can contain 1,024 time stamp entries. Figure 86 • Time Stamp Bus and FIFO The bus passes through all port modules and terminates in a timestamp FIFO in the rewriter. If the analyzer has decided to do a two-step operation, the rewriter pushes two entries into the FIFO. The first entry contains the egress time stamp and the egress port number; the second entry contains the ingress time stamp and the ingress port number. In addition, a flag indicates whether the entry contains ingress or egress information. When correlating frames copied to the CPU with entries in the FIFO, the ingress time stamp found in the IFH is the same as ingress time stamp found in the FIFO. Note that the IDLY and EDLY values are not added to the CF field in the two-step case, as the frames are transferred untouched. Software must manually add these delays for the follow-up frames. ## 3.27.5 Time of Day Time Stamping When sending out SYNC frames with full TOD, the rewriter does the TOD time stamping at the time where the frame passes through the rewriter and the port module is instructed to do a one-step update in addition. The transmitted SYNC therefore has ORG\_TIME='close to departure time', and CF='minor correction to that'. ``` REW: PDU.ORGTIME := (TOD_sec, TOD_nsec) REW: Preamble := (CF, NSF) DEV: CF += NSF@mac Tx-ofs ``` ## 3.27.6 Time of Day Generation The DEVCPU has connection to four GPIOs to be used for 1588 synchronization shown in the following illustration. Figure 87 • Timing Distribution Each block using timing has a TimeOfDay instance included. These modules let time pass according to an incoming delta request, instructing it to add the nominal clock period in nanoseconds (+0/+1/-1) for each system clock cycle. This is controlled by a deltaT function in the DEVCPU, which can be configured to do regular adjustments to the time by adding a single nanosecond more or less at specified intervals. The absT function in the DEVCPU can set the full TOD time in the system. This is controlled by the LoadStore controllers. The DEVCPU includes five LoadStore controllers. All but the last one use a designated GPIO pin on the GPIO interface. LoadStore controller 0 uses PTP\_0 pin; LoadStore controller 1 uses PTP\_1 pin, and so forth. Before using the LoadStore controller, the VCore-III CPU must enable the overlaid functions for the appropriate GPIO pins. For more information, see GPIO Overlaid Functions, page 355. Each controller has CPU accessible registers with the full time of day set, and can be configured to load these into the TimeOfDay instances, or to store the current values from them. The operation can be done on a detected edge on the associated pin or immediately. The GPIO pin can also generate a clock with configurable high and low periods set in nanoseconds using the TimeOfDay watches or it can generate a pulse at a configured time with a configurable duration and polarity. Table 202 • LoadStore Controller | Pin Control Field | Function | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Action | Load: Load TOD_SEC and TOD_NSEC through the absTime bus Delta: Add configured nsec to the current time of day (absT). Store: Store the current TOD_SEC,TOD_NSEC,TOD_NSF. Clock: Generate a clock or a pulse on the pin. | | Sync | Execute the load/store on incoming edge, if action is LOAD or STORE. Generate a pulse instead of clock if action is CLOCK. | | Inverse polarity | Falling edges are detected/generated. | | TOD_sec | The 48-bit seconds of a time of day set to be loaded or stored. | | TOD_nsec | The 30-bit nanoseconds of a time of day set to be loaded or stored. | | TOD_NSF | The 32-bit free running timer to be stored (no load of that one) | | Waveform high | Number of nanoseconds in the high period for generated clocks. Duration of pulse for generated pulse. | | Waveform_low | Number of nanoseconds in the low period for generated clocks. Delay from TOD_ns = 0 for generated pulse. | In addition, the load operation can load a delta to the current time. This is done by executing a LOAD action but using the DELTA command. Each operation generates an interrupt when executed. For the clock action, the interrupt is generated when the output switches to the active level. The interrupts from each controller can be masked and monitored by the interrupt controller in the ICPU\_CFG register target. The five controllers are completely equal in their capabilities. For concatenated distributed TC applications, two of the controllers are set up in STORE/sync mode, where incoming edges on the pin make the Time of day be stored in the controller registers. # 3.27.7 Multiple PTP Time Domains For communicating with link partners running in another TOD domain, the device includes three PTP time domains. Each port belongs to one domain only, and by default, all ports belong to time domain 0. Other time domains are accessed by configuring the time domain in the port modules, the analyzer, the rewriter, and the Loadstore controllers. ## 3.27.8 Register Interface to 1588 Functions The following table lists the blocks and register configurations associated with IEEE 1588 functionality. Table 203 • IEEE 1588 Configuration Registers Overview | Block | Configurations | |--------------|-------------------------------------------------------------------------------------------------------------| | Analyzer | PTP actions in VCAP IS2. | | Rewriter | Path and asymmetry delays Enabling use of preamble Setting PTP port mode/options Accessing time stamp FIFO | | Port modules | Enable rewriting. Read barrel shifter states for accuracy. I/O delays. Per port SMAC for address replacing. | | CPU device | Controlling TOD generation. | ### **3.27.8.1 VCAP IS2 Actions** In the analyzer, the VCAP IS2 actions are related to PTP operation. The REW\_CMD action field determines the PTP actions in the rewriter. Table 204 • PTP Actions in Rewriter | Action Bits | Description | |---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1-0: PTP command | 0: No operation. 1: One-step. 2: Two-step. 3: Time of day. | | 3-2: Delay command | 0: Do not add any delays. 1: Add PTP_EDLY(Tx port). 2: Add PTP_IDLY1(Rx port). 3: Add PTP_IDLY2(Rx port). | | 5-4: Sequence number and time stamp command | 0: No operation. 1: Sequence update. The rewriter contains a table of 256 sequence numbers which can be selected by the lower bits of the time stamp field from the IFH. If this command bit is set, the selected sequence number is put into the PDU, and the sequence will be incremented by one. Feature only makes sense when frame is injected by the CPU, in which case the IFH can be fully controlled by injecting with IFH. 2-3: Delay_Req/Delay_Resp processing. These modes are handled in the analyzer. This is used for automatic response generation without involving software. If bits 1-0 are set to one-step, the rewriter is requested to update the CF field to the time of reception. | | 6: SMAC to DMAC | If set, copy the SMAC into the DMAC of the frame. | | 7: Configuration to SMAC | If set, set the SMAC to the PTP SMAC configured per egress port. | ## 3.27.8.2 Rewriter Registers The following table lists registers associated with time stamping. Table 205 • Rewriter Registers | Register | Description | |------------------------------------------------|---------------------------------------------------------------| | PTP_MODE_CFG | Assign time domain and PTP port mode for each port. | | PTP_EDLY_CFG<br>PTP_IDLY1_CFG<br>PTP_IDLY2_CFG | Configure ingress and egress optional delays to use per port. | | PTP_SMAC_LSB<br>PTP_SMAC_MSB | Configure the optional SMAC to replace in the PDUs. | | PTP_MISC_CFG | Disable UDP checksum updating per port. | | PTP_TWOSTEP_CTRL | Get next time stamp from FIFO. | | PTP_TWOSTEP_STAMP | Next time stamp value. | | PTP_CPUVD_MODE_CFG | Set mode and time domain for CPU and virtual device ports. | | PTP_RSRV_NOT_ZERO | Sticky bit for incoming non-zero reserved bytes field. | | PTP_SEQ_NO | Set or get sequence number for 256 flows. | ### 3.27.8.3 Port Module Registers The following table lists the port module registers associated with time stamping. The PTP PHY PREDICT CFG register must be set for ports with internal PHYs. Table 206 • Port Module Registers | Register | Description | |-----------------------|------------------------------------------------------------------------------------------| | PTP_CFG | Set I/O delays for port, enable PTP, and set port's time domain. | | PTP_EVENTS | Sticky bit for correction field overflow. | | PTP_PHY_PREDICT_CFG | Configures the timing information delivered from the internal PHYs on port 0 and port 1. | | PTP_PHASE_PREDICT_CFG | Enables increased accuracy through clock phase evaluation. | ## 3.27.9 Configuring I/O Delays After a valid link is established and detected by the involved PCS logic, the I/O delays from the internal time stamping points to the serial line must be configured. The delays are both mode-specific and interface-specific, depending on the core clock frequency. Ingress barrel shifter states that in 1G mode, the Rx delays must be added 0.8 ns times the value of PCS1G\_LINK\_STATUS.DELAY\_VAR to adjust for barrel shifting state after link establishment. In 2.5G mode, the multiplier is 0.32 ns. In 100FX mode, the Rx delays must be subtracted 0.8 ns times the value of PCS\_FX100\_STATUS.EDGE\_POS\_PTP to adjust for detected data phase. The following tables provides the Rx and Tx delay times on the ports. Table 207 • I/O Delays at 156.25 MHz | Port Number | 100FX Mode<br>Rx/Tx | 1G Mode<br>Rx/Tx | 2.5G Mode<br>Rx/Tx | 10G Mode<br>Rx/Tx | |-------------|---------------------|------------------|--------------------|-------------------| | 0 – 4 | 69.3/79.5 | 43.2/44.7 | | | | 5, 6 | 78.2/80.8 | 51.7/43.9 | 22.0/14.1 | | | 7, 8 | 123.7/113.1 | 95.5/76.8 | 40.5/29.4 | | | 9, 10 | 123.7/113.1 | 95.5/76.8 | 39.9/29.2 | 111.8/162.1 | Table 208 • I/O Delays at 52 MHz | Port Number | 100FX Mode<br>Rx/Tx | 1G Mode<br>Rx/Tx | 2.5G Mode<br>Rx/Tx | 10G Mode<br>Rx/Tx | |-------------|---------------------|------------------|--------------------|-------------------| | 0 – 4 | 67.3/82.9 | 44.0/44.2 | Does not apply | Does not apply | | 5, 6 | 75.4/83.3 | 52.2/44.2 | Does not apply | Does not apply | | 7, 8 | 116.6/116.0 | 98.1/75.3 | Does not apply | Does not apply | | 9, 10 | 116.6/116.0 | 98.1/75.3 | Does not apply | Does not apply | # 3.28 SyncE and PTP DPLL Timing The device has integrated SyncE and PTP digital phase-lock loop (DPLL) functionality to support G.8262 SyncE EEC (Ethernet Equipment Clock) operation and additional features to support PTP clock recovery, including G.8263 PEC operation. These features simplifies system architectures. The SyncE controller in the device contains a DPLL with programmable filtering, four input clock qualifiers, and an EEC/PEC controller. The following illustration shows the block diagram of the SyncE controller. Figure 88 • SyncE Controller ## 3.28.1 Input Clock Selection The device has four input qualifiers that are each connected to clock recovery blocks. The clock recovery blocks for the first two qualifiers can be connected to the recovered clock of any of the internal ports, to dedicated differential input clocks or to clock inputs connected to the GPIO 12 to GPIO 15 pins. The last two clock qualifier blocks are directly connected to the two 10G Ethernet ports. The selection of the clock input to the input qualifiers is done in the SYNC\_ETH\_CFG registers. ### 3.28.1.1 Input Clock Qualifiers The input clock qualifiers can be programmed to qualify or disqualify the input clock, based on the clock quality. The clock quality is affected by several parameters such as missing clock edges, high frequency jitter, baseline wander, or noise on the input signal. Any of these parameters may lead to a disqualification of the selected input signal. The quality of input clock signal is indicated by alarms. As long as the input quality is within certain programmable bounds, no alarm becomes active. An insufficient input clock signal quality is indicated by an active alarm. The various alarms can be masked before combining them to a single alarm. Two of the alarm collect blocks are available; one alarm is directed to the EEC controller logic, and a second alarm is a general-purpose alarm that can be fed to an internal interrupt. The various blocks and alarms are described in the following sections. ## 3.28.1.2 Single Cycle Monitor (SCM) The single cycle monitor performs a short time observation of the input clock signal. Its major task is to inform the control logic as fast as possible about a missing or noisy clock signal or a clock with duty cycle distortion. The input clock is sampled by a high-speed clock, and the SCM is programmed to match the expected clock rate. The following checks are performed: - Check for missing clock edges. An error (scm\_mis\_clk\_error) is issued when more than a programmable number of clock edges is missing (scm\_max\_mis\_clk\_edge). - Checks for noise. An error (scm\_noise\_error) is issued if more edges occur than expected. - Checks for duty cycle errors. An error (scm\_duty\_cycle\_error) is issued if the duty cycle of the incoming clock deviates from expected. The errors are captured in the OMG QUAL SCM STAT registers. The input qualifier can also be configured to automatically learn the normal behavior of an input clock and then be set to disqualify the input if it changes more than a programmable level, as set by the phase length uncertainty (scm phase uncert). ### 3.28.1.3 Coarse Frequency Monitor (CFM) The coarse frequency monitor measures the frequency of the input clock signal and sets an alarm if the frequency varies more than the limit that is configured in the OMG\_QUAL\_CFM\_CHECK\_CFG register. This is not as fast as the SCM detection, but will react more quickly than the precise frequency monitor in case of sudden changes in frequency that still are small enough to not trigger the SCM. The CFM performs low-pass filtering of the input frequency to produce a CFM value that is checked against the frequency offset limit. The time constant of this low pass filter is programmable. Hysteresis ensures that a marginal signal does not cause the CFM to toggle too often. ### 3.28.1.4 Precise Frequency Monitor (PFM) The precise frequency monitor monitors the long-term frequency accuracy of the input clock and sets an alarm if the frequency varies more than the limit that is configured in the OMG\_QUAL\_PFM\_CHECK\_CFG register. The PFM functionality is the same as the CFM, except the time constants of the low-pass filter are longer. ### 3.28.1.5 External Loss of Sync Input (LOS) The qualifier logic has a dedicated loss-of-signal input with programmable "active" level (the LOS input polarity can be inverted in QUAL\_EXT\_LOS\_INV), which can be used as an additional alarm source. This signal can be connected to the signal detect information from the receiving port or to a GPIO for external signal quality judging logic. ### 3.28.1.6 Loss of Lock Input (LOL) The qualifier logic has a dedicated loss-of-lock input, which is treated as an additional alarm source. This signal is connected to the loss-of-lock signal of the PLL clocking the clock input. When this PLL falls out of lock, any clocking information, such as frequency, must be considered unreliable and the control logic is informed. ### 3.28.1.7 Guard Soak Timer (GST) The Guard Soak Timer (GST) mimics the operation of an analog integrator by accumulating failure events (alarms) from any enabled source (SCM, CFM, PFM, LOS, or LOL) with programmable fill (disqualification) and decay (qualification) times. The disqualification time, T<sub>DISQ</sub>, is the time it takes from when any (enabled) alarm input becomes permanently active until the GST alarm becomes active. The disqualification time can be calculated using the following formula: $$T_{DISQ} = 3.2 \text{ns} \times \text{gst\_qual\_prediv\_i} \times \frac{\text{gst\_qual\_threshold\_i}}{\text{gst\_qual\_incr\_i}}$$ The qualification time, $T_{QUAL}$ , is the opposite of the disqualification time. It is the time it takes from when the last alarm becomes inactive until the GST alarm becomes also inactive. The qualification time is independent of the disqualification time and is calculated using the following formula: $$T_{QUAL} = 3.2 \text{ns} \times \text{gst\_qual\_prediv\_i} \times \frac{\text{gst\_qual\_threshold\_i}}{\text{gst\_qual\_incr\_i}}$$ The following illustration shows the GST timing. There are five basic alarm sources: - scm\_alarm. This alarm is asserted on detection of clock cycle issues like missing clocks or duty cycle errors by single cycle monitor. - cfm\_alarm. This alarm is asserted on detection of (short term) frequency deviations by coarse frequency monitor. - pfm\_alarm. This alarm asserted on detection of (long term) frequency deviations by precise frequency monitor. - lol alarm. This alarm is asserted on detection of PLL lock issues. - los\_alarm. This alarm is sserted on detection of signal detect issues. These alarms are fed to the GST block to provide some kind of hysteresis in timing. The resulting alarm is the 6th possible alarm source: • gst\_alarm. This alarm is asserted if one of the other alarm inputs is active for a long period of time or too often within a given period of time. All six alarms are fed to two dedicated alarm collector blocks, where each alarm can be individually enabled or disabled (masking) to produce two overall alarm outputs. One of the resulting alarm outputs is used by the EEC/PEC controller block, allowing them to automatically switch to a different clock source or to change into holdover mode. The second alarm output can generate an interrupt. ## 3.29 EEC/PEC Controller The EEC/PEC controller in the device can be programmed to use any of the four clock inputs, based on a programmed priority between the inputs and the reported status from the input qualifiers. The EEC/PEC controller implements all the control and timers needed to support a SyncE EEC functionality without timing-critical software control. For PEC operation, the controller can be configured in a mode where the frequency generation is under software control, also called DCO mode. The DCO resolution allows very accurate frequency control with a resolution of 32 × 10<sup>-6</sup> ppb. This corresponds to 1 ns drift per 8.7 hours, assuming an ideal reference clock. The EEC/PEC controller also allow software to read back the filtered input clock frequency so that the generated outputs can be generated based on the combination of the SyncE frequency and the PTP frequency/phase. The output of the EEC/PEC controller is used to control the output frequency/phase of one or more of the output clock synthesizers. The EEC/PEC controller can be configured in the following operational modes. - AUTO mode. The EEC automatically selects between the qualified input clocks, and performs hitless switching between the selected input clocks in case of disqualification of the currently selected clock. If no clocks are valid it goes into holdover mode, where it keeps the output frequency at the last known good input, or into free-run mode if holdover data has not been collected yet. - Forced-to-holdover mode. This mode forces the EEC into holdover. Forced-to-free-run mode. When operating in this mode the output frequencies controlled by the EEC are locked to the reference clock of the chip. It is possible to control the free-run frequency offset relative the reference clock. ## 3.29.1 Input Qualification Timers The selection of each of the four input clocks into the EEC/PEC controller is based on the alarm inputs from the input qualifiers. The resulting clock status can be configured to use two types of timers as specified in the ITU G.781 specification: holdoff timer and wait-to-restore. - Holdoff timer. Timer between an alarm being set until the input is disqualified by the EEC controller if the alarm persists. - Wait-to-restore timer. Timer that ensures that an input stays disqualified for a certain period after being disqualified. In addition, an initial qualification timer can be used to delay a valid input from being selected initially. The holdoff timer has a range of 0 seconds to 65 seconds and can be configured with 1 ms resolution. The wait-to-restore timer has a range of 0 seconds to 1,023 seconds and can be configured with onesecond resolution. **Note:** The wait-to-restore timers cannot be stopped once they are started. If a one-second resolution is required, the wait-to-restore timers must be implemented in software. ### 3.29.2 Reference Clock Selection When the EEC is configured in AUTO mode, the EEC automatically selects between the four input clocks, based on the input status and the programmed priority of the inputs. Each priority 0-3 is configured to select one of the inputs or disabled. When an input is disqualified and a lower priority input selected, the EEC state machine returns to any higher priority input that becomes valid, unless revertive mode is disabled in the OMG\_CTRL\_MAIN\_CFG register. The state machine for the EEC follows the requirements of ITU-T G.781. Figure 90 • EEC State Machine ### 3.29.2.1 Hitless Reference Switching When the holdoff timer is configured to zero, the input switching is done immediately. The architecture of the EEC allows this to happen without any phase jumps at the outputs. This is also the case when switching in and out of the holdover and free-run states. When going from the freerun state to locked state, the output clocks are not locked to the input clock until after an initial holdover value has been acquired. The delay depends on the holdover configuration; the minimum holdover setting takes up to one second. #### 3.29.2.2 Holdover When the EEC controller has selected a valid input clock, it starts to capture holdover frequency data. A programmable progressive low-pass filter (programmable from 0.023 Hz to 1 Hz) filters the frequency data. The holdover logic allows the holdover data to be extracted based on different criteria. Normally the holdover value is based on low-pass filtered and averaged data. The holdover data is saved in a holdover stack. It has a depth of 12 stages. The first stage is updated every second with the low-pass filtered frequency information for the selected input. The second stage is updated every 2nd second and hence the last stage is updated every 211th = 2048th second. The values that is transferred from state to state is calculated based on the following formula: $$HO_n = HO_{n-1} \times (1 - CTRL_HO_FILT_CFG/4) + HO_n \times CTRL_HO_FILT_CFG/4$$ The CTRL\_HO\_FILT\_CFG configuration controls the weight of the averaging function. If CTRL\_HO\_FILT\_CFG=0 then the holdover stack will contain historic input data without averaging. When CTRL\_HO\_FILT\_CFG=2 the holdover stack will contain averaged data where all data has the same weight. When CTRL\_HO\_FILT\_CFG=1 the newest data has more weight than the older data and when CTRL\_HO\_FILT\_CFG=3 the older data has more weight than the new data. The OMG\_CTRL\_HO\_STACK\_CFG.CTRL\_HO\_SEL configuration selects the stage to be used for holdover mode. The OMG\_CTRL\_HO\_STACK\_CFG. CTRL\_HO\_MIN\_FILL\_LVL configuration defines which stage must be filled before a valid holdover value is considered found. The holdover stack is automatically cleared in all free-run modes and is automatically frozen (not updated any longer in all holdover modes). It is possible to read the values of the holdover stack and instead control the holdover value in software. This is enabled by writing the frequency offset (relative to the reference clock of the chip) into the OMG\_CTRL\_DF\_FRM registers and setting OMG\_CTRL\_HO\_STACK\_CFG.CTRL\_HO\_SEL to 15. The stability of the holdover frequency is governed by the stability of the external reference clock. This typically has to be a Stratum 3 or Stratum 3E oscillator depending on the holdover requirements of the equipment. #### 3.29.2.3 PEC Mode In PEC mode, the controller is configured in a mode where the output of the controller is under direct software control, also called DCO mode. This allow one PEC block to control the output frequencies of several clock synthesizers and to maintain the phase relationship between them. When operating in PEC mode, it is still possible to configure and monitor the clock inputs to the EEC/PEC controller, so that the software can track the DCO frequency to an external recovered clock. This can be beneficial in case of PTP holdover or for compensating for local clock variations over temperature. PEC mode is enabled by setting the OMG\_CTRL\_MAIN\_CFG.CTRL\_OP\_MODE to Forced Free-Run mode. The frequency offset, relative to the local reference clock, is then controlled by the values in the OMG\_CTRL\_DF\_FRM registers. The resolution of the DCO control is approximately $32 \times 10^{-6}$ ppb and is given by the following formula: Offset = DF FRM[35:0] $$\times 10^6 / (7 \times 2^{42})$$ ppm ## 3.29.3 Output Clock Synthesizers There are four low-jitter output clock synthesizers in the device. Each synthesizer can be configured independently to operate in three different modes: - Free-run/DCO mode, locked to the reference clock of the device with digital frequency control. - Locked directly to one of the four clock inputs. - Locked to the EEC/PEC controller. The input to each synthesizer is selected in the OMG FILTER MAIN register. #### 3.29.3.1 Differential Frequency Outputs The low-jitter differential outputs of each clock synthesizer can be configured to deliver any frequency in the range from 1 MHz to 250 MHz. ### 3.29.3.2 Single-Ended Clock Outputs Four single-ended clock outputs are available. The frequencies of these outputs can be generated either directly from the differential output of the selected clock synthesizer or from a separate frequency output generated by the same synthesizer. The frequency of the lower frequency output has a fixed ratio to the differential output. The clock output can be divided down with fixed dividers of 1, 2, 4, 5, 8, 16, and 25. Note that dividing with 5 and 25 results in reduced duty cycle. The single-ended clock outputs are configured in the SYNC\_ETH\_CFG register. Note that the maximum output frequency of the single-ended output clocks is 161 MHz and that the jitter performance of the single-ended clock outputs is worse than the differential clock outputs. The following table lists the most common Ethernet frequency rates supported. The LVTTL clock rates can be further divided down by the fixed dividers configured in the SYNC ETH CFG register. Table 209 • Common Ethernet Frequency Outputs | Differential Clock Output | Supported LVTTL Clock Rates | |---------------------------|-----------------------------| | 156.25 MHz | 156.25 MHz, 125 MHz | | 125 MHz | 156.25 MHz | | 250 MHz | 125 MHz | ### 3.29.3.3 Synchronizing Internal Ports The 1G and 2.5G Ethernet ports on the device are all transmitting based on PLL (line clock PLL). When operating the device with an internal EEC controller, PLL must be configured to be sourced from Synthesizer 1 in the PLL5G CFG6 register. The output frequency of Synthesizer 1 and the input frequency of PLL must match and must be configured during startup, because PLL must be configured and running before the Ethernet ports are configured. The differential and single-ended outputs of Synthesizer 1 can be used for external devices, but the output frequency will be dictated by the line-PLL configuration: 25 MHz, 125 MHz, 156.25 MHz, 250 MHz, or 312.5 MHz. ## 3.29.4 Synchronizing IEEE 1588 Time Stamping The IEEE 1588/PTP time stamp logic in the device can be configured to run based on PLL, PLL2, or clock synthesizer 2, depending on the desired operating mode. In hybrid mode, the PTP time progresses based on the SyncE clock, and the PTP software makes time adjustments based on the recovered time. In systems with external PHYs, the time adjustment must be performed in the PHYs as well. When using SW rate control, the PTP time block is configured to compensate for the frequency offset between the PTP time and the clock driving the PTP logic. In systems with external PHYs, this rate adjustment must also be performed in the PHYs. In DCO mode, the frequency driving the PTP time is controlled to match the PTP time. The phase adjust logic allows small phase changes to be made. If external devices/PHYs are using the same frequency source, the time adjustment only needs to happen in the DCO. Ensemble mode is similar to DCO mode, but allows fallback to SyncE holdover mode if the PTP connection is lost and allow the frequency generation to be set taking both the SyncE frequency source and the local reference clock into consideration. Table 210 • PTP/SyncE Operating Mode Support | PTP/Core Clock Source | PTP Operating Mode | Comments | |-----------------------|----------------------------------------------|----------------------------------------------------------------------------------------| | PLL | Hybrid | Allows Synthesizer 2 to be used for other purposes | | PLL2 | SW rate control | SW rate control must be configured in both switch PTP logic and in any external device | | Synthesizer 2 | Hybrid<br>DCO<br>Ensemble<br>SW rate control | Allows full flexibility in PTP operating mode | The CLK\_CFG.SWC\_CLK\_SRC register selects the core/1588 clock and must be configured at startup, before Ethernet switching is enabled. Care should be taken to configure Synthesizer 2 to generate 156.25 MHz before it is selected as the core/1588 clock. The differential and single-ended outputs of Synthesizer 2 can be used for external devices as well, but the output frequency will be 156.25 MHz. ### 3.29.4.1 Low-Pass Filter Configuration The configuration of the low-pass filtering of the DPLL is done in the OMG\_FILTER\_MAIN register. The configuration allows filtering bandwidths from 0.35 millihertz (mHz) to 33 kHz. For G.8262 EEC option 1 operation, the filter bandwidth is configured for 3 Hz, and for EEC option 2 operation, the filter bandwidth is configured for 0.1 Hz. ### 3.29.4.2 Phase Slope Limiting In addition to the low-pass filtering, the slope of any phase change can be limited. The phase slope limit is configured as a maximum frequency offset compared to the holdover value or alternatively to the local reference. The maximum ppb limit is configured as shown in the following equation: $$Limit = PSL\_LIMIT[9:5] \times 2^{PSL\_LIMIT[4:0]}$$ To configure a maximum phase slope of 100 ns/s = 100 ppb, the PSL\_LIMIT[4:0] = 2, and the PSL\_LIMIT[9:5] = 25. The synthesizers can be configured to run with phase build-out enabled or disabled. When phase build-out is disabled, the synthesizers ensure that the phase relationship between the input clock and the output clock returns to the initial state after the phase slope limiter has been active. If phase build-out is enabled, the phase difference that has been caused by the phase change at the input is ignored. The OMG\_FILTER\_PSL register of each synthesizer controls the slope and the operation mode. #### 3.29.4.3 Phase Shift Control The device allows manipulation of the output phases of the synthesizers by adding or subtracting a small frequency offset for a programmed amount of time. The following two modes are supported: - Mode A: The configured frequency offset is generated for the configured time. This frequency offset is applied to the input of the filter. - Mode B: The output frequency is stepped up, stays at the fixed offset for the defined time, and then stepped down again. Because both ramps have the same gradient (with opposite sign), the resulting phase offset is equal to the rectangle defined by the number of increments/decrements and the time between the first increment/decrement. This mode is not affected by the filtering. The entire phase shift generator is configured in the OMG\_PS\_GEN\_MAIN\_CFG register, and the timer configuration in the OMG\_PS\_GEN\_TIMER\_CFG register. The phase shift generator can control one or more of the output synthesizers simultaneously. The output synthesizers affected are selected in the OMG\_PS\_GEN\_MAIN\_CFG register. The phase shift control can also be used in IEEE1588 applications where it is desired to lock the IEEE1588 clock to the SyncE clock. If a time adjustment is needed, it can be done by using the phase shift control on the output synthesizer driving the 1588 timers. This ensures that the time adjustment happens synchronously on all parts of the system. ### 3.29.4.4 Clock Synthesizer DCO Operation The frequency of each synthesizer can be controlled in the Digitally Controlled Oscillator (DCO) mode. The DCO functionality can generates a small frequency offset to the current operating mode of the synthesizer. The DCO mode is typically used when the synthesizer is configured in free-run mode. This allows for precise frequency adjustments based on software control. This is the mode used when running packet-based timing protocols, such as IEEE 1588, where the software can control the frequency of the system based on the timing information received in the PTP frames. The DCO mode can also be used while the synthesizers are locked to the EEC/PEC block or locked directly to one of the input clocks, creating a frequency offset relative to the frequency it locks to. There is one DCO controller per clock synthesizer. If multiple synthesizers need to be controlled with the same DCO, the per-clock synthesizer DCO functionality should not be used. It is recommended to use the DCO functionality in the EEC/PEC block instead and then configure the synthesizers to lock to the PEC controller. ### 3.29.4.5 Generating "T4" Clock Outputs Some telecom systems require the generation of an unfiltered output clock that can be connected to a separate piece of equipment with better filtering capabilities. This is called a "T4" clock output in the ITU-T specifications. In the VSC7415 device, the T4 output clock is generated by configuring one of the synthesizers to lock to the specified input clock. ## 3.29.5 I/O Pin Mapping The following table shows the fixed mapping from interface macros to the device I/O pins. Table 211 • Interface Macro to I/O Pin Mapping | SERDES Macros | I/O Pin Names | |----------------------------|-------------------------------------------------------------------------------------| | SERDES10G_0 to SERDES10G_3 | CLKINO_N, CLKINO_P, CLKOUTO_N, CLKOUTO_P - CLKIN3_N, CLKIN3_P, CLKOUT3_N, CLKOUT3_P | ## 3.30 VRAP Engine The Versatile Register Access Protocol (VRAP) engine allows external equipment to access registers in the device through any of the Ethernet ports on the device. The VRAP engine interprets incoming VRAP requests, and executes read, write, and read-modify-write commands contained in the frames. The results of the register accesses are reported back to the transmitter through automatically generated VRAP response frames. The device supports version 1 of VRAP. All VRAP frames, both requests and responses, are standard Ethernet frames. All VRAP protocol fields are big-endian formatted. The registers listed in the following table control the VRAP engine. Table 212 • VRAP Registers | Register | Description | Replication | |----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------| | ANA_CL:PORT:CAPTURE_CFG. CPU_VRAP_REDIR_ENA | Enable redirection of VRAP frames to CPU. | Per port | | ANA_CL::CPU_PROTO_QU_CFG. CPU_VRAP_QU | Configure the CPU extraction queue for VRAP frames. | None | | QFWD:SYSTEM:FRAME_COPY_CFG.<br>FRMC_PORT_VAL | Map VRAP CPU extraction queue to a CPU port. One CPU port must be reserved for VRAP frames. | Per CPU<br>extraction<br>queue | | DEVCPU_QS:XTR:XTR_GRP_CFG.MODE | Enable VRAP mode for reserved CPU port. | Per CPU port | | DEVCPU_QS:INJ:INJ_GRP_CFG.MODE | Enable VRAP mode injection for reserved CPU port. | Per CPU port | | ASM:CFG:PORT_CFG.INJ_FORMAT_CFG | The IFH without prefix must be present for VRAP response frames. | Per port | | ASM:CFG:PORT_CFG.NO_PREAMBLE_ENA | Expect no preamble in front of IFH and frame. | Per port | | DEVCPU_GCB::VRAP_ACCESS_STAT | VRAP access status. | None | The VRAP engine processes incoming VRAP frames that are redirected to the VRAP CPU extraction queue by the basic classifier. For more information about the VRAP filter in the classifier, see CPU Forwarding Determination, page 108. The VRAP engine is enabled by allocating one of the two CPU ports as a dedicated VRAP CPU port (DEVCPU\_QS:XTR:XTR\_GRP\_CFG.MODE and DEVCPU\_QS:INJ:INJ\_GRP\_CFG.MODE). The VRAP CPU extraction queue (ANA\_CL::CPU\_PROTO\_QU\_CFG.CPU\_VRAP\_QU) must be mapped as the only CPU extraction queue to the VRAP CPU port (QFWD:SYSTEM:FRAME\_COPY\_CFG.FRMC\_PORT\_VAL). In addition, the VRAP CPU port must enable the use of IFH without prefix and without preamble (ASM::PORT\_CFG). The complete VRAP functionality can be enabled automatically at chip startup by using special chip boot modes. For more information, see VCore-III Configurations, page 309. ## 3.30.1 VRAP Request Frame Format The following illustration shows the format of a VRAP request frame. Figure 91 • VRAP Request Frame Format | DMAC | SMAC | EtherType | EPID | | | VRAP Command | S | FCS | |----------------|----------------|-----------|---------|-----------------------|----|-----------------|----|-----------| | Any valid DMAC | Any valid SMAC | 0x8880 | 0x0004 | VRAP HDR<br>(Request) | #1 | • • | #n | Valid FCS | | 48 bits | 48 bits | 16 bits | 16 bits | 32 bits | | variable lengtl | _ | 32 bits | VRAP request frames can optionally be VLAN tagged with one VLAN tag. The EtherType = 0x8880 and the Ethernet Protocol Identifier (EPID) = 0x0004 identify the VRAP frames. The subsequent VRAP header is used in both request and response frames. The VRAP commands included in the request frame are the actual register access commands. The VRAP engine supports the following five VRAP commands: - READ: Returns the 32-bit contents of any register in the device. - WRITE: Writes a 32-bit value to any register in the device. - READ-MODIFY-WRITE: Does read/modify/write of any 32-bit register in the device. - IDLE: Does not access registers; however, it is useful for padding and identification purposes. - PAUSE: Does not access registers, but causes the VRAP engine to pause between register access. Each of the VRAP commands are described in the following sections. Each VRAP request frame can contain multiple VRAP commands. Commands are processed sequentially starting with VRAP command 1, 2, and so on. There are no restrictions on the order or number of commands in the frame. ## 3.30.2 VRAP Response Frame Format The VRAP response frame follows the VRAP request frame in terms of VLAN tagging: If the VRAP request was tagged, the VRAP response is also tagged using the same VLAN. Only the READ and IDLE commands require data to be returned to the transmitter of the VRAP request frame. However, even if the VRAP request frame does not contain READ and IDLE commands, a VRAP response frame is generated with enough padding data (zeros) to fulfill the minimum transfer unit size. ### 3.30.3 VRAP Header Format Both VRAP request and VRAP response frames contain a 32-bit VRAP header. The VRAP header is used to identify the protocol version and to differentiate between VRAP requests and VRAP response frames. The device supports VRAP version 1. A valid VRAP request frame must use Version = 1 and Flags.R = 1. Frames with an invalid VRAP header are discarded and not processed by the VRAP engine. The following illustration shows the VRAP header. Figure 92 • VRAP Header Format #### Version: Set to 0x1 in VRAP response frames. VRAP request frames are ignored if Version <> 1 #### Flags 4 bits are used for Flags. Only one flag is defined: R: 0=Request, 1=Response Rsv: Set to 0 in VRAP response frames and ignored in VRAP request frames. #### Reserved: Set to 0 in VRAP response frames and ignored in VRAP request frames. ### 3.30.4 VRAP READ Command The VRAP READ command returns the contents of any 32-bit register inside the device. The 32-bit read-data result is put into the VRAP response frame. The READ command is 4 bytes wide and consists of one 32-bit address field, which is 32-bit aligned. The 2 least significant bits of the address set to 01. The following illustration shows the request command and the associated response result. Figure 93 • READ Command Figure 94 • WRITE Command ## 3.30.5 VRAP READ-MODIFY-WRITE Command The READ-MODIFY-WRITE command does read/modify/write-back on any 32-bit register inside the device. The READ-MODIFY-WRITE command is 12 bytes wide and consists of one 32-bit address field, which is 32-bit aligned. The two least significant bits of the address set to 11 followed by one 32-bit write-data field followed by one 32-bit overwrite-mask field. For bits set in the overwrite mask, the corresponding bits in the write data field are written to the register while bits cleared in the overwrite mask are untouched when writing to the register. The following illustration shows the command. Figure 95 • READ-MODIFY-WRITE Command #### Request: | Register address, bits 31:2 | 11 | Register write data | Overwrite mask | |-----------------------------|----|---------------------|----------------| | 1 | | | 1 | | 32 bits | | 32 bits | 32 bits | ### 3.30.6 VRAP IDLE Command The IDLE command does not access registers in the device. Instead it just copies itself (the entire command) into the VRAP response. This can be used for padding to fulfill the minimum transmission unit size, or an external CPU can use it to insert a unique code into each VRAP request frame so that it can separate different replies from each other. The IDLE command is 4 bytes wide and consists of one 32-bit code word with the four least significant bits of the code word set to 0000. The following illustration depicts the request command and the associated response. Figure 96 • IDLE Command ### 3.30.7 VRAP PAUSE Command The PAUSE command does not access registers in the device. Instead it causes the VRAP engine to enter a wait state and remain there until the pause time has expired. This can be used to ensure sufficient delay between VRAP commands when this is needed. The PAUSE command is 4 bytes wide and consists of one 32-bit code word with the four least significant bits of the code word set to 0100. The wait time is controlled by the 28 most significant bits of the wait command. The time unit is 1 us. The following illustration depicts the PAUSE command. Figure 97 • PAUSE Command # 3.31 Energy Efficient Ethernet The Ethernet ports support Energy Efficient Ethernet (EEE) to reduce power consumption when there is little or no traffic on a port. The state diagram in the following illustration shows the EEE LPI algorithm implemented in the device. Figure 98 • EEE State Diagram - LPI\_EMPTY: Low power mode. Port has no frames for transmission. - LPI\_NONEMPTY: Low power mode. Port has frames for transmission, but the number of frames is very limited (below EEE URGENT THRES in OQS) or EEE TIMER AGE has not passed yet. - ACTIVATING: Port is being activated prior to restarting frame transmission. The timer EEE TIMER WAKEUP controls the length of the activation time. - ACTIVE\_NONEMPTY: Port is active and transmitting. This is the normal state for ports without EEE enabled. - ACTIVE\_EMPTY: Port is active, but currently has no frames for transmission. If frames for transmission do not become available within EEE\_TIMER\_HOLDOFF, then the port enters low power mode (in state LPI\_EMPTY). The state transition timing values are configured in the EEE\_CFG register per port module, and the levels at which the queue system asserts forward pressure are configured in the QSYS::EEE\_CFG and QSYS::EEE\_THRES registers. As illustrated, the "port has frames for transmission" condition is true if there are frames for transmission and the scheduling algorithm allows transmission of any of the available frames. So it is possible that a port enters LPI\_EMPTY or stays in LPI\_EMPTY, even though there are frames in one or more queues. It is also possible, though not likely, that forward pressure is set for one or more queues when going into LPI\_EMPTY. This occurs when the scheduling algorithm has decided to transmit from other queue or queues than those signalling forward pressure and the transmission of these frames causes the port leaky bucket to close. The "forward pressure signalled for queues" condition does not look at whether the queues with forward pressure are actually allowed to transmit. For ports that are shaped to a low bandwidth, the forward pressure watermark in OQS should be set a low value, such that it is mainly the port shaping that controls when to exit LPI. ## 3.32 CPU Injection and Extraction This section provides an overview of how the CPU injects and extracts frames to and from the switch core The switch core forwards CPU extracted frames to eight CPU extraction queues that per queue are mapped to one of the two CPU ports (by means of QFWD:SYSTEM:FRAME\_COPY\_CFG[0:7]) that the CPU can access. For each CPU extraction queue, it is possible to specify the egress priority (QFWD:SYSTEM:FRAME\_COPY\_CFG.FRMC\_QOS\_ENA). For each CPU port, there is strict priority selection between the egress queues. For injection, there are two CPU injection groups that can simultaneously forward frames into the analyzer. The CPU can access the injection and extraction groups through either a Frame DMA or direct register access. For more information about injecting and extracting CPU traffic through front ports used as NPI port, see Internal Frame Header Placement, page 18; Setting Up a Port for Frame Injection, page 45; and Forwarding to GCPU, page 263. ## 3.32.1 Frame Injection The traffic at any injection pipeline point from CPU, NPI, and AFI using the IFH (IFH.MISC.PIPELINE ACT:= INJ MASQ and IFH.MISC.PIPELINE PT: = <value>). When a frame is injected at a given pipeline point, it is logically not processed in the flow before reaching the injection point. For example, a frame injected at the ANA\_CLM pipeline point bypasses VRAP detection and basic classification, which requires the frame to be injected with an IFH configured with all the fields normally set by basic classification. Injecting a frame at the ANA\_DONE pipeline point causes it to bypass the complete analyzer and destination port must be specified in IFH (IFH.MISC.DPORT = <egress port>). Frames can be injected as either unicast or as multicast: - Unicast injection that allows injection into a single egress port (configured in IFH.MISC.DPORT) with all IFH.DST.ENCAP operators available in the Rewriter such as OAM and PTP detection and hardware handling (if IFH.FWD.DST MODE is set to ENCAP). - Multicast injection that allows injection to multiple egress ports (IFH.FWD.DST\_MODE = INJECT and IFH.DST.INJECT.PORT\_MASK). Because IFH.DST is used for specifying the destination set, it is not possible to use IFH.DST.ENCAP for this type of injection and all IFH.DST.ENCAP fields will default to 0. This mode bypasses the analyzer, meaning that all IFH fields used by rewriter must be given a proper value by software. ### 3.32.1.1 Masgueraded Injection The device supports masqueraded injection of frames from CPU where processing of the frame is done as if the frame was received on the masqueraded port (IFH.MISC.PIPELINE\_ACT=INJ\_MASQ and IFH.FWD.SRC\_PORT=<masqueraded port>). A masquerade-injected frame sees the same source filter, classification, and learning as the physical port being masqueraded. #### 3.32.1.2 Injection Pipeline Points The device supports specifying where in the processing flow a frame is injected by specifying a pipeline point for the frame (IFH.MISC.PIPELINE\_PT0). The frame will then only be processed after the specified injection point. ### 3.32.2 Frame Extraction The CPU receives frames through eight CPU extraction queues. These extraction queues can be mapped to one of the two CPU ports or any of the front ports (QFWD:SYSTEM:FRAME\_COPY\_CFG[0-7]). The CPU extraction queues use memory resources from the shared queue system and are subject to the thresholds and congestion rules programmed for the CPU extraction queues and the shared queue system in general. A frame can be extracted for multiple reasons. For example, a BPDU with a new source MAC address can be extracted as both a BPDU and a learn frame with two different CPU extraction queues selected. By default, the highest CPU extraction queue number receives a copy of the frame, but it is also possible to generate multiple frame copies to all the selected CPU extraction queues (ANA\_AC::CPU\_CFG.ONE\_CPU\_COPY\_ONLY\_MASK). The CPU can read frames from the CPU port in two ways: - Reading registers in the CPU system. For more information, see Manual Extraction, page 334. - Using the Frame DMA in the CPU system. For more information, see FDMA Extraction, page 333. CPU extracted frames include an IFH (28-bytes) placed in front of the DMAC. The IFH contains relevant side band information about the frame, such as the frame's classification result (VLAN tag information, DSCP, QoS class) and the reason for sending the frame to the CPU. For more information about the contents of the IFH, Frame Headers, page 17. The originating CPU extraction port number is not part of the IFH, however, a 4-byte header can be included in front of the IFH containing the CPU extraction port number (DEVCPU QS::XTR GRP CFG.MODE). ## 3.32.3 Forwarding to CPU Several mechanisms can be used to trigger redirection or copying of frames to the CPU. The following blocks can generate traffic to a CPU queue. - Analyzer classifier ANA CL - Analyzer Laver 3 ANA L3 - Analyzer Access Control Lists ANA ACL - Analyzer Layer 2 ANA L2 - Analyzer Access Control ANA AC - Rewriter Frames copied or redirected to the CPU from both the rewriter and the Up-MEPs are looped and passed another time through the analyzer. ## 3.32.4 Automatic Frame Injection (AFI) The AFI block supports repeated (automated) injection, which requires the injection frame to be sent to the AFI block with a single IFH bit set (IFH.FWD.AFI\_INJ) and with an IFH header configured as for normal CPU injection. After an injection frame is sent to the AFI block, the frame can be added for AFI injection. For more information, see Adding Injection Frame, page 240. Frames injected from the AFI block are treated as any CPU injection, where IFH fields controls how injection occurs. Frames from the AFI can either be injected directly into an egress port or they can appear as if they were received on an ingress port (masquerading). Masqueraded frames are subsequently processed by the analyzer like any other frame received on the port. # 3.33 Priority-Based Flow Control (PFC) Priority-based flow control (PFC, IEEE 802.1Qbb) is supported on all ports for all QoS classes. The device provides independent support for transmission of pause frames and reaction to incoming pause frames, which allows asymmetric flow control configurations. #### 3.33.1 PFC Pause Frame Generation The queue system monitors the congestion per ingress and egress queue. If a flow control condition is asserted, the queue system forwards the congestion status to the disassembler. The disassembler stores the congestion status per (port, priority). Based on the congestion status, the disassembler will transmit PFC frames for each port. ### 3.33.1.1 Queue System The queue system has a set of dedicated PFC watermarks. If the memory consumption of a queue exceeds a PFC watermark, a flow control condition is asserted, and the updated congestion status is forwarded the disassembler. For information about the configuration of the PFC watermarks, see Priority-Based Flow Control (PFC), page 299. #### 3.33.1.2 Disassembler The disassembler (DSM) stores the congestion status per queue (per port, per priority) and generates PFC PDU based on the information. For more information about the available PFC configuration registers, see PFC Pause Frame Generation, page 270. The following illustration shows the algorithm controlling the generation of PFC frames for each port. The 8-bit congestion state from the queue system is fc\_qs. TX\_PAUSE\_VAL and PFC\_MIN\_UPDATE\_TIME are configurable per port. The TX\_PAUSE\_VAL configuration is shared between LLFC and PFC. When a priority becomes congested, a PFC PDU is generated to flow control this priority. When half of the signaled timer value has expired, and the queue is still congested, a new PFC PDU is generated. If other priorities become congested while the timer is running, then PFC\_MIN\_UPDATE\_TIME is used to speed up the generation of the next PFC PDU. The timer is shared between all priorities per port. Every PFC PDU signals the flow control state for all priorities of the port. In other words, the priority\_enable\_vector of the PFC PDU is always set to 0x00ff, independent of whether or not a priority is enabled for flow control. For disabled priorities, the pause time value is always set to 0. Figure 99 • PFC Generation Per Port fc\_qs: Congestion state per priority from QS #### **3.33.1.3** Statistics The number of transmitted pause frames is counted in the TX\_PAUSE\_CNT counter and shared with the counter for transmitted link-layer flow control pause frames. Statistics are handled locally in the DEV10G port modules. For other port module types, the assembler handles the statistics. ## 3.33.2 PFC Frame Reception Received PFC frames are detected by the assembler. The status is forwarded to the queue system, which will pause the egress traffic according to the timer value specified in the pause frames. #### 3.33.2.1 Assembler The assembler identifies PFC PDUs and stores the received pause time values in a set of counters. The counters are decremented according to the link speed of the port. The assembler signals a stop indication to the queue system for all (port, priority) with pause times different from 0. For information about the PFC configuration of the assembler, see Setting Up PFC, page 47. ### 3.33.2.2 Queue System The queue system stores the PFC stop indications received from the assembler per (port, priority). It pauses the transmission for all egress queues with an active PFC stop indication. The queue system does not require any PFC configuration. #### 3.33.2.3 Statistics PFC pause frames are recognized as control frames and counted in the RX\_UNSUP\_OPCODE\_CNT counter. Statistics are handled locally in the DEV10G port modules. For other port module types, the assembler handles the statistics. ## 3.34 Protection Switching The following types of hardware-assisted protection switching are supported: - · Ethernet ring protection switching - · Port protection switching Ring protection is also supported over a link aggregation group (LAG). ## 3.34.1 Ethernet Ring Protection Switching When protection switching occurs in an Ethernet ring (ITU-T G.8032), the following actions must be taken to restore connectivity. - MAC addresses learned on the ring ports for the involved FIDs must be flushed from the MAC table. This is done using the scan functionality in the LRN block. Using ANA\_L2:COMMON:SCAN\_FID\_CFG.SCAN\_FID\_VAL MAC, addresses for up to 16 FIDs can be flushed at a time. - The RPL port must be changed to forwarding state and ports interfacing to the failed link must be changed to blocking state. For rings supporting many VLANs, this can be done efficiently using VLAN TUPE. The following illustration shows an Ethernet ring protection example. Switch A is part of two rings, ring 1 and ring 2. Ring 1 uses 18 VIDs, VID 4-19 and 31-32, for forwarding traffic. Ring 2 uses 32 VIDs, VID 10-30 and 40-50. To allow a VLAN TUPE command to identify the VIDs used by each of the two rings, a bit in the TUPE\_CTRL field in the VLAN table is allocated for each of the two rings. In this example, ring 1 uses bit 0 in TUPE\_CTRL, and ring 2 uses bit 1. Figure 100 • Ethernet Ring Protection Example The following table shows the configuration of the VLAN table of switch A. The VLAN\_PORT\_MASK bit shows only the value for the ring ports. For the other ports (ports 2-6), the VLAN\_PORT\_MASK bits are assumed to be 0. Table 213 • VLAN Table Configuration Before APS | Address (VID) | TUPE_CTRL | VLAN_PORT_MASK | VLAN_FID | |---------------|-----------|----------------|--------------| | 4-9 | 0x01 | 0x0003 | 4-9 | | 10-19 | 0x03 | 0x0083 | 10-19 | | 31-32 | 0x01 | 0x0003 | 31-32 | | 20-30, 40-50 | 0x02 | 0x0080 | 20-30, 40-50 | VID 4-9 and 31-32 are only used by ring 1, so only bit 0 is set in TUPE\_CTRL. VLAN\_PORT\_MASK includes the two ring ports of ring 1, port 0, and port 1. VID 10-19 are used by both ring 1 and ring 2, so bit 0 and bit 1 are both set in TUPE\_CTRL. VLAN\_PORT\_MASK includes the ring ports of ring 1 as well as port 7, used by ring 2. Port 8 is not included, because it is in blocking state. VID 20-30 and 40-50 are only used by ring 2, so only bit 1 is set in TUPE\_CTRL. VLAN\_PORT\_MASK includes port 7. In this example, independently learning is used for all VLANs; that is, a separate FID is used for each VID. To also block reception of frames on any blocking ports, ANA\_L3:COMMON:VLAN\_FILTER\_CTRL must be configured to include all ring ports. In this example ports 0,1,7 and 8 must be set in ANA\_L3:COMMON:VLAN\_FILTER\_CTRL. The following illustration shows the same set up as the previous illustration, but now a link in ring 2 has failed. As a result, the RPL of ring 2 must be activated, meaning port 8 of switch A must be changed to forwarding state. Figure 101 • Ethernet Ring with Failure To avoid having to perform write access to the VLAN\_PORT\_MASKs of each of VID 10-30 and 40-50, VLAN TUPE can be used instead. The following table lists the VLAN TUPE parameters to reconfigure the VLAN table. Table 214 • VLAN TUPE Command for Ring Protection Switching | Field | Value | Comment | |------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------| | TUPE_CTRL_BIT_MASK | 0x0002 | Bits 0 and 1 of TUPE_CTRL are used as bit mask. The TUPE command is applied only to VIDs used by ring 2, so only bit 1 is set. | | TUPE_CTRL_BIT_ENA | 1 | Enables use of TUPE_CTRL_BIT_MASK. | | TUPE_START_ADDR | 10 | To make VLAN TUPE complete faster, only cover VID 10-50. | | TUPE_END_ADDR | 50 | | | TUPE_CMD_PORT_MASK_SET | 0x0100 | Enables forwarding on port 8. | | TUPE_START | 1 | Starts VLAN TUPE. The device clears TUPE_START when TUPE is completed. | After the VLAN TUPE command is completed, the VLAN table is updated as shown in the following table. Table 215 • VLAN Table Configuration After APS | Addr (VID) | TUPE_CTRL | VLAN_PORT_MASK | VLAN_FID | |--------------|-----------|----------------|--------------| | 4-9 | 0x01 | 0x0003 | 4-9 | | 10-19 | 0x03 | 0x0183 | 10-19 | | 31-32 | 0x01 | 0x0003 | 31-32 | | 20-30, 40-50 | 0x02 | 0x0180 | 20-30, 40-50 | The TUPE\_CTRL field is 16 bits wide, so using the described approach allows up 16 Ethernet rings with VLAN TUPE assisted protection switching. However, any unused bits in the 11-bit wide VLAN\_PORT\_MASK can be used in the same manner as TUPE\_CTRL bits. For Ethernet rings using only a few VIDs, there is little to gain in using VLAN TUPE and new values could instead be written directly to the VLAN PORT MASK of the relevant VIDs. In addition to running the VLAN TUPE commands listed in the previous table, any MAC addresses learned on the ring ports of ring 2 must be flushed from the MAC table. In the above example, ring 2 uses 32 VIDs for forwarding traffic. Each of these use a specific FID. In this example, FID is set equal to VID. MAC addresses for up to 16 FIDs can be flushed at a time, so to flush MAC addresses for 32 FIDs, two flush commands must be executed. The first flush command is shown in the following table. The second flush command is identical, except SCAN FID VAL is set to 26-30, 40-50. Table 216 • MAC Table Flush, First Command | Field | Value | Comment | |------------------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ANA_L2::SCAN_FID_CTRL.SCAN_FID_ENA | 1 | Enables use of SCAN_FID_VAL. | | ANA_L2::SCAN_FID_CFG.SCAN_FID_VAL | 10-25 | Flushes FIDs 10-25. Flushing can be done for up to 16 discrete FID values at a time. If flushing needs to be done for less than 16 FIDs. the unused FID values must be set to 0x1FFFF. | | LRN::SCAN_NEXT_CFG.FID_FILTER_ENA | 1 | Enables FID specific flushing. | | LRN::MAC_ACCESS_CFG_0.MAC_ENTRY_FID | 0x1FFFF | 0x1FFFF => not used. | | LRN::AUTOAGE_CFG_1.USE_PORT_FILTER_ENA | 1 | Enables flushing for specific ports. | | ANA_L2::FILTER_LOCAL_CTRL | 0x0180 | Flushes port 7 and 8. | | LRN::SCAN_NEXT_CFG.SCAN_NEXT_REMOVE_FOUND_ENA | 1 | Removes matches. In other words flushing. | | LRN::COMMON_ACCESS_CTRL.MAC_TABLE_ACC ESS_SHOT | 1 | Start flushing. The device clears MAC_TABLE_ACCESS_SHOT when flushing has completed. If desirable the device can be configured to generate an interrupt when flushing has completed. This can be used to trigger any subsequent flush commands. | Flushing MAC addresses from the MAC table usually takes longer than running VLAN TUPE. As a result, to have the protection switching complete as fast as possible, start MAC table flushing first, followed by VLAN TUPE. The two will then run in parallel, and when both have completed, the protection switching is done. ## 3.34.2 Link Aggregation For ring protection, the working/protection entity can be forwarded on a LAG, providing an additional layer of hardware assisted protection switching. When a link within the LAG fails, the 16 port masks in ANA\_AC:AGGR must be updated to avoid forwarding on the failed link. To avoid consuming multiple entries in VCAP ES0 for services being forwarded on a LAG, REW:COMMON:PORT\_CTRL.ES0\_LPORT\_NUM must be setup such that a common port number is used in VCAP ES0 keys, regardless of the actual LAG member chosen. ## 3.34.3 Port Protection Switching The device supports several methods through which 1:1 port protection switching can be supported: - Link Aggregation Groups. A LAG with two ports can be configured and ANA\_AC:AGGR can be set to only use one of the links in the LAG. - Disabling the standby port in ANA L3:MSTP. - Disabling the standby port using ANA\_L3:COMMON:PORT\_FWD\_CTRL and ANA\_L3:COMMON:PORT\_LRN\_CTRL. This is the recommended approach, because it interferes minimally with other features of the device. Regardless of the method, a logical port number must be configured for the involved ports such that MAC addresses are learned on the logical port number to avoid the need for flushing MAC table entries when protection switching occurs. The logical port number is configured in ANA CL:PORT:PORT ID CFG.LPORT NUM. REW:COMMON:PORT\_CTRL.ES0\_LPORT\_NUM must be used to avoid consuming multiple VCAP ES0 entries. For more information, see Link Aggregation, page 304. ## 3.35 Low Power Mode For applications that only use 1G port speeds it is possible to change the switch core to a low power mode where the operating clock frequency is dropped to one third of the normal clock frequency. Configuration of the switch core clock frequency is done after reset, before enabling switch ports. The low power mode can be used together with DPLL functionality. ## 3.35.1 One-Time Configurations for Low Power Mode For applications that only use 1G port speeds, reconfiguration of the switch core clock frequency is done in several steps listed in the following: - Configure the switch core clock frequency: HSIO:PLL5G\_CFG:PLL5G\_CFG0.CORE\_CLK\_DIV = 25 (write to all PLLs when applicable), HSIO::CLK\_CFG.SWC\_CLK\_DIV2 = 1. - 2. Configure the port calendar using the following procedure: ``` DSM::TAXI_CAL_CFG[0].CAL_PGM_ENA = 1 for (i=0; i<6; i++) { DSM::TAXI_CAL_CFG[0].CAL_IDX = i DSM::TAXI_CAL_CFG[0].CAL_PGM_VAL = i } DSM::TAXI_CAL_CFG[0].CAL_PGM_ENA = 1 DSM::TAXI_CAL_CFG[1].CAL_PGM_ENA = 1 for (i=0; i<5; i++) { DSM::TAXI_CAL_CFG[1].CAL_IDX = i DSM::TAXI_CAL_CFG[1].CAL_PGM_ENA = 1 } DSM::TAXI_CAL_CFG[1].CAL_PGM_ENA = 1 DSM::TAXI_CAL_CFG[2].CAL_PGM_ENA = 1 for (i=0; i<2; i++) { DSM::TAXI_CAL_CFG[2].CAL_IDX = i DSM::TAXI_CAL_CFG[2].CAL_IDX = i DSM::TAXI_CAL_CFG[2].CAL_IDX = i DSM::TAXI_CAL_CFG[2].CAL_PGM_VAL = i } DSM::TAXI_CAL_CFG[2].CAL_PGM_ENA = 1</pre> ``` 3. Configure VCore to operate with lower frequency: DEVCPU\_PTP::PTP\_SYS\_CLK\_CFG.PTP\_SYS\_CLK\_PER\_NS = 19, DEVCPU\_PTP::PTP\_SYS\_CLK\_CFG.PTP\_SYS\_CLK\_PER\_PS100 = 192, DEVCPU\_GCB::SIO\_CLOCK.SYS\_CLK\_PERIOD = 192, DEVCPU GCB::FAN CFG.CLK PERIOD = 192. Configure assembler to operate with lower frequency: ASM::TIME\_TICK\_CFG.TIME\_TICK\_VAL = 873812, ASM::PFC\_TIMER\_MAX.PFC\_TIMER\_MAX[1] = 3, ASM::PFC\_TIMER\_MAX.PFC\_TIMER\_MAX[2] = 11, ASM::PFC\_TIMER\_MAX.PFC\_TIMER\_MAX[3] = 27, ASM::PFC\_TIMER\_MAX.PFC\_TIMER\_MAX[4] = 267, ASM::PFC\_TIMER\_MAX.PFC\_TIMER\_MAX[5] = 2667. 5. Configure analyzer to operate with lower frequency: ANA\_AC\_POL:COMMON\_SDLB:DLB\_CTRL.CLK\_PERIOD\_01NS = 192, ANA AC POL:COMMON BDLB:DLB CTRL.CLK PERIOD 01NS = 192, ANA\_AC\_FOL:COMMON\_BDEB.DEB\_CTRL:CER\_FERIOD\_01NS = 192, ANA\_AC\_FOL:COMMON\_BUM\_SLB:DLB\_CTRL:CLK\_PERIOD\_01NS = 192, LRN::AUTOAGE CFG 1.CLK PERIOD 01NS = 192. Configure scheduler to operate with lower frequency: HSCH::SYS\_CLK\_PER.SYS\_CLK\_PER\_100PS = 192. ### 3.35.2 General Considerations in Low Power Mode In low power mode, the switch core clock period is 19.2 ns. This must be taken into account for registers where values depend on the switch core clock frequency. The following register requires special attention: - ANA AC POL::POL UPD INT CFG.POL UPD INT - AFI:TTI TICKS:TTI TICK BASE.BASE LEN - ANA AC POL::POL UPD INT CFG.POL UPD INT - VOP::LOC CTRL.LOC BASE TICK CNT - VOP::LOC PERIOD CFG.LOC PERIOD VAL - VOP::HMO PERIOD CFG.HMO PERIOD VAL When the on-chip temperature sensor is enabled in low power mode, the time between temperature sample refreshes (through HSIO::TEMP\_SENSOR\_STAT) is increased from 500 µs to 1.5 ms. The 1588 timing is less precise in low-power mode because the resolution of the timestamps changes together with the core clock frequency. During low power mode, SGMII/SERDES front ports operating in half-duplex mode cannot sustain the minimum interframe gap of 12 bytes. The expected interframe gap is in the range of 14 to 15 bytes. ## 3.36 Clocking and Reset There are two PLLs on the device: PLL and PLL2. The SERDES1G and SERDES6G reference clocks are driven by PLL. The switch-core clock and the VCore System clocks are driven by either PLL or PLL2. PLL2 is disabled by default, but it can be enabled in two ways. It can be strapped to enabled by pulling strapping input REFCLK2\_SEL high during device reset or it can be enabled after booting by writing HSIO::CLK\_CFG.PLL2\_ENA. When PLL2 is enabled during reset, by strapping REFCLK2\_SEL high, then PLL2 drives the switch-core and VCore System clocks. Otherwise, these clocks are driven by PLL. It is possible to re-configure the source of the switch core clock (including the IEEE 1588 one-second timers) by using HSIO::CLK\_CFG.SWC\_CLK\_SRC. The VCore System clock source is not reconfigurable. By using PLL2, the IEEE 1588 clock can be made independent of a clock recovered by Synchronous Ethernet clock. The reference clocks for PLL and PLL2 (REFCLK\_P/N and REFCLK2\_P/N) are either differential or single-ended. The frequency can be 25 MHz (REFCLK\_P/N only), 125 MHz, 156.25 MHz, or 250 MHz. PLL and PLL2 must be configured for the appropriate clock frequency by using strapping inputs REFCLK CONF[2:0] and m REFCLK2 CONF[2:0]. PLL and PLL2 can be used as a recovered clock sources for Synchronous Ethernet. For information about how to configure PLL and PLL2 clock recovery, see Layer 1 Timing, page 273. For information about protecting the VCore CPU system during a soft-reset, see Clocking and Reset, page 306. # 3.36.1 Pin Strapping Configure PLL2 reference clocks and VCore startup mode using the strapping pins on the GPIO interface. The device latches strapping pins and keeps their value when nRESET to the device is released. After reset is released, the strapping pins are used for other functions. For more information about which GPIO pins are used for strapping, see GPIO Overlaid Functions, page 355. By using resistors to pull the GPIOs either low or high, software can use these GPIO pins for other functions after reset has been released. Undefined configurations are reserved and cannot be used. VCore-III configurations that enable a front port or the PCle endpoint drive VCore\_CFG[3:2] high when the front port or PCle endpoint is ready to use ### Table 217 • Strapping | Pin | Description | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | REFCLK2_SEL | Strap high to enable PLL2. 0: PLL is source of switch core and VCore clocks. PLL2 is powered down, but can be enabled through registers. 1: PLL2 is source of switch core and VCore clocks. | | REFCLK_CONF[2:0] | Reference clock frequency for PLL. | | REFCLK2_CONF[2:0] | Configuration of reference clock frequency for PLL2, this is don't care if PLL2 is not enabled. 000: 125 MHz 001: 156.25 MHz 010: 250 MHz 100: 25 MHz 001: 250 MHz 100: 25 | | VCORE_CFG[3:0] | Configuration of VCore system startup conditions. 0000: VCore-III CPU is enabled (Little Endian mode) and boots from SI (the SI slave is disabled). 0001: PCle 1.x endpoint is enabled. Port 10 is enabled for SFI 10G, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC. VRAP block is accessible through the NPI port. Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 0010: PCle 1.x endpoint is enabled. Port 6 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC, and NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC. VRAP block is accessible through the NPI port. Au-tomatic boot of VCore-III CPU is disabled, and SI slave is enabled. 0100: PCle 1.x endpoint is enabled. Port 10 is enabled for SFI 10G, and NPI port 9 is enabled for SFI 10G. VRAP block is accessible through the NPI port. Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 1010: PCle 1.x endpoint is enabled. NPI port 9 is enabled for SFI 10G. VRAP block is accessible through the NPI port. Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 1000: PCle 1.x endpoint is enabled. NPI port 4 is enabled for SERDES NoAneg 1G FDX NoFC. VRAP block is accessible through the NPI port. Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 1001: PCle 1.x endpoint is enabled. Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 1001: PCle 1.x endpoint is enabled with MIIM address 0 (MIIM slave pins are overlaid on GPIOs). Automatic boot of VCore-III CPU is disabled, and SI slave is enabled. 1010: WIIM slave is enabled with MIIM address 31 (MIIM slave pins are overlaid on GPIOs). Automati | # 4 VCore-III System and CPU Interfaces This section provides information about the functional aspects of blocks and interfaces related to the VCore-III on-chip microprocessor system and an external CPU system. The device contains a powerful VCore-III CPU system that is based on an embedded MIPS24KEc-compatible microprocessor and a high bandwidth Ethernet Frame DMA engine. The VCore-III system can control the device independently, or it can support an external CPU, relieving the external CPU of the otherwise time consuming tasks of transferring frames, maintaining the switch core, and handling networking protocols. When the VCore-III CPU is enabled, it either automatically boots up from serial Flash or a external CPU can manually load a code-image to the device and then start the VCore-III CPU. An external CPU can be connected to the device through the PCIe interface, serial interface (SI), dedicated MIIM slave interface, or through Versatile Register Access Protocol (VRAP) formatted Ethernet frames using the NPI Ethernet port. Through these interfaces, the external CPU has access to the complete set of device registers and can control them without help from the VCore-III CPU if needed. The following illustration shows the VCore-III block diagram. Figure 102 • VCore-III System Block Diagram <sup>1.</sup> When the Vcore-III CPU boots up from the SI Flash, the SI is reserved as boot interface and cannot be used by an external CPU. <sup>2.</sup> Inbound PCIe access to BARO maps to VCore register space (switch core access block, interrupt controller, timers, two-wire serial master/slave, UARTs, and manual frame injection/extraction). Inbound PCIe access to BAR2 maps to the DDR3/3L memory space (DDR controller). ## 4.1 VCore-III Configurations The behavior of the VCore-III system after a reset is determined by four VCore strapping pins that are overlaid on GPIO pins. The value of these GPIOs is sampled shortly after releasing reset to the device. For more information about the strapping pins, see Pin Strapping, page 306. The strapping value determines the reset value for the ICPU\_CFG::GENERAL\_CTRL register. After startup, the behavior of the VCore-III system can be modified by changing some of the fields in this register. The following are common scenarios. - After starting the device with the VCore-III CPU disabled, an external CPU can manually boot the VCore-III CPU from SI Flash by writing ICPU\_CFG::GENERAL\_CTRL.IF\_SI\_OWNER = 1, ICPU\_CFG::GENERAL\_CTRL.BOOT\_MODE\_ENA = 1, and ICPU\_CFG::GENERAL\_CTRL.CPU\_DIS = 0. Endianess is configured by ICPU\_CFG::GENERAL\_CTRL.CPU\_BE\_ENA. Setting GENERAL\_CTRL.IF\_SI\_OWNER disables the SI slave, so the external CPU must use another interface than SI. - After starting the device with the VCore-III CPU disabled and loading software into DDR3/DDR3L memory, an external CPU can boot the VCore-III CPU from DDR3/DDR3L memory by writing ICPU\_CFG::GENERAL\_CTRL.BOOT\_MODE\_ENA = 0 and ICPU\_CFG::GENERAL\_CTRL.CPU\_DIS = 0. Endianess is configured using ICPU\_CFG::GENERAL\_CTRL.CPU\_BE\_ENA. - After automatically booting from SI Flash, the VCore-III CPU can release the SI interface and enable the SI slave by writing ICPU\_CFG::GENERAL\_CTRL.IF\_SI\_OWNER = 0. This enables SI access from an external CPU to the device. A special PCB design is required to make the serial interface work for both Flash and external CPU access. - MIIM slave can be manually enabled by writing ICPU\_CFG::GENERAL\_CTRL.IF\_MIIM\_SLV\_ENA = 1. The MIIM slave automatically takes control of the appropriate GPIO pins. The EJTAG interface of the VCore-III CPU and the Boundary Scan JTAG controller are both multiplexed onto the JTAG interface of the device. When the JTAG\_ICE\_nEN pin is low, the MIPS's EJTAG controller is selected. When the JTAG\_ICE\_nEN pin is high, the Boundary Scan JTAG controller is selected. ## 4.2 Clocking and Reset The following table lists the registers associated with reset and the watchdog timer. Table 218 • Clocking and Reset Configuration Registers | Register | Description | |----------------------|-------------------------------------------------------------------------------------------------| | ICPU_CFG::RESET | VCore-III reset protection scheme and initiating soft reset of the VCore-III system and/or CPU. | | DEVCPU_GCB::SOFT_RST | Initiating chip-level soft reset. | | ICPU_CFG::WDT | Watchdog timer configuration and status. | The VCore-III CPU runs 500 MHz, the DDR3/DDR3L controller runs 312.50 MHz, and the rest of the VCore-III system runs at 250 MHz. The VCore-III can be soft reset by setting RESET.CORE\_RST\_FORCE. By default, this resets both the VCore-III CPU and the VCore-III system. The VCore-III system can be excluded from a soft reset by setting RESET.CORE\_RST\_CPU\_ONLY; soft reset using CORE\_RST\_FORCE only then resets the VCore-III CPU. The frame DMA must be disabled prior to a soft reset of the VCore-III system. When CORE\_RST\_CPU\_ONLY is set, the frame DMA, PCIe endpoint, and DDR3/DDR3L controller are not affected by a soft reset and continue to operate throughout soft reset of the VCore-III CPU. The VCore-III system comprises all the blocks attached to the VCore Shared Bus (SBA), including the PCIe, DDR3/DDR3L, and frame DMA/injection/extraction blocks. Blocks attached to the switch core Register Bus (CSR), including VRAP, SI, and MIIM slaves, are not part of the VCore-III system reset domain. For more information about the VCore-III system blocks, see Figure 102, page 308. The device can be soft reset by writing SOFT\_RST.SOFT\_CHIP\_RST. The VCore-III system and CPU can be protected from a device soft reset by writing RESET.CORE\_RST\_PROTECT = 1 before initiating a soft reset. In this case, a chip-level soft reset is applied to all other blocks, except the VCore-III system and the CPU. When protecting the VCore-III system and CPU from a soft reset, the frame DMA must be disabled prior to a chip-level soft reset. The SERDES and PLL blocks can be protected from reset by writing to SOFT\_RST.SOFT\_SWC\_RST instead of SOFT\_CHIP\_RST. The VCore-III general purpose registers (ICPU\_CFG::GPR) and GPIO alternate modes (DEVCPU\_GCB::GPIO\_ALT) are not affected by a soft reset. These registers are only reset when an external reset is asserted. ## 4.2.1 Watchdog Timer The VCore system has a built-in watchdog timer (WDT) with a two-second timeout cycle. The watchdog timer is enabled, disabled, or reset through the WDT register. The watchdog timer is disabled by default. After the watchdog timer is enabled, it must be regularly reset by software. Otherwise, it times out and cause a VCore soft reset equivalent to setting RESET.CORE\_RST\_FORCE. Improper use of the WDT.WDT\_LOCK causes an immediate timeout-reset as if the watchdog timer had timed out. The WDT.WDT\_STATUS field shows if the last VCore-III CPU reset was caused by WDT timeout or regular reset (possibly soft reset). The WDT.WDT\_STATUS field is updated only during VCore-III CPU reset. To enable or to reset the watchdog timer, write the locking sequence, as described in WDT.WDT\_LOCK, at the same time as setting the WDT.WDT\_ENABLE field. Because watchdog timeout is equivalent to setting RESET.CORE\_RST\_FORCE, the RESET.CORE\_RST\_CPU\_ONLY field also applies to watchdog initiated soft reset. ### 4.3 Shared Bus The shared bus is a 32-bit address and 32-bit data bus with dedicated master and slave interfaces that interconnect all the blocks in the VCore-III system. The VCore-III CPU, PCIe inbound, and VCore SBA access block are masters on the shared bus; only they can start access on the bus. The shared bus uses byte addresses, and transfers of 8, 16, or 32 bits can be made. To increase performance, bursting of multiple 32-bit words on the shared bus can be performed. All slaves are mapped into the VCore-III system's 32-bit address space and can be accessed directly by masters on the shared bus. Two possible mappings of VCore-III shared bus slaves are boot mode and normal mode. - Boot mode is active after power-up and reset of the VCore-III system. In this mode, the SI Flash boot master is mirrored into the lowest address region. - In normal mode, the DDR3/DDR3L controller is mirrored into the lowest address region. Changing between boot mode and normal mode is done by first writing and then reading ICPU CFG::GENERAL CTRL.BOOT MODE ENA. A change takes effect during the read. The device supports up to 1 gigabyte (GB) of DDR3/DDR3L memory. By default, only 512 megabytes (MB) is accessible in the memory map. To accommodate more than 512 MB of memory, write ICPU CFG::MEMCTRL CFG.DDR 512MBYTE PLUS = 1. Figure 103 • Shared Bus Memory Map | 0x00000000 — | Boot Mode (Physical), 512 MB | 0x00000000 - | Normal Mode (Physical), 512 MB | |--------------|------------------------------|---------------|--------------------------------| | 0x10000000 — | 256 MB Mirror of SI Flash | - 000000000 - | 512 MB<br>Mirror of DDR3/DDR3L | | 0x20000000 — | 256 MB Reserved | 0x20000000 - | WIITOI OI DDR3/DDR3L | | | 512 MB<br>DDR3/DDR3L | | 512 MB DDR3/DDR3L | | 0x40000000 — | 256 MB SI Flash | 0x40000000 - | 256 MB SI Flash | | 0x50000000 — | 512 MB Reserved | 0x50000000 - | 512 MB Reserved | | 0x70000000 — | 256 MB Chip Registers | 0x70000000 - | 256 MB Chip Registers | | 0x80000000 — | 1 GB | 0x80000000 - | 1 GB | | | Reserved | | Reserved | | 0xC0000000 — | 1 GB | 0xC0000000 - | 1 GB | | | PCIe DMA | | PCIe DMA | | 0xFFFFFFF — | | 0xFFFFFFF - | | | | | | | | 0,00000000 | Boot Mode (Physical), 1 GB <sup>(1)</sup> | 0x00000000 — | Normal Mode (Physical), 1 GB <sup>(1)</sup> | |------------------------------|-------------------------------------------|---------------|---------------------------------------------| | 0x00000000 - | 256 MB Mirror of SI Flash | 0x00000000 = | 1 GB | | 0x10000000 - | 768 MB<br>Reserved | | Mirror of DDR3/DDR3L | | 0x40000000 - | 256 MB SI Flash | 0x40000000 - | 256 MB SI Flash | | 0x50000000 - | 512 MB Reserved | 0x50000000 — | 512 MB Reserved | | 0x70000000 - | 256 MB Chip Registers | 0x70000000 — | 256 MB Chip Registers | | 0x80000000 -<br>0xC0000000 - | 1 GB DDR3/DDR3L | 0x80000000 — | 1 GB DDR3/DDR3L | | 0x0000000 - | 1 GB PCIe DMA | - 0x0000000 — | 1 GB PCIe DMA | | OxFFFFFFF - | | 0xFFFFFFF — | | <sup>1.</sup> To enable support 1 gigabyte (GB) of DDR3/DDR3L memory (and the associated memory map), set ICPU\_CFG::MEMCTRL\_CFG.DDR\_512MBYTE\_PLUS. **Note:** When the VCore-III system is protected from a soft reset using ICPU\_CFG::RESET.CORE\_RST\_CPU\_ONLY, a soft reset does not change shared bus memory mapping. For more information about protecting the VCore-III system when using a soft reset, see Clocking and Reset, page 309. If the boot process copies the SI Flash image to DDR3/DDR3L, and if the contents of the SI memory and the DDR3 memory are the same, software can execute from the mirrored region when swapping from boot mode to normal mode. Otherwise, software must be execute from the fixed SI Flash region when changing from boot mode to normal mode. The Frame DMA has dedicated access to PCIe outbound and to the DDR3/DDR3L. This means that access on the SBA to other parts of the device, such as register access, does not affect Frame DMA injection/extraction performance. ### 4.3.1 VCore-III Shared Bus Arbitration The following table lists the registers associated with the shared bus arbitration. Table 219 • Shared Bus Configuration Registers | Register | Description | |--------------|-----------------------------------------| | SBA::PL_CPU | Master priorities | | SBA::PL_PCIE | Master priorities | | SBA::PL_CSR | Master priorities | | SBA::WT_EN | Enable of weighted token scheme | | SBA::WT_TCL | Weighted token refresh period | | SBA::WT_CPU | Token weights for weighted token scheme | | SBA::WT_PCIE | Token weights for weighted token scheme | | SBA::WT_CSR | Token weights for weighted token scheme | The VCore-III shared bus arbitrates between masters that want to access the bus. The default is to use a strict prioritized arbitration scheme where the VCore-III CPU has highest priority. The strict priorities can be changed using registers PL\_CPU, PL\_PCIE, and PL\_CSR. - \* CPU registers apply to VCore-III CPU access - \* PCIE registers apply to inbound PCIe access - \* CSR registers apply to VCore-III SBA access block access It is possible to enable weighted token arbitration scheme (WT\_EN). When using this scheme, specific masters can be guaranteed a certain amount of bandwidth on the shared bus. Guaranteed bandwidth that is not used is given to other masters requesting the shared bus. When weighted token arbitration is enabled, the masters on the shared bus are grated a configurable number of tokens (WT\_CPU, WT\_PCIE, and WT\_CSR) at the start of each refresh period. The length of each refresh period is configurable (WT\_TCL). For each clock cycle that the master uses the shared bus, the token counter for that master is decremented. When all tokens are spent, the master is forced to a low priority. Masters with tokens always take priority over masters with no tokens. The strict prioritized scheme is used to arbitrate between masters with tokens and between masters without tokens. **Example** Guarantee That PCle Can Get 25% Bandwidth. Configure WT\_TCL to a refresh period of 2048 clock cycles; the optimal length of the refresh period depends on the scenario, experiment to find the right setting. Guarantee PCle access in 25% of the refresh period by setting WT\_PClE to 512 (2048 × 25%). Set WT\_CPU and WT\_CSR to 0. This gives the VCore-III CPU and CSR unlimited tokens. Configure PCle to highest priority by setting PL\_PCle to 15. Finally, enable the weighted token scheme by setting WT\_EN to 1. For each refresh period of 2048 clock cycles, PCle is guaranteed access to the shared bus for 512 clock cycles, because it is the highest priority master. When all the tokens are spend, it is put into the low-priority category. ## 4.3.2 Chip Register Region Registers in the VCore-III domain and inside the switch core are memory mapped into the chip registers region of the shared bus memory map. All registers are 32-bit wide and must only be accessed using 32-bit reads and writes. Bursts are supported. Writes to this region are buffered (there is a one-word write buffer). Multiple back-to-back write access pauses the shared bus until the write buffer is freed up (until the previous writes are done). Reads from this region pause the shared bus until read data is available. Figure 104 • Chip Registers Memory Map The registers in the 0x70000000 through 0x70FFFFFF region are physically located inside the VCore-III system, so read and write access to these registers is fast (done in a few clock cycles). All registers in this region are considered fast registers. Registers in the 0x71000000 through 0x71FFFFFF region are located inside the switch core; access to registers in this range takes approximately 1 $\mu$ s. The DEVCPU\_ORG and DEVCPU\_QS targets are special; registers inside these two targets are faster; access to these two targets takes approximately 0.1 $\mu$ s. When more than one CPU is accessing registers, the access time may be increased. For more information, see Register Access and Multimaster Systems. Writes to the Chip Registers region is buffered (there is a one-word write buffer). Multiple back-to-back write access pauses the shared bus until the write buffer is freed up (until the previous write is done). A read access pause the shared bus until read data is available. Executing a write immediately followed by a read requires the write to be done before the read can be started. ## 4.3.3 SI Flash Region Read access from the SI Flash region initiates Flash formatted read access on the SI pins of the device by means of the SI boot controller. The SI Flash region cannot be written to. Writing to the SI interface must be implemented by using the SI master controller. For more information, see SI Master Controller, page 338. For legacy reasons, it is also possible to write to the SI interface by using the SI boot master's software "bit-banging" register interface. For more information, see SI Boot Controller, page 336. ## 4.3.4 DDR3/DDR3L Region Read and write access from or to the DDR3/DDR3L region maps to access on the DDR3 interface of the device using the DDR3 controller. For more information about the DDR3/DDR3L controller and initializing DDR3/DDR3L memory, see DDR3/DDR3L Memory Controller. ## 4.3.5 PCIe Region Read and write access from or to the PCle region maps to outbound read and write access on the PCle interface of the device by means of the PCle endpoint controller. For more information about the PCle endpoint controller and how to reach addresses in 32-bit and 64-bit PCle environments, see PCle Endpoint Controller. ### 4.4 VCore-III CPU The VCore-III CPU system is based on a powerful MIPS24KEc-compatible microprocessor with 16-entry MMU, 32 kilobytes (kB) instruction, and 32 kB data caches. This section describes how the VCore-III CPU is integrated into the VCore-III system. For more information about internal VCore-III CPU functions, such as bringing up caches, MMU, and so on, see the software board support package (BSP) at www.microsemi.com. When the automatic boot in the little-endian or big-endian mode is enabled using the VCore-III strapping pins, the VCore-III CPU automatically starts to execute code from the SI Flash at byte address 0. The following is a typical automatic boot sequence. - 1. Speed up the boot interface. For more information, see SI boot controller. - 2. Initialize the DDR3/DDR3L controller. For more information, see DDR3/DDR3L Memory Controller - 3. Copy code-image from Flash to DDR3/DDR3L memory. - 4. Change memory map from boot mode to normal mode, see Shared Bus. When automatic boot is disabled, an external CPU is still able to start the VCore-III CPU through registers. For more information, see VCore Configurations. The boot vector of the VCore-III CPU is mapped to the start of the KESEG1, which translates to physical address 0x00000000 on the VCore-III shared bus. The VCore-III CPU interrupts are mapped to interrupt inputs 0 and 1, respectively. ## 4.4.1 Little Endian and Big Endian Support The VCore-III system is constructed as a little endian system, and registers descriptions reflect little endian encoding. When big endian mode is enabled, instructions and data are byte-lane swapped just before they enter and when they leave the VCore-III CPU. This is the standard way of translating between a CPU in big endian mode and a little endian system. In big endian mode, care must be taken when accessing parts of the memory system that is also used by users other than the VCore-III CPU. For example, device registers are written and read by the VCore-III CPU, but they are also used by the device (which sees them in little endian mode). The VCore-III BSP contains examples of code that correctly handles register access for both little and big endian mode. Endianess of the CPU is selected by VCore-III strapping pins or by register configuration when manually booting the CPU. For more information, see VCore-III configurations. ## 4.4.2 Software Debug and Development The VCore CPU has a standard MIPS EJTAG debug interface that can be used for breakpoints, loading of code, and examining memory. When the JTAG\_ICE\_nEN strapping pin is pulled low, the JTAG interface is attached to the EJTAG controller. ## 4.5 External CPU Support An external CPU attaches to the device through the PCIe, SI, MIIM, or VRAP. Through these interfaces, an external CPU can access (and control) the device. For more information about interfaces and connections to device registers, see VCore-III system block diagram. Inbound PCIe access is performed on the VCore Shared Bus (SBA) in the same way as ordinary VCore-III CPU access. By means of the switch core Access block it is possible to access the Switch Core Register (CSR) bus. For more information about supported PCIe BAR regions, see PCIe Endpoint Controller. The SI, MIIM, and VRAP interfaces attach directly to the CSR. Through the VCore SBA access block, it is possible to access the VCore shared bus. For more information, see Access to the VCore Shared Bus. The external CPU can coexist with the internal VCore-III CPU, and hardware-semaphores and interrupts are implemented for inter-CPU communication. For more information, see Mailbox and Semaphores. ## 4.5.1 Register Access and Multimaster Systems There are three different groups of registers in the device: - Switch Core - Fast Switch Core - VCore The Switch Core registers and Fast Switch Core registers are separated into individual register targets and attached to the Switch Core Register bus (CSR). The Fast Switch Core registers are placed in the DEVCPU\_QS and DEVCPU\_ORG register targets. Access to Fast Switch Core registers is less than 0.1 µs; other Switch Core registers take no more than 1 µs to access. The VCore registers are attached directly to the VCore shared bus. The access time to VCore registers is negligible (a few clock cycles). Although multiple masters can access VCore registers and Switch Core registers in parallel without noticeable penalty to the access time, the following exceptions apply. - When accessing the same Switch Core register target (for example, DEVCPU\_GCB), the second master to attempt access has to wait for the first master to finish (round robin arbitration applies.) This does not apply to Fast Switch Core register targets (DEVCPU\_QS and DEVCPU\_ORG). - If both the VCore-III CPU and the PCIe master are performing Switch Core Register bus (CSR) access, both need to be routed through the Switch Core Access block. The second master has to wait for the first master to finish (shared bus arbitration applies). - If two or more SI, MIIM, or VRAP masters are performing VCore register access, they all need to go through the VCore SBA Access block. Ownership has to be resolved by use of software (for example, by using the build-in semaphores). The most common multimaster scenario is with an active VCore-III CPU and an external CPU using either SI or VRAP. In this case, Switch Core register access to targets that are used by both CPUs may see two times the access time (no more than $2 \mu s$ ). #### 4.5.2 Serial Interface in Slave Mode This section provides information about the function of the serial interface in slave mode. The following table lists the registers associated with SI slave mode. Figure 105 • SI Slave Mode Register | Register | Description | |------------------------|------------------------------------------| | DEVCPU_ORG::IF_CTRL | Configuration of endianess and bit order | | DEVCPU_ORG::IF_CFGSTAT | Configuration of padding | | ICPU_CFG::GENERAL_CTRL | SI interface ownership | The serial interface implements a SPI-compatible protocol that allows an external CPU to perform read and write access to register targets within the device. Endianess and bit order is configurable, and several options for high frequencies are supported. The serial interface is available to an external CPU when the VCore-III CPU does not use the SI for Flash or external SI access. For more information, VCore-III System and CPU interfaces. The following table lists the serial interface pins when the SI slave is configured as owner of SI interface in GENERAL\_CTRL.IF\_SI\_OWNER. Table 220 . SI Slave Mode Pins | Pin Name | I/O | Description | |----------|-----|------------------------| | SI_nCS0 | I | Active-low chip select | | SI_CLK | I | Clock input | | SI_DI | I | Data input (MOSI) | | SI_DO | 0 | Data output (MISO) | SI\_DI is sampled on rising edge of SI\_CLK. SI\_DO is driven on falling edge of SI\_CLK. There are no requirements on the logical values of the SI\_CLK and SI\_DI inputs when SI\_nCS is deasserted; they can be either 0 or 1. SI\_DO is only driven during read access when read data is shifted out of the device. The external CPU initiates access by asserting chip select and then transmitting one bit read/write indication, one don't care bit, 22 address bits, and 32 bits of write data (or don't care bits when reading). With the register address of a specific register (REG\_ADDR), the SI address (SI\_ADDR) is calculated as: $SI\_ADDR = (REG\_ADDR \& 0x00FFFFFF)>>2$ Data word endianess is configured through IF\_CTRL[0]. The order of the data bits is configured using IF\_CTRL[1]. The following illustration shows various configurations for write access. The order of the data bits during writing, as depicted, is also used when the device is transmitting data during read operations. Figure 106 • Write Sequence for SI When using the serial interface to read registers, the device needs to prepare read data after receiving the last address bit. The access time of the register that is read must be satisfied before shifting out the first bit of read data. For information about access time, see Register Access and Multimaster Systems. The external CPU must apply one of the following solutions to satisfy read access time. Use SI\_CLK with a period of minimum twice the access time for the register target. For example, for normal switch core targets (single master): 1/(2 × 1 µs) = 500 kHz (maximum) - Pause the SI\_CLK between shifting of serial address bit 0 and the first data bit with enough time to satisfy the access time for the register target. - Configure the device to send out padding bytes before transmitting the read data to satisfy the access time for the register target. For example, 1 dummy byte allows enough read time for the SI clock to run up to 6 MHz in a single master system. See the following calculation. The device is configured for inserting padding bytes by writing to IF\_CFGSTAT.IF\_CFG. These bytes are transmitted before the read data. The maximum frequency of the SI clock is calculated as: ``` (IF\_CFGSTAT.IF\_CFG \times 8 - 1.5)/access-time ``` For example, for normal switch core targets (single master), 1-byte padding give( $1 \times 8 - 1.5$ ) /1 $\mu$ s = 6 MHz (maximum). The SI\_DO output is kept tri-stated until the actual read data is transmitted. The following illustrations show options for serial read access. The illustrations show only one mapping of read data, little endian with most significant bit first. Any of the mappings can be configured and applied to read data in the same way as for write data. #### Figure 107 • Read Sequence for SI\_CLK Slow #### Figure 108 • Read Sequence for SI\_CLK Pause #### Figure 109 • Read Sequence for One-Byte Padding When dummy bytes are enabled (IF\_CFGSTAT.IF\_CFG), the SI slave logic enables an error check that sends out 0x88888888 and sets IF\_CFGSTAT.IF\_STAT if the SI master does not provide enough time for register read. When using SI, the external CPU must configure the IF\_CTRL register after power-up, reset, or chip-level soft reset. The IF\_CTRL register is constructed so that it can be written no matter the state of the interface. For more information about constructing write data for this register, see the instructions in IF\_CTRL.IF\_CTRL. #### 4.5.3 MIIM Interface in Slave Mode This section provides the functional aspects of the MIIM slave interface. The MIIM slave interface allows an external CPU to perform read and write access to the device register targets. Register access is done indirectly, because the address and data fields of the MIIM protocol is less than those used by the register targets. Transfers on the MIIM interface are using the Management Frame Format protocol specified in IEEE 802.3, Clause 22. The MIIM slave pins on the device are overlaid functions on the GPIO interface. MIIM slave mode is enabled by configuring the appropriate VCore\_CFG strapping pins. For more information, see VCore-III Configurations, page 309. When MIIM slave mode is enabled, the appropriate GPIO pins are automatically overtaken. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. The following table lists the pins of the MIIM slave interface. Table 221 • MIIM Slave Pins | Pin Name | I/O | Description | |--------------------|-----|------------------------------| | MIIM_SLV_MDC/GPIO | I | MIIM slave clock input | | MIIM_SLV_MDIO/GPIO | I/O | MIIM slave data input/output | MIIM\_SLV\_MDIO is sampled or changed on the rising edge of MIIM\_SLV\_MDC by the MIIM slave interface. The MIIM slave can be configured to answer on one of two different PHY addresses using ICPU\_CFG::GENERAL\_CTRL.IF\_MIIM\_SLV\_ADDR\_SEL or the VCore\_CFG strapping pins. The MIIM slave has seven 16-bit MIIM registers defined as listed in the following table. Table 222 • MIIM Registers | Register Address | Register Name | Description | |------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ADDR_REG0 | Bits 15:0 of the address to read or write. The address field must be formatted as word address. | | 1 | ADDR_REG1 | Bits 31:16 of the address to read or write. | | 2 | DATA_REG0 | Bits 15:0 of the data to read or write. Returns 0x8888 if a register read error occurred. | | 3 | DATA_REG1 | Bits 31:16 of the data to read or write. The read or write operation is initiated after this register is read or written. Returns 0x8888 if read while busy or a register read error occurred. | | 4 | DATA_REG1_INCR | Bits 31:16 of data to read or write. The read or write operation is initiated after this register is read or written. When the operation is complete, the address register is incremented by one. Returns 0x8888 if read while busy or a register read error occurred. | | 5 | DATA_REG1_INERT | Bits 31:16 of data to read or write. Reading or writing to this register does not cause a register access to be initiated. Returns 0x8888 if a register read error occurred. | | 6 | STAT_REG | The status register gives the status of any ongoing operations. Bit 0: Busy. Set while a register read/write operation is in progress. Bit 1: Busy_rd. Busy status during the last read or write operation. Bit 2: Err. Set if a register access error occurred. Others: Reserved. | A 32-bit switch core register read or write transaction over the MIIM interface is done indirectly due to the limited data width of the MIIM frame. First, the address of the register inside the device must be set in the two 16-bit address registers of the MIIM slave using two MIIM write transactions. The two 16-bit data registers can then be read or written to access the data value of the register inside the device. Thus, it requires up to four MIIM transactions to perform a single read or write operation on a register target. The address of the register to read/write is set in registers ADDR\_REG0 and ADDR\_REG1. The data to write to the register pointed to by the address in ADDR\_REG0 and addr\_reg1 is first written to DATA\_REG0 and then to DATA\_REG1. When the write transaction to DATA\_REG1 is completed, the MIIM slave initiates the switch core register write. With the register address of a specific register (REG\_ADDR), the MIIM address (MIIM\_ADDR) is calculated as: MIIM ADDR = (REG ADDR & 0x00FFFFFF)>>2 The following illustration shows a single MIIM write transaction on the MIIM interface. Figure 110 • MIIM Slave Write Sequence A read transaction is done in a similar way. First, read the DATA\_REG0 and then read the DATA\_REG1. As with a write operation. The switch core register read is not initiated before the DATA\_REG1 register is read. In other words, the returned read value is from the previous read transaction. The following illustration shows a single MIIM read transaction on the MIIM interface. Figure 111 • MIIM Slave Read Sequence ### 4.5.4 Access to the VCore Shared Bus This section provides information about how to access the VCore shared bus (SBA) from an external CPU attached by means of the VRAP, SI, or MIIM. The following table lists the registers associated with the VCore shared bus access. Table 223 • VCore Shared Bus Access Registers | Register | Description | |---------------------------|-------------------------------------------------| | DEVCPU_GCB::VA_CTRL | Status for ongoing access | | DEVCPU_GCB::VA_ADDR | Configuration of shared bus address | | DEVCPU_GCB::VA_DATA | Configuration of shared bus address | | DEVCPU_GCB::VA_DATA_INCR | Data register, access increments VA_ADDR | | DEVCPU_GCB::VA_DATA_INERT | Data register, access does not start new access | An external CPU perform 32-bit reads and writes to the SBA through the VCore Access (VA) registers. In the VCore-III system, a dedicated master on the shared bus handles VA access. For information about arbitration between masters on the shared bus, see VCore Shared Bus Arbitration. The SBA address is configured in VA\_ADDR. Writing to VA\_DATA starts an SBA write with the 32-bit value that was written to VA\_DATA. Reading from VA\_DATA returns the current value of the register and starts an SBA read access, when the read access completes, the result is automatically stored in the VA\_DATA register. The VA\_DATA\_INCR register behaves similar to VA\_DATA, except that after starting an access, the VA\_ADDR register is incremented by four (so that it points to the next word address in the SBA domain). Reading from the VA\_DATA\_INCR register returns the value of VA\_DATA, writing to VA\_DATA\_INCR overwrites the value of VA\_DATA. **Note:** By using VA\_DATA\_INCR, sequential word addresses can be accessed without having to manually increment the VA\_ADDR register between each access. The VA\_DATA\_INERT register provides direct access to the VA\_DATA value without starting access on the SBA. Reading from the VA\_DATA\_INERT register returns the value of VA\_DATA, writing to VA\_DATA\_INERT overwrites the value of VA\_DATA. The VCore-III shared bus is capable of returning error-indication when illegal register regions are accessed. If a VA access results in an error-indication from the SBA, the VA\_CTRL.VA\_ERR field is set, and the VA\_DATA is set to 0x888888888. **Note:** Note SBA error indications only occur when non-existing memory regions or illegal registers are accessed. This will not happen during normal operation, so the VA\_CTRL.VA\_ERR indication is useful during debugging only. **Example** Reading from ICPU\_CFG::GPR[1] through the VA registers. The GPR register is the second register in the SBA VCore-III Registers region. Set VA\_ADDR to 0x70000004, read once from VA\_DATA (and discard the read value). Wait until VA\_CTRL.VA\_BUSY is cleared, then VA\_DATA contains the value of the ICPU\_CFG::GPR[1] register. Using VA\_DATA\_INERT (instead of VA\_DATA) to read the data is appropriate, because this does not start a new SBA access. #### 4.5.4.1 Optimized Reading VCore-III shared bus access is typically much faster than the CPU interface, which is used to access the VA registers. The VA\_DATA register (VA\_DATA\_INCR and VA\_DATA\_INERT) return 0x88888888 while VA\_CTRL.VA\_BUSY is set. This means that it is possible to skip checking for busy between read access to SBA. For example, after initiating a read access from SBA, software can proceed directly to reading from VA\_DATA, VA\_DATA\_INCR, or VA\_DATA\_INERT - If the second read is different from 0x88888888, then the second read returned valid read data (the SBA access was done before the second read was performed). - If the second read is equal to 0x88888888, then the VA logic may have been busy during the read and additional actions are required: First read the VA\_CTRL.VA\_BUSY field until the field is cleared (VA logic is not busy). Then read VA\_DATA\_INERT. If VA\_DATA\_INERT returns 0x88888888, then read-data is actually 0x88888888, continue to the next read. Otherwise, repeat the last read from VA\_DATA, VA\_DATA\_INCR, or VA\_DATA\_INERT and then continue to the next read from there. Optimized reading can be used for single read and sequential read access. For sequential reads, the VA\_ADDR is only incremented on successful (non-busy) reads. ## 4.5.5 Mailbox and Semaphores This section provides information about the semaphores and mailbox features for CPU to CPU communication. The following table lists the registers associated with mailbox and semaphores. | Table 224 • Mailbox and Semaphore Registers | Table 224 • | Mailbox and | Semaphore | Registers | |---------------------------------------------|-------------|-------------|-----------|-----------| |---------------------------------------------|-------------|-------------|-----------|-----------| | Register | Description | |-------------------------|-----------------------------------------------| | DEVCPU_ORG::MAILBOX_SET | Atomic set of bits in the mailbox register. | | DEVCPU_ORG::MAILBOX_CLR | Atomic clear of bits in the mailbox register. | | DEVCPU_ORG::MAILBOX | Current mailbox state. | | DEVCPU_ORG::SEMA_CFG | Configuration of semaphore interrupts. | | DEVCPU_ORG::SEMA0 | Taking of semaphore 0. | Table 224 • Mailbox and Semaphore Registers (continued) | Register | Description | |-------------------------|-------------------------------| | DEVCPU_ORG::SEMA1 | Taking of semaphore 1. | | DEVCPU_ORG::SEMA0_OWNER | Current owner of semaphore 0. | | DEVCPU_ORG::SEMA1_OWNER | Current owner of semaphore 1. | The mailbox is a 32-bit register that can be set and cleared atomically using any CPU interface (including the VCore-III CPU). The MAILBOX register allows reading (and writing) of the current mailbox value. Atomic clear of individual bits in the mailbox register is done by writing a mask to MAILBOX\_CLR. Atomic setting of individual bits in the mailbox register is done by writing a mask to MAILBOX\_SET. The device implements two independent semaphores. The semaphores are part of the Switch Core Register Bus (CSR) block and are accessible by means of the fast switch core registers. Semaphore ownership can be taken by interfaces attached to the CSR. That is, the VCore-III, VRAP, SI, and MIIM can be granted ownership. The VCore-III CPU and PCIe interface share the same semaphore, because they both access the CSR through the switch core access block. Any CPU attached to an interface can attempt to take a semaphore n by reading SEMA0.SEMA0 or SEMA1.SEMA1. If the result is 1, the corresponding semaphore was successfully taken and is now owned by that interface. If the result is 0, the semaphore was not free. After a successfully taking a semaphore, all additional reads from the corresponding register will return 0. To release a semaphore write 1 to SEMA0.SEMA0 or SEMA1.SEMA1. **Note:** Any interface can release semaphores; it does not have to the one that has taken the semaphore. This allows implementation of handshaking protocols. The current status for a semaphore is available in SEMA0\_OWNER.SEMA0\_OWNER and SEMA1\_OWNER.SEMA1\_OWNER. See register description for encoding of owners. Software interrupt is generated when semaphores are free or taken. Interrupt polarity is configured through SEMA\_CFG.SEMA\_INTR\_POL. Semaphore 0 is hooked up to SW0 interrupt and semaphore 1 is hooked up to SW1 interrupt. For configuration of software-interrupt, see Interrupt Controller. In addition to interrupting on semaphore state, software interrupt can be manually triggered by writing directly to the ICPU\_CFG::INTR\_FORCE register. Software interrupts (SW0 and SW1) can be individually mapped to either the VCore-III CPU or to external interrupt outputs (to an external CPU). ## 4.6 PCle Endpoint Controller The device implements a single-lane PCIe 1.x endpoint that can be hooked up to any PCIe capable system. Using the PCIe interface, an external CPU can access (and control) the device. Ethernet frames can be injected and extracted using registers or the device can be configured to DMA Ethernet frames autonomously to/from PCIe memory. The device's DDR3/DDR3L memory is available through the PCIe interface, allowing the external CPU full read and write access to DDR3/DDR3L modules attached to the device. The DDR3/DDR3L controller and memory modules can be initialized either via PCIe or by the VCore-III CPU. Both the VCore-III CPU and Frame DMA can generate PCIe read/write requests to any 32-bit or 64-bit memory region in PCIe memory space. However, it is up to software running on an external CPU to set up or communicate the appropriate PCIe memory mapping information to the device. The defaults for the endpoints capabilities region and the extended capabilities region are listed in the registers list's description of the PCIE registers. The most important parameters are: - Vendor (and subsystem vendor) ID: 0x101B, Microsemi Corporation - Device ID: 0xB004, device family ID - Revision ID: 0x00, device family revision ID - Class Code: 0x028000, Ethernet Network controller - Single function, non-Bridge, INTA and Message Signaled Interrupt (MSI) capable device The device family 0xB004 covers several register-compatible devices. The software driver must determine actual device ID and revision by reading DEVCPU\_GCB::CHIP\_ID from the device's memory mapped registers region. For information about base address registers, see Base Address Registers, Inbound Requests. The IDs, class code, revision ID, and base address register setups can be customized before enabling the PCIe endpoint. However, it requires a manual bring-up procedure by software running locally on the VCore-III CPU. For more information, see Enabling the Endpoint. The endpoint is power management capable and implements PCI Bus Power Management Interface Specification Revision 1.2. For more information, see Power Management. The endpoint is MSI capable. Up to four 64-bit messages are supported. Messages can be generated on rising and falling edges of each of the two external VCore-III interrupt destinations. For more information, see Outbound Interrupts. For information about all PCI Express capabilities and extended capabilities register defaults, see the PCIE region's register descriptions. ## 4.6.1 Accessing Endpoint Registers The root complex accesses the PCIe endpoint's configuration registers by PCIe CfgRd/CfgWr requests. The VCore-III CPU can read configuration registers by means of the PCIE region. For more information, see Chip Register Region. The PCIE region must not be accessed when the PCIe endpoint is disabled. The PCIe region is used during manual bring-up of PCIe endpoint. By using this region, it is possible to write most of the endpoint's read-only configuration registers, such as Vendor ID. The PCIe endpoint's read-only configuration register values must not be changed after the endpoint is enabled. The VCore-III has a few dedicated PCIe registers in the ICPU\_CFG:PCIE register group. An external CPU attached through the PCIe interface has to go through BAR0 to reach these registers. ## 4.6.2 Enabling the Endpoint The PCIe endpoint is disabled by default. It can be enabled automatically or manually by either setting the VCore CFG strapping pins or by software running in the VCore-III CPU. The recommended approach is using VCore\_CFG strapping pins, because it is fast and does not require special software running on the VCore-III CPU. The endpoint is ready approximately 50 ms after release of the device's nRESET. Until this point, the device ignores any attempts to do link training, and the PCIe output remains idle (tri-stated). By using software running on the VCore-III CPU, it is possible to manually start the PCIe endpoint. Note that PCIe standard specifies a maximum delay from nRESET release to working PCIe endpoint so software must enable the endpoint as part of the boot process. The root complex must follow standard PCIe procedures for bringing up the endpoint. ## 4.6.2.1 Manually Starting MAC/PCS and SerDes This section provides information about how to manually start up the PCIe endpoint and customize selected configuration space parameters. The following table lists the registers related to manually bringing up PCIe. Table 225 • Manual PCIe Bring-Up Registers | Register | Description | |---------------------------|------------------------------------------| | ICPU_CFG::PCIE_CFG | Disable of automatic link initialization | | HSIO::SERDES6G_COMMON_CFG | SERDES configuration | | HSIO::SERDES6G_MISC_CFG | SERDES configuration | | HSIO::SERDES6G_IB_CFG | SERDES configuration | Table 225 • Manual PCIe Bring-Up Registers (continued) | Register | Description | |-------------------------------------------------------------------------------------------------|-------------------------------------| | HSIO::SERDES6G_IB_CFG1 | SERDES configuration | | HSIO::SERDES6G_OB_CFG | SERDES configuration | | HSIO::SERDES6G_OB_CFG1 | SERDES configuration | | HSIO::SERDES6G_DES_CFG | SERDES configuration | | HSIO::SERDES6G_PLL_CFG | SERDES configuration | | HSIO::SERDES6G_MISC_CFG | SERDES configuration | | HSIO::MCB_SERDES6G_ADDR_CFG | SERDES configuration | | PCIE::DEVICE_ID_VENDOR_ID, PCIE::CLASS_CODE_REVISION_ID, PCIE::SUBSYSTEM_ID_SUBSYSTEM_VENDOR_ID | Device parameter customization | | PCIE::BAR1, PCIE::BAR2 | Base address register customization | Disable automatic link training for PICe endpoint. - 1. PCIE CFG.LTSSM DIS = 1. Configure and enable PCIe SERDES for 2G5 mode. - 1. SERDES6G\_MISC\_CFG = 0x00000031. - 2. SERDES6G\_OB\_CFG = 0x60000171. - SERDES6G OB CFG1 = 0x000000B0. - 4. SERDES6G DES CFG = 0x000068A6. - 5. SERDES6G IB CFG = 0x3D57AC37. - SERDES6G IB CFG1 = 0x00110FF0. - 7. SERDES6G COMMON CFG = 0x00024009. - 8. MCB SERDES6G ADDR CFG = 0x80000004 and wait until bit 31 is cleared. - 9. SERDES6G PLL CFG = 0x00030F20. - 10. MCB\_SERDES6G\_ADDR\_CFG = 0x80000004 and wait until bit 31 is cleared. - 11. Wait at least 20 ms. - 12. SERDES6G IB CFG = 0x3D57AC3F. - 13. SERDES6G\_MISC\_CFG = 0x00000030. - 14. MCB\_SERDES6G\_ADDR\_CFG = 0x80000004 and wait until bit 31 is cleared. - 15. Wait at least 60 ms. - 16. SERDES6G IB CFG = 0x3D57ACBF. - 17. SERDES6G IB CFG1 = 0x00103FF0. - 18. MCB SERDES6G ADDR CFG = 0x80000004 and wait until bit 31 is cleared. To optionally disable BAR1: - PCIE CFG.PCIE BAR WR ENA = 1 - 2. BAR1 = 0x00000000 - PCIE CFG.PCIE BAR WR ENA = 0 To optionally increase BAR2 from 128 to 256 megabytes: - 1. PCIE CFG.PCIE BAR WR ENA = 1 - 2. BAR2 = 0x0FFFFFF - 3. PCIE CFG.PCIE BAR WR ENA = 0 To optionally change selected PCIe configuration space values: - Write Vendor ID/Device ID using DEVICE\_ID\_VENDOR\_ID. - Write Class Code/Revision ID using CLASS CODE REVISION ID. - Write Subsystem ID/Subsystem Vendor ID using SUBSYSTEM\_ID\_SUBSYSTEM\_VENDOR\_ID. Enable automatic link training for PCIe endpoint 1. PCIE CFG.LTSSM DIS = 0 The last step enables the endpoint for link training, and the root complex will then be able to initialize the PCIe endpoint. After this the PCIE parameters must not be changed anymore. ## 4.6.3 Base Address Registers Inbound Requests The device implements three memory regions. Read and write operations using the PCIe are translated directly to read and write access on the SBA. When manually bringing up the PCIe endpoint, BAR1 can be disabled. For more information, see Manually Starting MAC/PCS and SerDes. Table 226 • Base Address Registers | Register | Description | |-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BAR0, 32-bit, 32 megabytes | Chip registers region. This region maps to the Chip registers region in the SBA address space. See Chip Register Region. This region only supports 32-bit word-aligned reads and writes. Single and burst accesses are supported. | | BAR1, 32-bit, 16 megabytes | SI Flash region. This region maps to the SI Flash region in the SBA address space. See SI Flash Region. This region only supports 32-bit word-aligned reads. Single and burst access is supported. | | BAR2, 32-bit, 128 megabytes | DDR3/DDR3L region. This region maps to the low 128 megabytes of the DDR3/DDR3L region in the SBA address space. See DDR3/DDR3L Region. | This region support all access types. To access the BAR1 region, a Flash must be attached to the SI interface of the device. For information about how to set up I/O timing and to program the Flash through BAR0; the Chip Registers Region, see SI Boot Controller, page 336. To access the BAR2 region, DDR3/DDR3L modules must be present and initialized. For information about initializing the DDR3/DDR3L controller and modules through BAR0; the Chip Registers, see DDR3/DDR3L Memory Controller. During manual bring up of PCIe, the size of the BAR2 region can be changed to match the size of the attached DDR3/DDR3L modules. For more information, see Manually Starting MAC/PCS and SerDes. ## 4.6.4 Outbound Interrupts The device supports both Message Signaled Interrupt (MSI) and Legacy PCI Interrupt Delivery. The root complex configures the desired mode using the MSI enable bit in the PCIe MSI Capability Register Set. For information about the VCore-III interrupt controller, see Interrupt Controller, page 367. The following table lists the device registers associated PCIe outbound interrupts. Table 227 • PCIe Outbound Interrupt Registers | Register | Description | |--------------------------------|---------------------------| | ICPU_CFG::PCIE_INTR_COMMON_CFG | Interrupt mode and enable | | ICPU_CFG::PCIE_INTR_CFG | MSI parameters | In legacy mode, one interrupt is supported; select either EXT\_DST0 or EXT\_DST1 using PCIE\_INTR\_COMMON\_CFG.LEGASY\_MODE\_INTR\_SEL. The PCIe endpoint uses Assert\_INTA and Deassert\_INTA messages when configured for legacy mode. In MSI mode, both EXT\_DST interrupts can be used. EXT\_DST0 is configured though PCIE\_INTR\_CFG[0] and EXT\_DST1 through PCIE\_INTR\_CFG[1]. Enable message generation on rising and/or falling edges in PCIE\_INTR\_CFG[n].INTR\_RISING\_ENA and PCIE\_INTR\_CFG[n].INTR\_FALLING\_ENA. Different vectors can be generated for rising and falling edges, configure these through PCIE\_INTR\_CFG[n].RISING\_VECTOR\_VAL and PCIE\_INTR\_CFG[n].FALLING\_VECTOR\_VAL. Finally, each EXT\_DST interrupt must be given an appropriate traffic class via PCIE\_INTR\_CFG[n].TRAFFIC\_CLASS. After the root complex has configured the PCIe endpoint's MSI Capability Register Set and the external CPU has configured how interrupts from the VCore-III interrupt controller are propagated to PCIe, interrupts must then be enabled by setting PCIE\_INTR\_COMMON\_CFG.PCIE\_INTR\_ENA. ### 4.6.5 Outbound Access After the PCIe endpoint is initialized, outbound read/write access to PCIe memory space is initiated by reading or writing the SBA's PCIe DMA region. The following table lists the device registers associated with PCIe outbound access. Table 228 • Outbound Access Registers | Register | Description | |-------------------------|-----------------------------------------------| | ICPU_CFG::PCIESLV_SBA | Configures SBA outbound requests. | | ICPU_CFG::PCIESLV_FDMA | Configures FDMA outbound requests. | | PCIE::ATU_REGION | Select active region for the ATU_* registers. | | PCIE::ATU_CFG1 | Configures TLP fields. | | PCIE::ATU_CFG2 | Enable address translation. | | PCIE::ATU_TGT_ADDR_LOW | Configures outbound PCIe address. | | PCIE::ATU_TGT_ADDR_HIGH | Configures outbound PCIe address. | The PCIe DMA region is 1 gigabyte. Access in this region is mapped to any 1 gigabyte region in 32-bit or 64-bit PCIe memory space by using address translation. Two address translation regions are supported. The recommended approach is to configure the first region for SBA outbound access and the second region for FDMA outbound access. Address translation works by taking bits [29:0] from the SBA/FDMA address, adding a configurable offset, and then using the resulting address to access into PCIe memory space. Offsets are configurable in steps of 64 kilobytes in the ATU\_TGT\_ADDR\_HIGH and ATU\_TGT\_ADDR\_LOW registers. The software on the VCore-III CPU (or other SBA masters) can dynamically reconfigure the window as needed; however, the FDMA does not have that ability, so it must be disabled while updating the 1 gigabyte window that is set up for it. **Note:** Although the SBA and FDMA both access the PCIe DMA region by addresses 0xC0000000 though 0xFFFFFFF, the PCIe address translation unit can differentiate between these accesses and apply the appropriate translation. ### 4.6.5.1 Outbound SBA Translation Region Configuration Configure PCIESLV\_SBA.SBA\_OFFSET = 0 and select address translation region 0 by writing ATU\_REGION.ATU\_IDX = 0. Set PCIE::ATU\_BASE\_ADDR\_LOW.ATU\_BASE\_ADDR\_LOW = 0x0000 and PCIE::ATU\_LIMIT\_ADDR.ATU\_LIMIT\_ADDR = 0x3FFF. The following table lists the appropriate PCIe headers that must be configured before using the SBA's PCIe DMA region. Remaining header fields are automatically handled. Table 229 • PCIe Access Header Fields | Header Field | Register::Fields | |--------------------------|--------------------| | Attributes | ATU_CFG1.ATU_ATTR | | Poisoned Data | PCIESLV_SBA.SBA_EP | | TLP Digest Field Present | ATU_CFG1.ATU_TD | | Traffic Class | ATU_CFG1.ATU_TC | | Туре | ATU_CFG1.ATU_TYPE | Table 229 • PCle Access Header Fields (continued) | Header Field | Register::Fields | |--------------|-----------------------| | Byte Enables | PCIESLV_SBA.SBA_BE | | Message Code | ATU_CFG2.ATU_MSG_CODE | Configure the low address of the destination window in PCIe memory space as follows: - Set ATU\_TGT\_ADDR\_HIGH.ATU\_TGT\_ADDR\_HIGH to bits [63:32] of the destination window. Set to 0 when a 32-bit address must be generated. - Set ATU\_TGT\_ADDR\_LOW.ATU\_TGT\_ADDR\_LOW to bits [31:16] of the destination window. This field must not be set higher than 0xC000. Enable address translation by writing ATU\_CFG2.ATU\_REGION\_ENA = 1. SBA access in the PCIe DMA region is then mapped to PCIe memory space as defined by ATU\_TGT\_ADDR\_LOW and ATU\_TGT\_ADDR\_HIGH. The header fields and the PCle address fields can be reconfigured on-the-fly as needed; however, set ATU REGION.ATU IDX to 0 to ensure that the SBA region is selected. ### 4.6.5.2 Configuring Outbound FDMA Translation Region Configure PCIESLV\_FDMA.FDMA\_OFFSET = 1, and select address translation region 1 by writing ATU REGION.ATU IDX = 1. Set PCIE::ATU\_BASE\_ADDR\_LOW.ATU\_BASE\_ADDR\_LOW = 0x4000 and PCIE::ATU\_LIMIT\_ADDR.ATU\_LIMIT\_ADDR = 0x7FFF. The FDMA PCIe header must be MRd/MWr type, reorderable, cache-coherent, and without ECRC. Remaining header fields are automatically handled. Table 230 • FDMA PCIe Access Header Fields | Header Field | Register::Fields | Suggested Value | |--------------------------|-------------------|----------------------------------| | Attributes | ATU_CFG1.ATU_ATTR | Set to 2 | | TLP Digest Field Present | ATU_CFG1.ATU_TD | Set to 0 | | Traffic Class | ATU_CFG1.ATU_TC | Use an appropriate traffic class | | Туре | ATU_CFG1.ATU_TYPE | Set to 0 | Configure low address of destination window in PCIe memory space as follows: - Set ATU\_TGT\_ADDR\_HIGH.ATU\_TGT\_ADDR\_HIGH to bits [63:32] of the destination window. Set to 0 when a 32-bit address must be generated. - Set ATU\_TGT\_ADDR\_LOW.ATU\_TGT\_ADDR\_LOW to bits [31:16] of the destination window. This field must not be set higher than 0xC000. Enable address translation by writing ATU\_CFG2.ATU\_REGION\_ENA = 1. The FDMA can be configured to make access in the 0xC0000000 - 0xFFFFFFF address region. These accesses will then be mapped to PCIe memory space as defined by ATU\_TGT\_ADDR\_LOW and ATU\_TGT\_ADDR\_HIGH. The FDMA must be disabled if the address window needs to be updated. ## 4.6.6 Power Management The device's PCIe endpoint supports D0, D1, and D3 device power-management states and associated link power-management states. The switch core does not automatically react to changes in the PCIe endpoint's power management states. It is, however, possible to enable a VCore-III interrupt on device power state changes and then have the VCore-III CPU software make application-specific changes to the device operation depending on the power management state. Table 231 • Power Management Registers | Register | Description | |---------------------------|--------------------------------------------| | ICPU_CFG::PCIE_STAT | Current power management state | | ICPU_CFG::PCIEPCS_CFG | Configuration of WAKE output and beacon | | ICPU_CFG::PCIE_INTR | PCIe interrupt sticky events | | ICPU_CFG::PCIE_INTR_ENA | Enable of PCle interrupts | | ICPU_CFG::PCIE_INTR_IDENT | Currently interrupting PCIe sources | | ICPU_CFG::PCIE_AUX_CFG | Configuration of auxiliary power detection | Because the device does not implement a dedicated auxiliary power for the PCIe endpoint, the endpoint is operated from the VDD core power supply. Before the power management driver initializes the device, software can "force" auxiliary power detection by writing PCIE\_AUX\_CFG = 3, which causes the endpoint to report that it is capable of emitting Power Management Events (PME) messages in the D3c state. The current device power management state is available using PCIE\_STAT.PM\_STATE. A change in this field's value sets the PCIE\_INTR.INTR\_PM\_STATE sticky bit. To enable this interrupt, set PCIE\_INTR\_ENA.INTR\_PM\_STATE\_ENA. The current state of the PCIe endpoint interrupt towards the VCore-III interrupt controller is shown in PCIE\_INTR\_IDENT register (if different from zero, then interrupt is active). The endpoint can emit PMEs if the PME\_En bit is set in the PM Capability Register Set and if the endpoint is in power-down mode. - Outbound request from either SBA or FDMA trigger PME. - A change in status for an enabled outbound interrupt (either legacy or MSI) triggers PME. This feature can be disabled by setting ICPU\_CFG::PCIE\_INTR\_COMMON\_CFG.WAKEUP\_ON\_INTR\_DIS. In the D3 state, the endpoint transmits a beacon. The beacon function can be disabled and instead drive the WAKE output using the overlaid GPIO function. For more information about the overlaid function on the GPIO for this signal, see GPIO Overlaid Functions, page 355. Table 232 • PCle Wake Pin | Pin Name | I/O | Description | |----------------|-----|------------------| | PCIe_WAKE/GPIO | 0 | PCIe WAKE output | Enable WAKE by setting PCIEPCS\_CFG.BEACON\_DIS. The polarity of the WAKE output is configured in PCIEPCS\_CFG.WAKE\_POL. The drive scheme is configured in PCIEPCS\_CFG.WAKE\_OE. ## 4.6.7 Device Reset Using PCIe The built-in PCIe reset mechanism in the PCIe endpoint resets only the PCIe MAC. The device reset is not tied into the MAC reset. To reset the complete the device, use the following procedure. - Save the state of the PCle controller registers using operating system. - 2. Set DEVCPU GCB::SOFT RST.SOFT CHIP RST. - Wait for 100 ms. - 4. Recover state of PCIe controller registers using operating system. Setting SOFT\_CHIP\_RST will cause re-initialization of the device. # 4.7 Frame DMA This section describes the Frame DMA engine (FDMA). When FDMA is enabled, Ethernet frames can be extracted or injected autonomously to or from the device's DDR3/DDR3L memory and/or PCIe memory space. Linked list data structures in memory are used for injecting or extracting Ethernet frames. The FDMA generates interrupts when frame extraction or injection is done and when the linked lists needs updating. Table 233 • FDMA Registers | Register | Description | |--------------------------------------|-------------------------------------------------------------------| | DEVCPU_QS::XTR_GRP_CFG | CPU port ownership, extraction direction. | | DEVCPU_QS::INJ_GRP_CFG | CPU port ownership, injection direction. | | DEVCPU_QS::INJ_CTRL | Injection EOF to SOF spacing. | | ASM::PORT_CFG | Enables IFH and disables FCS recalculation (for injected frames). | | ICPU_CFG::FDMA_CH_CFG | Channel configuration, priorities, and so on. | | ICPU_CFG::FDMA_CH_ACTIVATE | Enables channels. | | ICPU_CFG::FDMA_CH_DISABLE | Disables channels. | | ICPU_CFG::FDMA_CH_STAT | Status for channels. | | ICPU_CFG::FDMA_CH_SAFE | Sets when safe to update channel linked lists. | | ICPU_CFG::FDMA_DCB_LLP | Linked list pointer for channels. | | ICPU_CFG::FDMA_DCB_LLP_PREV | Previous linked list pointer for channels. | | ICPU_CFG::FDMA_CH_CNT | Software counters for channels. | | ICPU_CFG::FDMA_INTR_LLP | NULL pointer event for channels. | | ICPU_CFG::FDMA_INTR_LLP_ENA | Enables interrupt on NULL pointer event. | | ICPU_CFG::FDMA_INTR_FRM | Frame done event for channels. | | ICPU_CFG::FDMA_INTR_FRM_ENA | Enables interrupt on frame done event. | | ICPU_CFG::FDMA_INTR_SIG | SIG counter incremented event for channels. | | ICPU_CFG::FDMA_INTR_SIG_ENA | Enables interrupt on SIG counter event. | | ICPU_CFG::MANUAL_INTR | Manual injection/extraction events. | | ICPU_CFG::MANUAL_INTR_ENA | Enables interrupts on manual injection/extraction events. | | ICPU_CFG::FDMA_EVT_ERR | Error event for channels. | | ICPU_CFG::FDMA_EVT_ERR_CODE | Error event description. | | ICPU_CFG::FDMA_INTR_ENA | Enables interrupt for channels. | | ICPU_CFG::FDMA_INTR_IDENT | Currently interrupting channels. | | DEVCPU_QS::XTR_FRM_PRUNING | Enables pruning of extraction frames. | | ICPU_CFG::FDMA_CH_INJ_TOKEN_CNT | Injection tokens. | | ICPU_CFG::FDMA_CH_INJ_TOKEN_TICK_RLD | Periodic addition of injection tokens. | | ICPU_CFG::MANUAL_CFG | Configures manual injection/extraction. | | ICPU_CFG::MANUAL_XTR | Memory region used for manual extraction. | | ICPU_CFG::MANUAL_INJ | Memory region used for manual injection. | | DEVCPU_QS::INJ_CTRL | Configures injection gap. | | ICPU_CFG::FDMA_GCFG | Configures injection buffer watermark. | The FDMA implements two extraction channels per CPU port and a total of eight injection channels. Extraction channels are hard-coded per CPU port, and injection channels can be individually assigned to any CPU port. - FDMA channel 0 corresponds to port 53 (group 0) extraction direction. - FDMA channel 1 corresponds to port 54 (group 1) extraction direction. - FDMA channel 2 through 9 corresponds to port 53 (group 0) injection direction when FDMA CH CFG[channel].CH INJ GRP is set to 0. - FDMA channel 2 through 9 corresponds to port 54 (group 1) injection direction when FDMA\_CH\_CFG[channel].CH\_INJ\_GRP is set to 1. The FDMA implements a strict priority scheme. Injection and extraction channels can be assigned individual priorities, which are used when the FDMA has to decide between servicing two or more channels. Channel priority is configured in FDMA\_CH\_CFG[ch].CH\_PRIO. When channels have same priority, the higher channel number takes priority over the lower channel number. When more than one injection channel is enabled for injection on the same CPU port, then priority determines which channel that is allowed to inject data. Ownership is re-arbitrated on frame boundaries. The internal frame header is added in front of extracted frames and provides useful switching information about the extracted frames. Injection frames requires an internal frame header for controlling injection parameters. The internal frame header is added in front of frame data. The device recalculates and overwrites the Ethernet FCS for frames that are injected via the CPU when requested by setting in the internal frame header. For more information about the extraction and injection IFH, see Frame Headers, page 17. The FDMA supports a manual mode where the FDMA decision logic is disabled and the FDMA takes and provides data in the order that was requested by an external master (internal or external CPU). The manual mode is a special case of normal FDMA operation where only few of the FDMA features apply. For more information about manual operation, see Manual Mode. The following configuration must be performed before enabling FDMA extraction: Set XTR GRP CFG[group].MODE = 2. The following configurations must be performed before enabling FDMA injection: Set INJ\_GRP\_CFG[group].MODE = 2. Set INJ\_CTRL[group].GAP\_SIZE = 0, set PORT\_CFG[port].INJ\_FORMAT\_CFG = 1, set PORT\_CFG[port].NO\_PREAMBLE\_ENA = 1, and set PORT\_CFG[port].VSTAX2\_AWR\_ENA = 0. ### 4.7.1 DMA Control Block Structures The FDMA processes linked lists of DMA Control Block Structures (DCBs). The DCBs have the same basic structure for both injection or for extraction. A DCB must be placed on a 32-bit word-aligned address in memory. Each DCB must have an associated data block that is placed on a 32-bit word aligned address in memory, the length of the data block must be a complete number of 32-bit words. An Ethernet frame can be contained inside one data block (if the data block is big enough) or the frame can be spread across multiple data blocks. A data block never contains more than one Ethernet frame. Data blocks that contain start-of-frame have set a special bit in the DCB's status word, likewise for data blocks that contains end of frame. The FDMA stores or retrieves Ethernet frame data in network order. This means that the data at byte address (n) of a frame was received just before the data at byte address (n + 1). Frame data inside the DCB's associated data blocks can be placed at any byte offset and have any byte length as long as byte offset and length does not exceed the size of the data block. Byte offset and length is configured using special fields inside the DCB status word. Software can specify offset both when setting up extraction and injection DCBs. Software only specifies length for injection DCBs; the FDMA automatically calculates and updates length for extraction. **Example** If a DCB's status word has block offset 5 and block length 2, then the DCB's data block contains two bytes of frame data placed at second and third bytes inside the second 32-bit word of the DCB's associated data block. DCBs are linked together by the DCB's LLP field. The last DCB in a chain must have LLP = NULL. Chains consisting of a single DCB are allowed. #### Figure 112 • FDMA DCB Layout STAT[16] SOF: Set to 1 if data block contains start of frame. STAT[17] EOF: Set to 1 if data block contains end of frame. STAT[18] ABORT: Abort indication. Extraction: Set to 1 if the frame associated with the data block was aborted. Injection: If set to 1 when FDMA loads the DCB, it aborts the frame associated with the data block. STAT[19] PD: Pruned/Done indication. Extraction: Set to 1 if the frame associated with the data block was pruned. Injection: The FDMA set this to 1 when done processing the DCB. If set to 1 when FDMA loads the DCB, it is treated as ABORT. DATAL[16] SIG: If set to 1 when FDMA loads the DCB, the CH\_CNT\_SIG counter is incremented by one. DATAL[17] TOKEN: Token indication, only used during injection. If set to 1, the FDMA uses one token (CH\_INJ\_TOKEN\_CNT) when injecting the contents of the DCB. If the token counter is 0 when loading the DCB, then injection is postponed until tokens are made available. #### 4.7.2 **Enabling and Disabling FDMA Channels** To enable a channel (ch), write a valid DCB pointer to FDMA DCB LLP[ch] and enable the channel by setting FDMA\_CH\_ACTIVATE.CH\_ACTIVATE[ch]. This makes the FDMA load the DCB from memory and start either injection or extraction. To schedule a channel for disabling, set FDMA CH DISABLE.CH DISABLE[ch]. An active channel does not disable immediately. Instead it waits until the current data block is done, saves the status word, and then disables. Channels can be in one of three states: DISABLED, UPDATING, or ACTIVE. Channels are DISABLED by default. When the channel is reading a DCB or writing the DCB status word, it is considered to be UPDATING. The status of individual channels is available in FDMA CH STAT.CH STAT[ch]. The following illustration shows the FDMA channel states. Figure 113 • FDMA Channel States A channel that has FDMA\_DCB\_LLP[ch].DCB\_LLP==NULL when going from ACTIVE to UPDATING disables itself instead of loading a new DCB. After this it can be re-enabled as previously described. Extraction channels emit an INTR\_LLP-event when loading a DCB with LLP==NULL. Injection channels emit an INTR\_LLP-event when saving status for a DCB that has the LLP==NULL. **Note:** Extraction channel running out of DCBs during extraction is a problem that software must avoid. A hanging extraction channel will potentially be head-of-line blocking other extraction channels. It is possible to update an active channels LLP pointer and pointers in the DCB chains. Before changing pointers software must schedule the channel for disabling (by writing FDMA\_CH\_DISABLE.CH\_DISABLE[ch]) and then wait for the channel to set FDMA\_CH\_SAFE.CH\_SAFE[ch]. When the pointer update is complete, soft must re-activate the channel by setting FDMA\_CH\_ACTIVATE.CH\_ACTIVATE[ch]. Setting activate will cancel the deactivate-request, or if the channel has disabled itself in the meantime, it will re activate the channel. **Note:** The address of the current DCB is available in FDMA\_DCB\_LLP\_PREV[ch]. This information is useful when modifying pointers for an active channel. The FDMA does not reload the current DCB when reactivated, so if the LLP-field of the current DCB is modified, then software must also modify FDMA\_DCB\_LLP[ch]. Setting FDMA\_CH\_CFG[ch].DONEEOF\_STOP\_ENA disables an FDMA channel and emits LLP-event after saving status for DCBs that contains EOF (after extracting or injecting a complete frame). Setting FDMA\_CH\_CFG[ch].DONE\_STOP\_ENA disables an FDMA channel and emits LLP-event after saving status for any DCB. ### 4.7.3 Channel Counters The FDMA implements three counters per channel: SIG, DCB, and FRM. These counters are accessible through FDMA\_CH\_CNT[ch].CH\_CNT\_SIG, FDMA\_CH\_CNT[ch].CH\_CNT\_DCB, and FDMA\_CH\_CNT[ch].CH\_CNT\_FRM, respectively. For more information about how to safely modify these counters, see the register descriptions. The SIG (signal) counter is incremented by one each time the FDMA loads a DCB that has the DATAL.SIG bit set to 1. - The FRM (frame) counter is incremented by one each time the FDMA store status word for DCB that has EOF set. It is a wrapping counter that can be used for software driver debug and development. This counter does not count aborted frames. - The DCB counter is incremented by one every time the FDMA loads a DCB from memory. It is a wrapping counter that can be used for software driver debug and development. It is possible to enable channel interrupt whenever the SIG counter is incremented; this makes it possible for software to receive interrupt when the FDMA reaches certain points in a DCB chain. ## 4.7.4 FDMA Events and Interrupts Each FDMA channel can generate four events: LLP-event, FRM-event, SIG-event, and ERR-event. These events cause a bit to be set in FDMA\_INTR\_LLP.INTR\_LLP[ch], FDMA\_INTR\_FRM.INTR\_FRM[ch], FDMA\_INTR\_SIG.INTR\_SIG[ch], and FDMA\_EVT\_ERR.EVT\_ERR[ch], respectively. - LLP-event occurs when an extraction channel loads a DCB that has LLP = NULL or when an injection channel writes status for a DCB that has LLP=NULL. LLP-events are also emitted from channels that have FDMA\_CH\_CFG[ch].DONEEOF\_STOP\_ENA or FDMA\_CH\_CFG[ch].DONE\_STOP\_ENA set. For more information, see Enabling and Disabling FDMA Channels. - FRM-event is indicated when an active channel loads a new DCB and the previous DCB had EOF. The FRM-event is also indicated for channels that are disabled after writing DCB status with EOF. - SIG-event is indicated whenever the FDMA\_CH\_CNT[ch].CH\_CNT\_SIG counter is incremented. The SIG (signal) counter is incremented when loading a DCB that has the DATAL.SIG bit set. - ERR-event is an error indication that is set for a channel if it encounters an unexpected problem during normal operation. This indication is implemented to ease software driver debugging and development. A channel that encounters an error will be disabled, depending on the type of error the channel state may be too corrupt for it to be restarted without system reset. When an ERR-event occurs, the FDMA\_EVT\_ERR\_CODE.EVT\_ERR\_CODE shows the exact reason for an ERR-event. For more information about the errors that are detected, see FDMA\_EVT\_ERR\_CODE.EVT\_ERR\_CODE. Each of the events (LLP, FRM, SIG) can be enabled for channel interrupt through FDMA\_INTR\_LLP\_ENA.INTR\_LLP\_ENA[ch], FDMA\_INTR\_FRM\_ENA.INTR\_FRM\_ENA[ch], and FDMA\_INTR\_SIG.INTR\_SIG[ch] respectively. The ERR event is always enabled for channel interrupt. The highest numbered extraction channel supports two additional non-sticky events related to manual extraction: XTR\_SOF\_RDY-event and XTR\_ANY\_RDY-event. An active event causes the following fields to be set: MANUAL\_INTR\_INTR\_XTR\_SOF\_RDY and MANUAL\_INTR.INTR\_XTR\_ANY\_RDY respectively. For more information, see Manual Extraction. - XTR\_SOF\_RDY-event is active when the next word to be manually extracted contains an SOF indication. This event is enabled in MANUAL\_INTR\_ENA.INTR\_XTR\_SOF\_RDY\_ENA. - XTR\_ANY\_RDY-event is active when any word is available for manually extraction. This event is enabled in MANUAL INTR ENA.INTR XTR ANY RDY ENA respectively. The highest numbered injection channel supports one additional non-sticky event related to manual injection: INJ\_RDY-event. This event is active when the injection logic has room for (at least) sixteen 32-bit words of injection frame data. When this event is active, MANUAL\_INTR.INTR\_INJ\_RDY is set. The INJ\_RDY-event can be enabled for channel interrupt by setting MANUAL\_INTR\_ENA.INTR\_INJ\_RDY\_ENA. For more information, see Manual Injection. The FDMA\_INTR\_ENA.INTR\_ENA[ch] field enables interrupt from individual channels, FDMA\_INTR\_IDENT.INTR\_IDENT[ch] field shows which channels that are currently interrupting. While INTR\_IDENT is non-zero, the FDMA is indicating interrupting towards to the VCore-III interrupt controller. The following illustration shows the FDMA channel interrupt hierarchy. Figure 114 • FDMA Channel Interrupt Hierarchy ### 4.7.5 FDMA Extraction During extraction, the FDMA extracts Ethernet frame data from the Queuing System and saves it into the data block of the DCB that is currently loaded by the FDMA extraction channel. The FDMA continually processes DCBs until it reaches a DCB with LLP = NULL or until it is disabled. When an extraction channel writes the status word of a DCB, it updates SOF/EOF/ABORT/PRUNED-indications and BLOCKL. BLOCKO remains unchanged (write value is taken from the value that was read when the DCB was loaded). Aborting frames from the queuing system will not occur during normal operation. If the queuing system is reset during extraction of a particular frame, then ABORT and EOF is set. Software must discard frames that have ABORT set. Pruning of frames during extraction is enabled per extraction port through XTR\_FRM\_PRUNING[group].PRUNE\_SIZE. When enabled, Ethernet frames above the configured size are truncated, and PD and EOF is set. ## 4.7.6 FDMA Injection During injection, the FDMA reads Ethernet frame data from the data block of the DCB that is currently loaded by the FDMA injection channel and injects this into the queuing system. The FDMA continually processes DCBs until it reaches a DCB with LLP = NULL or until it is disabled. When an injection channel writes the status word of a DCB, it sets DONE indication. All other status word fields remain unchanged (write value is stored the first time the injection channel loads the DCB). The rate by which the FDMA injects frames can be shaped by using tokens. Each injection channel has an associated token counter (FDMA\_CH\_INJ\_TOKEN\_CNT[ich]). A DCB that has the DATAL.TOKEN field set causes the injection channel to deduct one from the token counter before the data block of the DCB can be injected. If the token counter is at 0, the injection channel postpones injection until the channels token counter is set to a value different from 0. Tokens can be added to the token counter by writing the FDMA\_CH\_INJ\_TOKEN\_CNT[ich] register. Tokens can also be added automatically (with a fixed interval) by using the dedicated token tick counter. Setting FDMA\_CH\_INJ\_TOKEN\_TICK\_RLD[ich] to a value n (different from 0) will cause one token to be added to that injection channel every $n \times 200$ ns. ### 4.7.7 Manual Mode The decision making logic of the FDMA extraction path and/or injection paths can be disabled to give control of the FDMA's extraction and/or injection buffers directly to any master attached to the Shared Bus Architecture. When operating in manual mode DCB structure, counters and most of the interrupts do not apply. Manual extraction and injection use hard-coded channel numbers. - Manual extraction mode uses FDMA channel 1 (port 54 extraction direction). - Manual injection mode uses FDMA channel 9 (port 54 injection direction). To enable manual extraction, set MANUAL\_CFG.XTR\_ENA. The FDMA must not be enabled for FDMA extraction when manual extraction mode is active. To enable manual injection, set MANUAL\_CFG.INJ\_ENA and FDMA\_CH\_CFG[9].CH\_INJ\_CRP = 1. The FDMA must not be enabled for FDMA injection when manual injection mode is active. Extraction and injection paths are independent. For example, FDMA can control extraction at the same time as doing manual injection by means of the CPU. #### 4.7.7.1 Manual Extraction Extraction is done by reading one or more blocks of data from the extraction memory area. A block of data is defined by reading one or more data words followed by reading of the extraction status word. The extraction memory area is 16 kilobytes and is implemented as a replicated register region MANUAL\_XTR. The highest register in the replication (0xFFF) maps to the extraction status word. The status word is updated by the extraction logic and shows the number of frame bytes read, SOF and EOF indications, and PRUNED/ABORT indications. **Note:** During frame extraction, the CPU does not know the frame length. This means that the CPU must check for EOF regularly during frame extraction. When reading a data block from the device, the CPU can burst read from the memory area in such a way that the extraction status word is read as the last word of the burst. Figure 115 • Extraction Status Word Encoding The extraction logic updates the extraction status word while the CPU is reading out data for a block. Prior to starting a new data block, the CPU can write the two least significant bits of the BLOCKO field. The BLOCKO value is stored in the extraction logic and takes effect when the new data block is started. Reading the status field always returns the BLOCKO value that applies to the current data block. Unless written (before stating a data block), the BLOCKO is cleared, so by default all blocks have 0 byte offset. The offset can be written multiple times; the last value takes effect. The CPU can abort frames that it has already started to read out by writing the extraction status field with the ABORT field set. All other status-word fields will be ignored. This causes the extraction logic to discard the active frame and remove it from the queuing system. Reading of block data does not have to be done in one burst. As long as the status word is not read, multiple reads from the extraction region are treated as belonging to the same block. #### 4.7.7.2 Manual Injection Injection is done by writing one or more blocks of data to the injection memory area. A block of data is defined by writing an injection status word followed by writing one or more data words. The injection memory area is 16 kilobytes and is implemented as a replicated register region MANUAL\_INJ. The first register in this replication maps to the injection status word. The status word for each block defines the following: - · Number of bytes to be injected - · Optional byte offset before injection data - · SOF and EOF indications - Optional ABORT indication **Note:** In general, it makes sense to inject frames as a single large block of data (containing both SOF and EOF). However, because offset/length can be specified individually for each block, injecting frames through several blocks is useful when compensating for offset/word misalignment. For example, when building a frame from different memory regions in the CPU main memory. Figure 116 • Injection Status Word Encoding Injection logic updates the PD field of the status word. The status word can be read at any time during injection without affecting current data block transfers. However, a CPU is able to calculate how much data that is required to inject a complete block of data (at least BLOCKO + BLOCKL bytes), so reading the status word is for software development and debug only. Writing status word before finishing a previous data block will cause that frame to be aborted. Frames are also aborted if they do not start with SOF or end with EOF indications. As long as the status word is not written, multiple writes to the injection region are treated as data belonging to the same block. This means multiple bursts of data words can be written between each injection status word update. Software can abort frames by writing to injection status with ABORT field set. All other status word fields are ignored. When a frame is aborted, the already injected data is removed from the queuing system. ## 4.8 VCore-III System Peripherals This section describes the subblocks of the VCore-III system. Although the subblocks are primarily intended to be used by the VCore-III CPU, an external CPU can also access and control them through the shared bus. ### 4.8.1 SI Boot Controller The SPI boot master allows booting from a Flash that is connected to the serial interface. For information about how to write to the serial interface, see SI Master Controller, page 338. For information about using an external CPU to access device registers using the serial interface, see Serial Interface in Slave Mode, page 315. The following table lists the registers associated with the SI boot controller. Table 234 • SI Boot Controller Configuration Registers | Register | Description | |------------------------|----------------------------------------------------| | ICPU_CFG::SPI_MST_CFG | Serial interface speed and address width | | ICPU_CFG::SW_MODE | Legacy manual control of the serial interface pins | | ICPU_CFG::GENERAL_CTRL | SI interface ownership | By default, the SI boot controller operates in 24-bit address mode. In this mode, there are four programmable chip selects when the VCore-III system controls the SI. Each chip select can address up to 16 megabytes (MB) of memory. Figure 117 • SI Boot Controller Memory Map in 24-Bit Mode The SI boot controller can be reconfigured for 32-bit address mode through SPI\_MST\_CFG.A32B\_ENA. In 32-bit mode, the entire SI region of 256 megabytes (MB) is addressed using chip select 0. Figure 118 • SI Boot Controller Memory Map in 32-Bit Mode Reading from the memory region for a specific SI chip select generates an SI read on that chip select. The VCore-III CPU can execute code directly from Flash by executing from the SI boot controller's memory region. For 32-bit capable SI Flash devices, the VCore-III must start up in 24-bit mode. During the boot process, it must manually reconfigure the Flash device (and SI boot controller) into 32-bit mode and then continue booting. The SI boot controller accepts 8-bit, 16-bit, and 32-bit read access with or without bursting. Writing to the SI requires manual control of the SI pins using software. Setting SW\_MODE.SW\_PIN\_CTRL\_MODE places all SI pins under software control. Output enable and the value of SI\_CLK, SI\_DO, SI\_nCSn are controlled through the SW\_MODE register. The value of the SI\_DI pin is available in SW\_MODE.SW\_SPI\_SDI. The software control mode is provided for legacy reasons; new implementations should use the dedicated master controller for writing to the serial interface. For more information see SI Master Controller, page 338. **Note:** The VCore-III CPU cannot execute code directly from the SI boot controller's memory region at the same time as manually writing to the serial interface. The following table lists the serial interface pins when the SI boot controller is configured as owner of SI interface in GENERAL\_CTRL.IF\_SI\_OWNER. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 235 • Serial Interface Pins | Pin Name | I/O | Description | |-----------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------| | SI_nCS0<br>SI_nCS[3:1]/GPIO | 0 | Active low chip selects. Only one chip select can be active at any time. Chip selects 1 through 3 are overlaid functions on GPIO pins. | | SI_CLK | 0 | Clock output. | | SI_DO | 0 | Data output (MOSI). | | SI_DI | I | Data input (MISO). | The SI boot controller does speculative prefetching of data. After reading address n, the SI boot controller automatically continues reading address n + 1, so that the next value is ready if requested by the VCore-III CPU. This greatly optimizes reading from sequential addresses in the Flash, such as when copying data from Flash into program memory. The following illustrations depict 24-bit address mode. When the controller is set to 32-bit mode (through SPI MST CFG.A32B ENA), 32 address bits are transferred instead of 24. Figure 119 • SI Read Timing in Normal Mode #### Figure 120 • SI Read Timing in Fast Mode The default timing of the SI boot controller operates with most serial interface Flash devices. Use the following process to calculate the optimized serial interface parameters for a specific SI device: - 1. Calculate an appropriate frequency divider value as described in SPI\_MST\_CFG.CLK\_DIV. The SI operates at no more than 25 MHz, and the maximum frequency of the SPI device must not be exceeded. The VCore-III system frequency in the device is 250 MHz. - The SPI device may require a FAST READ command rather than normal READ when the SI frequency is increased. Setting SPI MST CFG.FAST READ ENA makes the SI boot controller use FAST READ commands. - Calculate SPI\_MST\_CFG.CS\_DESELECT\_TIME so that it matches how long the SPI device requires chip-select to be deasserted between access. This value depends on the SI clock period that results from the SPI MST CFG.CLK DIV setting. These parameters must be written to SPI MST CFG. The CLK DIV field must either be written last or at the same time as the other parameters. The SPI MST CFG register can be configured while also booting up from the SI. When the VCore-III CPU boots from the SI interface, the default values of the SPI MST CFG register are used until the SI MST CFG is reconfigured with optimized parameters. This implies that SI CLK is operating at approximately 8.1 MHz, with normal read instructions and maximum gap between chip select operations to the Flash. Note: The SPI boot master does optimized reading. SI DI (from the Flash) is sampled just before driving falling edge on SI CLK (to the Flash). This greatly relaxes the round trip delay requirement for SI CLK to SI DI, allowing high Flash clock frequencies. #### 4.8.2 SI Master Controller This section describes the SPI master controller (SIMC) and how to use it for accessing external SPI slave devices, such as programming of a serially attached Flash device on the boot interface. VCore booting from serial Flash is handled by the SI boot master. The following table lists the registers associated with the SI master controller. Table 236 • SI Master Controller Configuration Registers Overview | Register | Description | |------------------------|-------------------------------------------| | SIMC::CTRLR0 | Transaction configuration | | SIMC::CTRLR1 | Configurations for receive-only mode | | SIMC::SIMCEN | SI master controller enable | | SIMC::SER | Slave select configuration | | SIMC::BAUDR | Baud rate configuration | | SIMC::TXFTLR | Tx FIFO threshold level | | SIMC::RXFTLR | Rx FIFO Threshold Level | | SIMC::TXFLR | Tx FIFO fill level | | SIMC::RXFLR | Rx FIFO fill level | | SIMC::SR | Various status indications | | SIMC::IMR | Interrupt enable | | SIMC::ISR | Interrupt sources | | SIMC::RISR | Unmasked interrupt sources | | SIMC::TXOICR | Clear of transmit FIFO overflow interrupt | | SIMC::RXOICR | Clear of receive FIFO overflow interrupt | | SIMC::RXUICR | Clear of receive FIFO underflow interrupt | | SIMC::DR | Tx/Rx FIFO access | | ICPU_CFG::GENERAL_CTRL | Interface configurations | The SI master controller supports Motorola SPI and Texas Instruments SSP protocols. The default protocol is SPI, enable SSP by setting CTRLR0.FRF = 1 and GENERAL\_CTRL.SSP\_MODE\_ENA = 1. The protocol baud rate is programmable in BAUDR.SCKDV; the maximum baud rate is 25 MHz. Before the SI master controller can be used, it must be set as owner of the serial interface. This is done by writing GENERAL\_CTRL.IF\_SI\_OWNER = 2. The SI master controller has a programmable frame size. The frame size is the smallest unit when transferring data over the SI interface. Using CTRLR0.DFS, the frame size is configured in the range of 4 bits to 16 bits. When reading or writing words from the transmit/receive FIFO, the number of bits that is stored per FIFO-word is always equal to frame size (as programmed in CTRLR0.DFS). The controller operates in one of three following major modes: Transmit and receive, transmit only, or receive only. The mode is configured in CTRLR0.TMOD. **Transmit and receive.** software paces SI transactions. For every data frame that software writes to the transmission FIFO, another data frame is made available in the receive FIFO (receive data from the serial interface). Transaction will go on for as long as there is data available in the transmission FIFO. **Transmit only.** Software paces SI transactions. The controller transmits only; receive data is discarded. Transaction will go on for as long as there is data available in the transmission FIFO. **Receive only.** The controller paces SI transactions. The controller receives only data, software requests a specific number of data frames by means of CTRLR1.NDF, the transaction will go on until all data frames has been read from the SI interface. Transaction is initiated by software writing one data frame to transmission FIFO. This frame is not used for anything else than starting the transaction. The SI\_DO output is undefined during receive only transfers. Receive data frames are put into the receive FIFO as they are read from SI. For SPI mode, chip select is asserted throughout transfers. Transmit transfers end when the transmit FIFO runs out of data frames. Software must make sure it is not interrupted while writing data for a multiframe transfer. When multiple distinct transfers are needed, wait for SR.TFE = 1 and SR.BUSY = 0 before initiating new transfer. SR.BUSY is an indication of ongoing transfers, however, it is not asserted immediately when writing frames to the FIFO. As a result, software must also check the SR.TFE (transmit FIFO empty) indication. The SI master controller supports up to 16 chip selects. Chip select 0 is mapped to the SI\_nCS pin of the serial interface. The remaining chips selects are available using overlaid GPIO functions. Software controls which chip selects to activate for a transfer using the SER register. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 237 • SI Master Controller Pins | Pin Name | I/O | Description | |------------------------------|-----|---------------------------------------------------------------------------------------------| | SI_nCS0<br>SI_nCS[15:1]/GPIO | 0 | Active low chip selects. Chip selects 1 through 15 are overlaid functions on the GPIO pins. | | SI_CLK | 0 | Clock output. | | SI_DO | 0 | Data output (MOSI). | | SI_DI | I | Data input (MISO). | Writing to any DR replication index put data into the transmission FIFO, and reading from any DR replication index take out data from the receive FIFO. FIFO status indications are available in the SR register's TFE, TFNF, RFF, and RFNE fields. For information about interrupting on FIFO status, see SIMC Interrupts, page 342. After completing all initial configurations, the SI master controller is enabled by writing SIMCEN.SIMCEN = 1. Some registers can only be written when the controller is in disabled state. This is noted in the register-descriptions for the affected registers. #### 4.8.2.1 SPI Protocol When the SI master controller is configured for SPI mode, clock polarity and position is configurable in CTRLR0.SCPH and CTRLR0.SCPOL. The following illustration shows the four possible combinations for 8-bit transfers. Figure 121 • SIMC SPI Clock Configurations Data is sampled in the middle of the data-eye. When using SPI protocol and transferring more than one data frame at the time, the controller performs one consecutive transfer. The following illustration shows a transfer of three data frames of 4 bits each. **Note:** Transmitting transfers end when the transmit FIFO runs out of data frames. Receive only transfers end when the pre-defined number of data-frames is read from the SI interface. Figure 122 • SIMC SPI 3x Transfers ### 4.8.2.2 SSP Protocol The SSP protocol for transferring two 6-bit data frames is shown in the following illustration. When using SSP mode, CTRLR0.SCPH and CTRLR0.SCPOL must remain zero. #### 4.8.2.3 SIMC SSP 2x Transfers ### 4.8.2.4 SIMC Interrupts The SI master controller has five interrupt sources: - RXF interrupt is asserted when the fill level of the receive FIFO (available in RXFLR) exceeds the programmable level set in RXFTLR. This interrupt is non-sticky; it is deasserted when fill level is decreased below the programmable level. - RXO interrupt is asserted on receive FIFO overflow. This interrupt is cleared by reading the RXOICR register. - RXU interrupt is asserted when reading from an empty receive FIFO. This interrupt is cleared by reading the RXUICR register. - TXO interrupt is asserted when writing to a full transmit FIFO. This interrupt is cleared by reading the TXOICR register. - TXE interrupt is asserted when the fill level of the transmit FIFO (available in TXFLR) is below the programmable level set in TXFTLR. This interrupt is non-sticky; it is deasserted when fill level is increased above the programmable level. The raw (unmasked) status of these interrupts is available in the RISR register. Each of the interrupts can be individually masked by the IMR register. All interrupts are enabled by default. The currently active interrupts are shown in the ISR register. If the RXO, RXU, and TXO interrupts occur during normal use of the SI master controller, it is an indication of software problems. Interrupt is asserted towards the VCore-III interrupt controller when any enabled interrupt is asserted and the SI master controller is enabled. ### 4.8.2.5 SIMC Programming Example This example shows how to use the SI master controller to interface with the SI slave of another device. The slave device will be initialized for big endian/most significant bit first mode and then the DEVCPU\_GCB::GPR register is written with the value 0x01234567. It is assumed that the other device's SI slave is connected on SI nCS1 (and that appropriate GPIO alternate function has been enabled). The SI slave is using a 24-bit address field and a 32-bit data field. This example uses 4 x 16-bit data frames to transfer the write-access. This means that 8 bits too much will be transferred, this is not a problem for the Microsemi SI slave interface; it ignores data above and beyond the 56 bit required for a write-access. For information about initialization and how to calculate the 24-bit SI address field, see Serial Interface in Slave Mode, page 315. The address-field when writing DEVCPU\_GCB::GPR is 0x804001 (including write-indication). The following steps are required to bring up the SI master controller and write twice to the SI slave device. **Important** The following procedure disconnects the SI boot master from the SI interface. Booting must be done before attempting to overtake the boot-interface. - Write GENERAL\_CTRL.IF\_SI\_OWNER = 2 to make SI master controller the owner of the SI interface. - 2. Write BAUDR = 250 to get 1 MHz baud rate. - 3. Write SER = 2 to use SI nCS1. - 4. Write CTRLR0 = 0x10F for 16-bit data frame and transmit only. - 5. Write SIMCEN = 1 to enable the SI master controller. - 6. Write DR[0] = 0x8000, 0x0081, 0x8181, 0x8100 to configure SI slave for big endian / most significant bit first mode. - 7. Wait for SR.TFE = 1 and SR.BUSY = 0 for chip select to deassert between accesses to the SI slave. - 8. Write DR[0] = 0x8040, 0x0101, 0x2345, 0x6700 to write DEVCPU GCB::GPR in slave device. - 9. Wait for SR.TFE = 1 and SR.BUSY = 0, then disable the SI master controller by writing SIMCEN = 0. When reading from the SI slave, CTRLR0.TMOD must be configured for transmit and receive. One-byte padding is appropriate for a 1 MHz baud rate. # 4.8.3 DDR3/DDR3L Memory Controller This section provides information about how to configure and initialize the DDR3/DDR3L memory controller. The following table lists the registers associated with the memory controller. Table 238 • DDR3/DDR3L Controller Registers | Register | Description | |--------------------------------|------------------------------| | ICPU_CFG::RESET | Reset Control | | ICPU_CFG::MEMCTRL_CTRL | Control | | ICPU_CFG::MEMCTRL_CFG | Configuration | | ICPU_CFG::MEMCTRL_STAT | Status | | ICPU_CFG::MEMCTRL_REF_PERIOD | Refresh period configuration | | ICPU_CFG::MEMCTRL_ZQCAL | DDR3/DDR3L ZQ-calibration | | ICPU_CFG::MEMCTRL_TIMING0 | Timing configuration | | ICPU_CFG::MEMCTRL_TIMING1 | Timing configuration | | ICPU_CFG::MEMCTRL_TIMING2 | Timing configuration | | ICPU_CFG::MEMCTRL_TIMING3 | Timing configuration | | ICPU_CFG::MEMCTRL_MR0_VAL | Mode register 0 value | | ICPU_CFG::MEMCTRL_MR1_VAL | Mode register 1 value | | ICPU_CFG::MEMCTRL_MR2_VAL | Mode register 2 value | | ICPU_CFG::MEMCTRL_MR3_VAL | Mode register 3 value | | ICPU_CFG::MEMCTRL_TERMRES_CTRL | Termination resistor control | | ICPU_CFG::MEMCTRL_DQS_DLY | DQS window configuration | | ICPU_CFG::MEMPHY_CFG | SSTL configuration | | ICPU_CFG::MEMPHY_ZCAL | SSTL calibration | The memory controller works with JEDEC-compliant DDR3/DDR3L memory modules. The controller runs 312.50 MHz and supports one or two byte lanes in either single or dual row configurations (one or two chip selects). The controller supports up to 16 address bits. The maximum amount of physical memory that can be attached to the controller is 1 gigabyte. The memory controller supports ECC encoding/decoding by using one of the two lanes for ECC information. Enabling ECC requires that both byte lanes are populated. When ECC is enabled, half the total physical memory is available for software use; the other half is used for ECC information. The following steps are required to bring up the memory controller. - Release the controller from reset by clearing RESET.MEM RST FORCE. - Configure timing and mode parameters. These depend on the DDR3/DDR3L module and configuration selected for the device. For more information, see DDR3/DDR3L Timing and Mode Configuration Parameters, page 344. - 3. Enable and calibrate the SSTL I/Os. For more information, see Enabling and Calibrating SSTL I/Os. - 4. Initialize the memory controller and modules. For more information, see Memory Controller and Module Initialization. - Calibrate the DQS read window. For more information, see DQS Read Window Calibration. - Optionally configure ECC and 1 gigabyte support. For more information, see ECC and 1-Gigabyte Support, page 348. #### 4.8.3.1 DDR3/DDR3L Timing and Mode Configuration Parameters This section provides information about each of the parameters that must be configured prior to initialization of the memory controller. It provides a quick overview of fields that must be configured and their recommended values. For more information about each field, see the register list. The memory controller operates at 312.5 MHz, and the corresponding DDR clock period is 3.2 ns (DDR625). When a specific timing value is used in this section (for example, $t_{\text{MOD}}$ ), it means that the corresponding value from the memory module datasheet is expressed in memory controller clock cycles (divided by 3.2 ns and rounded up and possibly adjusted for minimum clock cycle count). The following table defines general parameters for DDR3/DDR3L required when configuring the memory controller. **Parameter** DDR3/DDR3L RI CL WL **CWL** MD $t_{MOD}$ ID $t_{XPR}$ SD t<sub>DLLK</sub> 2 OW 2 OR RP $t_{RP}$ **FAW** $t_{\mathsf{FAW}}$ BL 4 MR0 $((RL-4) << 4) \mid ((t_{WR-4}) << 9)$ MR1 0x0040 MR2 ((WL-5) << 3)MR3 0x0000 Table 239 • General DDR3/DDR3L Timing and Mode Parameters The following table lists the memory controller registers that must be configured before initialization. It is recommended to configure all fields listed, even when ODT or dual row configurations are not used. Table 240 • Memory Controller Configuration | Register Field | Description | |----------------------|-------------------------------| | MEMCTRL_CFG.DDR_MODE | Set to 1 for DDR3/DDR3L mode. | Table 240 • Memory Controller Configuration (continued) | Register Field | Description | |------------------------------------------|---------------------------------------------------------------------------------------------------------| | MEMCTRL_CFG.DDR_WIDTH | Set to 0 when using 1 byte lane. Set to 1 when using 2 byte lanes. | | MEMCTRL_CFG.MSB_COL_ADDR | Set to one less than the number of column address bits for the modules. | | MEMCTRL_CFG.MSB_ROW_ADDR | Set to one less than the number of row address bits for the modules. See field description for example. | | MEMCTRL_CFG.BANK_CNT | Set to 1. | | MEMCTRL_CFG.BURST_LEN | Set to 1. | | MEMCTRL_CFG.BURST_SIZE | Set to same value as MEMCTRL_CFG.DDR_WIDTH. | | MEMCTRL_CFG.DDR_ECC_ENA | Set to 0 during initialization of the memory controller. | | MEMCTRL_CFG.DDR_ECC_COR_ENA | Set to 0 during initialization of the memory controller. | | MEMCTRL_CFG.DDR_ECC_ERR_ENA | Set to 0 during initialization of the memory controller. | | MEMCTRL_CFG.DDR_512MBYTE_PLUS | Set to 0 during initialization of the memory controller. | | MEMCTRL_REF_PERIOD.REF_PERIOD | Set to (tREFI(ns)/3.2ns) round down to the nearest integer. | | MEMCTRL_REF_PERIOD.MAX_PEND_REF | Set to 8. | | MEMCTRL_TIMING0.RD_DATA_XFR_DLY | Set to (RL-3). | | MEMCTRL_TIMING0.WR_DATA_XFR_DLY | Set to (WL-1). | | MEMCTRL_TIMING0.RD_TO_PRECH_DLY | Set to (BL-1). | | MEMCTRL_TIMING0.WR_TO_PRECH_DLY | Set to (WL+BL+tWR-1). | | MEMCTRL_TIMING0.RAS_TO_PRECH_DLY | Set to (tRAS(min)-1). | | MEMCTRL_TIMING0.RD_CS_CHANGE_DLY | Set to BL. | | MEMCTRL_TIMING0.WR_CS_CHANGE_DLY | Set to (BL-1). | | MEMCTRL_TIMING0.RD_TO_WR_DLY | Set to (RL+BL+1-WL). | | MEMCTRL_TIMING1.WR_TO_RD_DLY | Set to (WL+BL+tWTR-1). | | MEMCTRL_TIMING1.RAS_TO_CAS_DLY | Set to (tRCD-1). | | MEMCTRL_TIMING1.RAS_TO_RAS_DLY | Set to (tRRD-1). | | MEMCTRL_TIMING1.PRECH_TO_RAS_DLY | Set to (tRP-1). | | MEMCTRL_TIMING1.BANK8_FAW_DLY | Set to (FAW-1). | | MEMCTRL_TIMING1.RAS_TO_RAS_SAME_BANK_DLY | Set to (tRC-1). | | MEMCTRL_TIMING2.INIT_DLY | Set to (ID-1) during initialization of the memory controller. | | MEMCTRL_TIMING2.REF_DLY | Set to (tRFC-1). | | MEMCTRL_TIMING2.MDSET_DLY | Set to (MD-1). | | MEMCTRL_TIMING2.PRECH_ALL_DLY | Set to (RP-1). | | MEMCTRL_TIMING3.WR_TO_RD_CS_CHANGE_DLY | Set to (WL+tWTR-1). | | MEMCTRL_TIMING3.LOCAL_ODT_RD_DLY | Set to (RL-3). | | MEMCTRL_TIMING3.ODT_WR_DLY | Set to (OW-1). | | MEMCTRL_TIMING3.ODT_RD_DLY | Set to (OR-1). | | MEMCTRL_MR0_VAL.MR0_VAL | Set to MR0. | **Table 240 • Memory Controller Configuration (continued)** | Register Field | Description | | |-------------------------|-------------|--| | MEMCTRL_MR1_VAL.MR1_VAL | Set to MR1. | | | MEMCTRL_MR2_VAL.MR2_VAL | Set to MR2. | | | MEMCTRL_MR3_VAL.MR3_VAL | Set to MR3. | | The memory controller supports two chip selects and automatically selects modules based on the configured address width and bank count. The resulting pool of memory is one large consecutive region. #### 4.8.3.2 On-Die Termination An end termination scheme must be configured when writing from the device to the memory modules, the memory module furthest away from the device must be connected to the ODT output. Enable assertion of ODT output for all write access by setting MEMCTRL\_TERMRES\_CTRL = 0x0000000C. Figure 123 • Memory Controller ODT Hookup # 4.8.3.3 Enabling and Calibrating SSTL I/Os Prior to controller initialization, the device's SSTL I/O drivers must be enabled and calibrated to correct drive strength and termination resistor values. It is recommended that the device's I/O drive and termination strengths be 60 $\Omega$ /60 $\Omega$ . Complete the following tasks to enable and calibrate the SSTL I/Os. - Enable the SSTL mode by clearing MEMPHY\_CFG.PHY\_RST and setting MEMPHY\_CFG.PHY\_SSTL\_ENA. - Perform calibration with the previously mentioned drive and termination strengths by writing 0xEF to MEMPHY\_ZCAL. - 3. Wait until MEMPHY\_ZCAL.ZCAL\_ENA is cleared (indicates calibration is done). - 4. Enable drive of the SSTL I/Os by setting MEMPHY\_CFG.PHY\_CK\_OE, MEMPHY\_CFG.PHY\_CL\_OE, and MEMPHY\_CFG.PHY\_ODT\_OE. The SSTL interface is now enabled and calibrated, and the initialization of the memory controller can commence. #### 4.8.3.4 Memory Controller and Module Initialization After memory controller parameters are configured, and after the SSTL I/Os are enabled and calibrated, the memory controller and modules are initialized by setting MEMCTRL CTRL.INITIALIZE. During initialization, the memory controller automatically follows the proper JEDEC defined procedure for initialization and writing of mode registers to the DDR3/DDR3L memory modules. The memory controller automatically clears MEMCTRL\_CTRL.INITIALIZE and sets the MEMCTRL\_STAT.INIT\_DONE field after the controller and the memory module (or modules) are operational. Software must wait for the INIT\_DONE indication before continuing to calibrate the read window. #### 4.8.3.5 DQS Read Window Calibration After initialization of the memory controller, successful writes to the memory are guaranteed. Reading is not yet possible, because the round trip delay between controller and memory modules are not calibrated. Calibration of the read window includes writing a known value to the start of the DDR memory and then continually reading this value while adjusting the DQS window until the correct value is read from the memory. The calibration procedure depends on the number of byte lanes that are used (see MEMCTRL CFG.DDR WIDTH). **Note:** For an ECC system, the calibration procedure for two byte lanes must be used, because the memory controller is initialized without ECC enabled. #### Calibration of One Byte Lane The following procedure applies to systems where MEMCTRL\_CFG.DDR\_WIDTH is 0: - Write 0x000000FF to SBA address 0x20000000. - Set the MEMCTRL DQS DLY[0].DQS DLY field to 0. Perform the following steps to calibrate the read window. Do not increment the DQS\_DLY field beyond its maximum value. If the DQS\_DLY maximum value is exceeded, it is an indication something is incorrect, and the memory controller will not be operational. - Read byte address 0x20000000. If the content is different from 0xFF, increment MEMCTRL\_DQS\_DLY[0].DQS\_DLY by one, and repeat step 1, else continue to step 2. - Read byte address 0x20000000. If the content is different from 0x00, increment MEMCTRL\_DQS\_DLY[0].DQS\_DLY by one, and repeat step 2, else continue to step 3. - 3. Decrement MEMCTRL\_DQS\_DLY[0].DQS\_DLY by three. After the last step, which configures the appropriate DQS read window, the memory is ready for random read and write operations. For more information about ECC or 1 gigabyte support, see ECC and 1-Gigabyte Support, page 348. #### **Calibration of Two Byte Lanes** This procedure applies to systems where MEMCTRL CFG.DDR WIDTH is 1: - Write 0x0000FFFF to SBA address 0x20000000. - Write 0x00000000 to SBA address 0x20000004. - Set the MEMCTRL\_DQS\_DLY[0].DQS\_DLY field to 0. - Set the MEMCTRL DQS DLY[1].DQS DLY field to 0. Perform the following steps to calibrate the read window. Do not increment the DQS\_DLY fields beyond their maximum value. If a DQS\_DLY maximum value is exceeded, it is an indication something is incorrect, and the memory controller will not be operational. Read byte addresses 0x20000000 and 0x20000001 from memory. If the contents of byte address 0x20000000 is different from 0xFF, increment MEMCTRL\_DQS\_DLY[0].DQS\_DLY by one. If the contents of byte address 0x20000001 is different from 0xFF, increment MEMCTRL\_DQS\_DLY[1].DQS\_DLY by one. If any DQS DLY was incremented repeat step 1, else continue to step 2. Read byte addresses 0x20000000 and 0x20000001 from memory. If the contents of byte address 0x20000000 is different from 0x00, increment MEMCTRL\_DQS\_DLY[0].DQS\_DLY by one. If the contents of byte address 0x20000001 is different from 0x00, increment MEMCTRL\_DQS\_DLY[1].DQS\_DLY by one. - If any DQS DLY was incremented repeat step 2, else continue to step 3. - Decrement MEMCTRL\_DQS\_DLY[0].DQS\_DLY by three, and decrement MEMCTRL\_DQS\_DLY[1] by three. The last step configures the appropriate DQS read windows. After this step the memory is ready for random read and write operations. If ECC or 1 gigabyte is needed, see ECC and 1 Gigabyte Support. # 4.8.3.6 ECC and 1-Gigabyte Support The memory controller supports ECC, allowing correction of single bit and detection of two bit errors in every byte that is read from memory. When ECC is enabled, one byte lane is used for data words and the other is used for ECC check-word. After enabling ECC, the amount of memory available to software is half of the physical memory (the lower half of the memory region). ECC support must be enabled just after read calibration by setting MEMCTRL\_CFG.DDR\_ECC\_ENA = 1 and at the same time setting MEMCTRL\_CFG.BURST\_SIZE = 0. When ECC is enabled, the memory controller automatically corrects single-bit errors and detects two-bit errors. It is possible to propagate these events to the SBA to trigger a bus-error event in the VCore-III CPU. Non-correctable error indications are forwarded when MEMCTRL\_CFG.DDR\_ECC\_ERR\_ENA = 1. Correctable "errors" are forwarded when MEMCTRL\_CFG.DDR\_ECC\_COR\_ENA = 1. The VCore-III CPU can generate interrupt on these events so that software can take the appropriate action. The memory controller supports up to 1 gigabyte of physical memory. To access more than 512 megabytes from the VCore-III CPU, set MEMCTRL\_CFG.DDR\_512MBYTE\_PLUS = 1 to change the SBA memory map. For more information, see Shared Bus. When ECC is enabled with 1 gigabyte of physical memory, MEMCTRL\_CFG.DDR\_512MBYTE\_PLUS does not have to be set, because only half of the physical memory is available to software. ## **4.8.4** Timers This section provides information about the timers. The following table lists the registers associated with timers. Table 241 • Timer Registers | Register | Description | |------------------------------|-----------------------------| | ICPU_CFG::TIMER_CTRL | Enable/disable timer | | ICPU_CFG::TIMER_VALUE | Current timer value | | ICPU_CFG::TIMER_RELOAD_VALUE | Value to load when wrapping | | ICPU_CFG::TIMER_TICK_DIV | Common timer-tick divider | There are three decrementing 32-bit timers in the VCore-III system that run from a common divider. The common divider is driven by a fixed 250 MHz clock and can generate timer ticks from 0.1 $\mu$ s (10 MHz) to 1 ms (1 kHz), configurable through TIMER TICK DIV. The default timer tick is 100 $\mu$ s (10 kHz). Software can access each timer value through the TIMER\_VALUE[n] registers. These can be read or written at any time, even when the timers are active. When a timer is enabled through TIMER\_CTRL[n].TIMER\_ENA, it decrements from the current value until it reaches zero. An attempt to decrement a TIMER\_VALUE[n] of zero generates interrupt and assigns TIMER\_VALUE[n] to the contents of TIMER\_RELOAD\_VALUE[n]. Interrupts generated by the timers are sent to the VCore-III interrupt controller. From here, interrupts can be forwarded to the VCore-III CPU or to an external CPU. For more information, see Interrupt Controller. By setting TIMER\_CTRL[n].ONE\_SHOT\_ENA, the timer disables itself after generating one interrupt. By default, timers will decrement, interrupt, and reload indefinitely (or until disabled by clearing TIMER\_CTRL[n].TIMER\_ENA). A timer can be reloaded from TIMER\_RELOAD\_VALUE[n] at the same time as it is enabled by setting TIMER\_CTRL[n].FORCE\_RELOAD and TIMER\_CTRL[n].TIMER\_ENA at the same time. **Example** Configure Timer0 to interrupt every 1 ms. With the default timer tick of 100 µs ten timer ticks are needed for a timer that wraps every 1 ms. Configure TIMER\_RELOAD\_VALUE[0] to 0x9, then enable the timer and force a reload by setting TIMER\_CTRL[0].TIMER\_ENA and TIMER\_CTRL[0].FORCE RELOAD at the same time. #### 4.8.5 **UARTs** This section provides information about the UART (Universal Asynchronous Receiver/Transmitter) controllers. There are two independent UART controller instances in the VCore-III system: UART and UART2. These instances are identical copies and anywhere in this description the word UART can be replaced by UART2. The following table lists the registers associated with the UART. Register Description UART::RBR THR Receive buffer/transmit buffer/Divisor (low) **UART::IER** Interrupt enable/divisor (high) UART::IIR FCR Interrupt identification/FIFO control **UART::LCR** Line control **UART::MCR** Modem control **UART::LSR** Line status **UART::MSR** Modem status **UART::SCR** Scratchpad **UART::USR UART** status Table 242 • UART Registers The VCore-III system UART is functionally based on the industry-standard 16550 UART (RS232 protocol). This implementation features a 16-byte receive and a 16-byte transmit FIFO. Figure 124 • UART Timing The number of data bits, parity, parity-polarity, and stop-bit lengths are all programmable using LCR. The UART pins on the device are overlaid functions on the GPIO interface. Before enabling the UART, the VCore-III CPU must enable overlaid modes for the appropriate GPIO pins. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. The following table lists the pins of the UART interfaces. Table 243 • UART Interface Pins | Pin Name | I/O | Description | |---------------|-----|-------------------| | UART_RXD/GPIO | I | UART receive data | Table 243 • UART Interface Pins (continued) | Pin Name | I/O | Description | |----------------|-----|---------------------| | UART_TXD/GPIO | 0 | UART transmit data | | UART2_RXD/GPIO | I | UART2 receive data | | UART2_TXD/GPIO | 0 | UART2 transmit data | The baud rate of the UART is derived from the VCore-III system frequency. The divider value is indirectly set through the RBR\_THR and IER registers. The baud rate is equal to the VCore-III system clock frequency, divided by 16, and multiplied by the value of the baud rate divisor. A divider of zero disables the baud rate generator and no serial communications occur. The default value for the divisor register is zero. **Example** Configuring a baud rate of 9600 in a 250 MHz VCore-III system. To generate a baud rate of 9600, the divisor register must be set to 0x65C (250 MHz/(16 × 9600 Hz)). Set LCR.DLAB and write 0x5C to RBR\_THR and 0x06 to IER (this assumes that the UART is not in use). Finally, clear LCR.DLAB to change the RBR\_THR and IER registers back to the normal mode. By default, the FIFO mode of the UART is disabled. Enabling the 16-byte receive and 16-byte transmit FIFOs (through IIR FCR) is recommended. **Note:** Although the UART itself supports RTS and CTS, these signals are not available on the pins of the device. #### 4.8.5.1 **UART Interrupt** The UART can generate interrupt whenever any of the following prioritized events are enabled (through IER). - Receiver error - Receiver data available - Character timeout (in FIFO mode only) - Transmit FIFO empty or at or below threshold (in programmable THRE interrupt mode) When an interrupt occurs, the IIR\_FCR register can be accessed to determine the source of the interrupt. Note that the IIR\_FCR register has different purposes when reading or writing. When reading, the interrupt status is available in bits 0 through 3. For more information about interrupts and how to handle them, see the IIR\_FCR register description. **Example** Enabling interrupt when transmit fifo is below one-quarter full. To get this type of interrupt, the THRE interrupt must be used. First, configure TX FIFO interrupt level to one-quarter full by setting IIR\_FCR.TET to 10; at the same time, ensure that the IIR\_FCR.FIFOE field is also set. Set IER.PTIME to enable the THRE interrupt in the UART. In addition, the VCore-III interrupt controller must be configured for the CPU to be interrupted. For more information, see Interrupt Controller. #### 4.8.6 Two-Wire Serial Interface This section provides information about the two-wire serial interface controllers. There are two independent two-wire serial interface controller instances in the VCore-III system, TWI and TWI2. These instances are identical copies and anywhere in this description the word TWI can be replaced by TWI2. The following table lists the registers associated with the two-wire serial interface. Table 244 • Two-Wire Serial Interface Registers | Register | Description | | |---------------|--------------------------------------|--| | TWI::CFG | General configuration. | | | TWI::TAR | Target address. | | | TWI::SAR | Slave address. | | | TWI::DATA_CMD | Receive/transmit buffer and command. | | Table 244 • Two-Wire Serial Interface Registers (continued) | Register | Description | |--------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | TWI::SS_SCL_HCNT | Standard speed high time clock divider. | | TWI::SS_SCL_LCNT | Standard speed low time clock divider. | | TWI::FS_SCL_HCNT | Fast speed high time clock divider. | | TWI::FS_SCL_LCNT | Fast speed low time clock divider. | | TWI::INTR_STAT | Masked interrupt status. | | TWI::INTR_MASK | Interrupt mask register. | | TWI::RAW_INTR_STAT | Unmasked interrupt status. | | TWI::RX_TL | Receive FIFO threshold for RX_FULL interrupt. | | TWI::TX_TL | Transmit FIFO threshold for TX_EMPTY interrupt. | | TWI::CLR_* | Individual CLR_* registers are used for clearing specific interrupts. See register descriptions for corresponding interrupts. | | TWI::CTRL | Control register. | | TWI::STAT | Status register. | | TWI::TXFLR | Current transmit FIFO level. | | TWI::RXFLR | Current receive FIFO level. | | TWI::TX_ABRT_SOURCE | Arbitration sources. | | TWI::SDA_SETUP | Data delay clock divider. | | TWI::ACK_GEN_CALL | Acknowledge of general call. | | TWI::ENABLE_STATUS | General two-wire serial controller status. | | ICPU_CFG::TWI_CONFIG | Configuration of TWI_SDA hold-delay. | | ICPU_CFG::TWI_SPIKE_FILTER_CFG | Configuration of TWI_SDA spike filter. | The two-wire serial interface controller is compatible with the industry standard two-wire serial interface protocol. The controller supports standard speed up to 100 kbps and fast speed up to 400 kbps. Multiple bus masters, as well as both 7-bit and 10-bit addressing, are also supported. The two-wire serial interface controller operates as master only. The two-wire serial interface pins on the device are overlaid functions on the GPIO interface. Before enabling the two-wire serial interface, the VCore-III CPU must enable overlaid functions for the appropriate GPIO pins. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. The following table lists the pins of the two-wire serial interface. Table 245 • Two-Wire Serial Interface Pins | Pin Name | I/O | Description | |--------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TWI_SCL/GPIO | I/O | Two-wire serial interface clock, open-collector output. | | TWI_SDA/GPIO | I/O | Two-wire serial interfacedata, open-collector output. | | TWI_SCL_Mn/GPIO | I/O | Two-wire serial interface multiplexed clocks (12 instances in total), open-collector outputs. | | TWI_SCL_Mn_AD/GPIO | I/O | Two-wire serial interface multiplexed clocks (4 instances in total). Same as TWI_SCL_Mn/GPIO but the pin is always driven meaning feedback from slave devices is not possible. | | TWI2_SCL/GPIO | I/O | Two-wire serial interface 2 clock, open-collector output. | Table 245 • Two-Wire Serial Interface Pins (continued) | Pin Name | I/O | Description | |---------------|-----|----------------------------------------------------------| | TWI2_SDA/GPIO | I/O | Two-wire serial interface 2 data, open-collector output. | Setting CTRL.ENABLE enables the controller. The controller can be disabled by clearing the CTRL.ENABLE field, there is a chance that disabling is not allowed (at the time when it is attempted); the ENABLE STATUS register shows if the controller was successful disabled. Before enabling the controller, the user must decide on either standard or fast mode (CFG.SPEED) and configure clock dividers for generating the correct timing (SS\_SCL\_HCNT, SS\_SCL\_LCNT, FS\_SCL\_HCNT, FS\_SCL\_LCNT, and SDA\_SETUP). The configuration of the divider registers depends on the VCore-III system clock frequency. The register descriptions explain how to calculate the required values. Some two-wire serial devices require a hold time on TWI\_SDA after TWI\_SCL when transmitting from the two-wire serial interface controller. The device supports a configurable hold delay through the TWI\_CONFIG register. The two-wire serial interface controller has an 8-byte combined receive and transmit FIFO. During normal operation of the two-wire serial interface controller, the STATUS register shows the activity and FIFO states. Figure 125 • Two-Wire Serial Interface Timing for 7-bit Address Access # 4.8.6.1 Two-Wire Serial Interface Addressing To configure either 7-bit or 10 bit addressing, use CFG.MASTER\_10BITADDR. The two-wire serial interface controller can generate both General Call and START Byte. Initiate this through TAR.GC\_OR\_START\_ENA or TAR.GC\_OR\_START. The target/slave address is configured using the TAR register. #### 4.8.6.2 Two-Wire Serial Interface Interrupt The two-wire serial interface controller can generate a multitude of interrupts. All of these are described in the RAW\_INTR\_STAT register. The RAW\_INTR\_STAT register contains interrupt fields that are always set when their trigger conditions occur. The INTR\_MASK register is used for masking interrupts and allowing interrupts to propagate to the INTR\_STAT register. When set in the INTR\_STAT register, the two-wire serial interface controller asserts interrupt toward the VCore-III interrupt controller. The RAW\_INTR\_STAT register also specifies what is required to clear the specific interrupts. When the source of the interrupt is removed, reading the appropriate CLR\_\* register (for example, CLR\_RX\_OVER) clears the interrupt. #### 4.8.6.3 Built-in Two-Wire Serial Multiplexer The device has built-in support for connecting to multiple two-wire serial devices that use the same two-wire serial address. This is done by using the multiplexed clock outputs (TWI\_SCL\_Mn) for the two-wire serial devices rather than TWI\_SCL. Depending on which device or devices it needs to talk to, software can then enable/disable the various clocks. This multiplexing feature is available for the first two-wire serial interface controller instance. From the two-wire serial controllers point of view, it does not know if it is using TWI\_SCL or TWI\_SCL\_Mn clocks. When using multiplexed mode, software needs to enable/disable individual TWI\_SCL\_Mn connections before initiating the access operation using the two wire serial controller. Feedback on the clock (from slow two-wire serial devices) is automatically done for the TWI\_SCL\_Mn lines that are enabled. To enable multiplexed clocks, first configure the TWI\_SCL\_Mn overlaid mode in the GPIO controller. Individual TWI\_SCL\_Mn clocks are then enabled by writing 1 to the corresponding GPIO output bit (in DEVCPU\_GCB::GPIO\_OUT). To disable the clock, write 0 to the GPIO output bit. Disabled TWI\_SCL\_Mn clocks are not driven during access and the feedback is disabled. **Note:** In multiprocessor systems, the DEVCPU\_GCB::GPIO\_OUT\_SET and DEVCPU\_GCB::GPIO\_OUT\_CLR registers can be used to avoid race conditions. # 4.8.7 MII Management Controller This section provides information about the MII Management (MIIM) controllers. The following table lists the registers associated with the MII Management controllers. Table 246 • MIIM Registers | Register | Description | |-------------------------------------|-----------------------------------------------| | DEVCPU_GCB::MII_STATUS | Controller status | | DEVCPU_GCB::MII_CMD | Command and write data | | DEVCPU_GCB::MII_DATA | Read data | | DEVCPU_GCB::MII_CFG | Clock frequency configuration | | DEVCPU_GCB::MII_SCAN_0 | Auto-scan address range | | DEVCPU_GCB::MII_SCAN_1 | Auto-scan mask and expects | | DEVCPU_GCB::MII_SCAN_LAST_RSLTS | Auto-scan result | | DEVCPU_GCB::MII_SCAN_LAST_RSLTS_VLD | Auto-scan result valid | | DEVCPU_GCB:: MII_SCAN_RSLTS_STICKY | Differences in expected versus read auto-scan | The device contains two MIIM controllers with equal functionality. Data is transferred on the MIIM interface using the Management Frame Format protocol specified in IEEE 802.3, Clause 22 or the MDIO Manageable Device protocol defined in IEEE 802.3, Clause 45. The Clause 45 protocol differs from the Clause 22 protocol by using indirect register access to increase the address range. The controller supports both Clause 22 and Clause 45. The first MIIM controller is connected to the internal PHYs of the device. The MIIM interface pins for the second controller are overlaid functions on the GPIO interface. Before using this MIIM controller, the overlaid functions for the appropriate GPIO pins must first be enabled. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 247 • MIIM Management Controller Pins | Pin Name | I/O | Description | |------------|-----|-----------------------------------------| | MDC1/GPIO | 0 | MIIM clock for controller 1 | | MDIO1/GPIO | I/O | MIIM data input/output for controller 1 | The MDIO signal is changed or sampled on the falling edge of the MDC clock by the controller. The MDIO pin is tri-stated in-between access and when expecting read data. #### Figure 126 • MII Management Timing #### 4.8.7.1 Clock Configuration The frequency of the management interface clock generated by the MIIM controller is derived from the switch core's frequency. The MIIM clock frequency is configurable and is selected with MII\_CFG\_MIIM\_CFG\_PRESCALE. The calculation of the resulting frequency is explained in the register description for MII\_CFG.MIIM\_CFG\_PRESCALE. The maximum frequency of the MIIM clock is 25 MHz. ## 4.8.7.2 MII Management PHY Access Reads and writes across the MII management interface are performed through the MII\_CMD register. Details of the operation, such as the PHY address, the register address of the PHY to be accessed, the operation to perform on the register (for example, read or write), and write data (for write operations), are set in the MII\_CMD register. When the appropriate fields of MII\_CMD are set, the operation is initiated by writing 0x1 to MII\_CMD.MIIM\_CMD\_VLD. The register is automatically cleared when the MIIM command is initiated. When initiating single MIIM commands, MII\_CMD.MIIM\_CMD\_SCAN must be set to 0x0. When an operation is initiated, the current status of the operation can be read in MII\_STATUS. The fields MII\_STATUS.MIIM\_STAT\_PENDING\_RD and MII\_STATUS.MIIM\_STAT\_PENDING\_WR can be used to poll for completion of the operation. For a read operation, the read data is available in MII\_DATA\_MIIM\_DATA\_RDDATA after completion of the operation. The value of MII\_DATA.MIIM\_DATA\_RDDATA is only valid if MII\_DATA.MIIM\_DATA\_SUCCESS indicates no read errors. The MIIM controller contains a small command FIFO. Additional MIIM commands can be queued as long as MII\_STATUS.MIIM\_STAT\_OPR\_PEND is cleared. Care must be taken with read operations, because multiple queued read operations will overwrite MII\_DATA.MIIM\_DATA\_RDDATA. Note: A typical software implementation will never queue read operations, because the software needs read data before progressing the state of the software. In this case, MIIM\_STATUS.MIIM\_STAT\_OPR\_PEND is checked before issuing MIIM read or write commands, for read operations MII\_STATUS.MIIM\_STAT\_BUSY is checked before returning read result. By default, the MIIM controller operates in Clause 22 mode. To access Clause 45 compatible PHYs, MII\_CFG.MIIM\_ST\_CFG\_FIELD and MII\_CMD.MIIM\_CMD\_OPR\_FIELD must be set according to Clause 45 mode of operation. #### 4.8.7.3 PHY Scanning The MIIM controller can be configured to continuously read certain PHY registers and detect if the read value is different from an expected value. If a difference is detected, a special sticky bit register is set or a CPU interrupt is generated, or both. For example, the controller can be programmed to read the status registers of one or more PHYs and detect if the Link Status changed since the sticky register was last read. The reading of the PHYs is performed sequentially with the low and high PHY numbers specified in MII\_SCAN\_0 as range bounds. The accessed address within each of the PHYs is specified in MII\_CMD.MIIM\_CMD\_REGAD. The scanning begins when a 0x1 is written to MII\_CMD.MIIM\_CMD\_SCAN and a read operation is specified in MII\_CMD.MIIM\_CMD\_OPR\_FIELD. Setting MII\_CMD.MIIM\_CMD\_SINGLE\_SCAN stops the scanning after all PHYs have been scanned one time. The remaining fields of MII\_CMD register are not used when scanning is enabled. The expected value for the PHY register is set in MII\_SCAN\_1.MIIM\_SCAN\_EXPECT. The expected value is compared to the read value after applying the mask set in MII\_SCAN\_1.MIIM\_SCAN\_MASK. To don't-care a bit-position, write a 0 to the mask. If the expected value for a bit position differs from the read value during scanning, and the mask register has a 1 for the corresponding bit, a mismatch for the PHY is registered. The scan results from the most recent scan can be read in MII\_SCAN\_LAST\_RSLTS. The register contains one bit for each of the possible 32 PHYs. A mismatch during scanning is indicated by a 0. MII\_SCAN\_LAST\_RSLTS\_VLD will indicate for each PHY if the read operation performed during the scan was successful. The sticky-bit register MII\_SCAN\_RSLTS\_STICKY has the mismatch bit set for all PHYs that had a mismatch during scanning since the last read of the sticky-bit register. When the register is read, its value is reset to all-ones (no mismatches). # 4.8.7.4 MII Management Interrupt The MII management controllers can generate interrupts during PHY scanning. Each MII management controller has a separate interrupt signal to the interrupt controller. Interrupt is asserted when one or more PHYs have a mismatch during scan. The interrupt is cleared by reading the MII\_SCAN\_RSLTS\_STICKY register, which resets all MII\_SCAN\_RSLTS\_STICKY indications. #### 4.8.8 **GPIO Controller** This section provides information about the use of GPIO pins. The following table lists the registers associated with GPIO. | Register | Description | |-----------------------------|------------------------------------------| | DEVCPU_GCB::GPIO_OUT | Value to drive on GPIO outputs | | DEVCPU_GCB::GPIO_OUT_SET | Atomic set of bits in GPIO_OUT | | DEVCPU_GCB::GPIO_OUT_CLR | Atomic clear of bits in GPIO_OUT | | DEVCPU_GCB::GPIO_IN | Current value on the GPIO pins | | DEVCPU_GCB::GPIO_OE | Enable of GPIO output mode (drive GPIOs) | | DEVCPU_GCB::GPIO_ALT | Enable of overlaid GPIO functions | | DEVCPU_GCB::GPIO_INTR | Interrupt on changed GPIO value | | DEVCPU_GCB::GPIO_INTR_ENA | Enable interrupt on changed GPIO value | | DEVCPU_GCB::GPIO_INTR_IDENT | Currently interrupting sources | | DEVCPU_GCB::GPIO_SD_MAP | Mapping of parallel signal detects | The GPIO pins are individually programmable. GPIOs are inputs by default and can be individually changed to outputs through GPIO\_OE. The value of the GPIO pins is reflected in the GPIO\_IN register. GPIOs that are in output mode are driven to the value specified in GPIO\_OUT. In a system where multiple different CPU threads (or different CPUs) may work on the GPIOs at the same time, the GPIO\_OUT\_SET and GPIO\_OUT\_CLR registers provide a way for each thread to safely control the output value of individual GPIOs, without having to implement locked regions and semaphores. The GPIO\_ALT registers are only reset by external reset to the device. This means that software reset of the DEVCPU\_GCB is possible without affecting the mapping of overlaid functions on the GPIOs. #### 4.8.8.1 **GPIO Overlaid Functions** Most of the GPIO pins have overlaid (alternative) functions that can be enabled through replicated GPIO ALT registers. To enable a particular GPIO pin with the alternate function, set the G\_ALT[n] register field in the replicated registers as follows: - Overlaid mode 1, set GPIO\_ALT[1][n], GPIO\_ALT[0][n] = 1. - Overlaid mode 2, set GPIO ALT[1][n], GPIO ALT[0][n] = 2. Normal GPIO mode, set GPIO\_ALT[1][n], GPIO\_ALT[0][n] = 0. When the MIIM slave mode is enabled through the VCore\_CFG strapping pins, specific GPIO pins are overtaken and used for the MIIM slave interface. During reset, the VCore\_CFG interface is sampled and used for VCore configuration. After reset, the device is released, and the GPIOs can be used for output or inputs. For more information, see VCore-III Configurations, page 309. The following table maps the GPIO pins and available overlaid functions. Table 249 • GPIO Overlaid Functions | Name | Overlaid Function 1 | Overlaid Function 2 | Overlaid Function 3 | Configuration or Interface | |---------|---------------------|---------------------|---------------------|----------------------------| | GPIO_0 | SG0_CLK | | | | | GPIO_1 | SG0_DO | | | REFCLK2_CONF0 | | GPIO_2 | SG0_DI | | | | | GPIO_3 | SG0_LD | | | | | GPIO_4 | IRQ0_IN | IRQ0_OUT | TWI_SCL_M0 | | | GPIO_5 | IRQ1_IN | IRQ1_OUT | TWI_SCL_M1 | | | GPIO_6 | UART_RXD | | | | | GPIO_7 | UART_TXD | | | REFCLK2_CONF1 | | GPIO_8 | SPI_nCS1 | SFP0_SD | TWI_SCL_M2 | | | GPIO_9 | PCI_Wake | SFP1_SD | SPI_nCS2 | | | GPIO_10 | PTP_0 | SFP2_SD | TWI_SCL_M3 | | | GPIO_11 | PTP_1 | SFP3_SD | TWI_SCL_M4 | | | GPIO_12 | REF_CLK0 | SFP4_SD | TWI_SCL_M5 | | | GPIO_13 | REF_CLK1 | SFP5_SD | TWI_SCL_M6 | | | GPIO_14 | REF_CLK2 | IRQ0_OUT | SPI_nCS3 | | | GPIO_15 | REF_CLK3 | IRQ1_OUT | SPI_nCS4 | | | GPIO_16 | TACHO | SFP6_SD | SPI_nCS5 | | | GPIO_17 | PWM | PLL_STAT0 | TWI_SCL_M7 | | | GPIO_18 | PTP_2 | SFP7_SD | SPI_nCS6 | | | GPIO_19 | PTP_3 | SFP8_SD | SPI_nCS7 | | | GPIO_20 | UART2_RXD | SFP9_SD | SPI_nCS8 | | | GPIO_21 | UART2_TXD | | | REFCLK2_CONF2 | | GPIO_22 | MIIM1_MDC | SFP10_SD | TWI2_SDA | MIIM_SLV_MDC | | GPIO_23 | MIIM1_MDIO | SFP11_SD | TWI2_SCL | MIIM_SLV_MDIO | | GPIO_24 | TWI_SDA | | | | | GPIO_25 | TWI_SCL | SFP12_SD | TWI_SCL_M8 | | | GPIO_26 | TWI_SCL_M9 | SFP13_SD | SPI_nCS9 | | | GPIO_27 | TWI_SCL_M10 | SFP14_SD | SPI_nCS10 | | | GPIO_28 | TWI_SCL_M11 | SFP15_SD | SPI_nCS11 | | | GPIO_29 | TWI_SCL_M12_AD | | | REFCLK2_SEL | | GPIO_30 | TWI_SCL_M13_AD | | | REFCLK0_CONF0 | Table 249 • GPIO Overlaid Functions (continued) | Name | Overlaid Function 1 | Overlaid Function 2 | Overlaid Function 3 | Configuration or<br>Interface | |---------|---------------------|---------------------|---------------------|-------------------------------| | GPIO_31 | TWI_SCL_M14_AD | | | REFCLK0_CONF1 | | GPIO_32 | TWI_SCL_M15_AD | | | REFCLK0_CONF2 | | GPIO_33 | RCVRD_CLK0 | | | VCORE_CFG0 | | GPIO_34 | RCVRD_CLK1 | | | VCORE_CFG1 | | GPIO_35 | RCVRD_CLK2 | PLL_STAT1 | | VCORE_CFG2 | | GPIO_36 | RCVRD_CLK3 | PLL_STAT2 | | VCORE_CFG3 | # 4.8.8.2 **GPIO** Interrupt The GPIO controller continually monitors all inputs and set bits in the GPIO\_INTR register whenever a GPIO changes its input value. By enabling specific GPIO pins in the GPIO\_INTR\_ENA register, a change indication from GPIO\_INTR is allowed to propagate (as GPIO interrupt) from the GPIO controller to the VCore-III Interrupt Controller. The currently interrupting sources can be read from GPIO\_INTR\_IDENT, this register is the result of a binary AND between the GPIO\_INTR and GPIO\_INTR\_ENA registers. # 4.8.8.3 Parallel Signal Detect The GPIO controller has 16 programmable parallel signal detects, SFP0\_SD through SFP15\_SD. When parallel signal detect is enabled for a front port index, it overrides the signal-detect/loss-of-signal value provided by the serial GPIO controller. To enable parallel signal detect n, first configure which port index from the serial GPIO controller that must be overwritten by setting GPIO\_SD\_MAP[n].G\_SD\_MAP, then enable the SFPn\_SD function on the GPIOs. The following table lists parallel signal detect pins, which are overlaid on GPIOs. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 250 • Parallel Signal Detect Pins | Register | I/O | Description | |---------------|-----|---------------------------| | SFP0_SD/GPIO | I | Parallel signal detect 0 | | SFP1_SD/GPIO | I | Parallel signal detect 1 | | SFP2_SD/GPIO | I | Parallel signal detect 2 | | SFP3_SD/GPIO | I | Parallel signal detect 3 | | SFP4_SD/GPIO | I | Parallel signal detect 4 | | SFP5_SD/GPIO | I | Parallel signal detect 5 | | SFP6_SD/GPIO | I | Parallel signal detect 6 | | SFP7_SD/GPIO | I | Parallel signal detect 7 | | SFP8_SD/GPIO | I | Parallel signal detect 8 | | SFP9_SD/GPIO | I | Parallel signal detect 9 | | SFP10_SD/GPIO | I | Parallel signal detect 10 | | SFP11_SD/GPIO | I | Parallel signal detect 11 | | SFP12_SD/GPIO | I | Parallel signal detect 12 | | SFP13_SD/GPIO | I | Parallel signal detect 13 | | SFP14_SD/GPIO | I | Parallel signal detect 14 | Table 250 • Parallel Signal Detect Pins (continued) | Register | I/O | Description | |---------------|-----|---------------------------| | SFP15_SD/GPIO | I | Parallel signal detect 15 | # 4.8.9 Serial GPIO Controller The device features one serial GPIO (SIO) controller. By using a serial interface, the SIO controller significantly extends the number of available GPIOs with a minimum number of additional pins on the device. The primary purpose of the SIO controller is to connect control signals from SFP modules and to act as an LED controller. Each SIO controller supports up to 128 serial GPIOs (SGPIOs) organized into 32 ports, with four SGPIOs per port. The following table lists the registers associated with the SIO controller. Table 251 • SIO Registers | Register | Description | |-------------------------------|----------------------------------------| | DEVCPU_GCB::SIO_INPUT_DATA | Input data | | DEVCPU_GCB::SIO_CFG | General configuration | | DEVCPU_GCB::SIO_CLOCK | Clock configuration | | DEVCPU_GCB::SIO_PORT_CFG | Output port configuration | | DEVCPU_GCB::SIO_PORT_ENA | Port enable | | DEVCPU_GCB::SIO_PWM_CFG | PWM configuration | | DEVCPU_GCB::SIO_INTR_POL | Interrupt polarity | | DEVCPU_GCB::SIO_INTR_RAW | Raw interrupt status | | DEVCPU_GCB::SIO_INTR_TRIGGER0 | Interrupt trigger mode 0 configuration | | DEVCPU_GCB::SIO_INTR_TRIGGER1 | Interrupt trigger mode 1 configuration | | DEVCPU_GCB::SIO_INTR | Currently interrupting SGPIOs | | DEVCPU_GCB::SIO_INTR_ENA | Interrupt enable | | DEVCPU_GCB::SIO_INTR_IDENT | Currently active interrupts | The following table lists the SIO controller pins, which are overlaid functions on GPIO pins. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 252 • SIO Controller Pins | Pin Name | I/O | Description | |--------------|-----|---------------------------------------------------------------------------| | SG0_CLK/GPIO | 0 | SIO clock output, frequency is configurable using SIO_CLOCK.SIO_CLK_FREQ. | | SG0_DO/GPIO | 0 | SIO data output. | | SG0_DI/GPIO | I | SIO data input. | | SG0_LD/GPIO | 0 | SIO load data, polarity is configurable using SIO_CFG.SIO_LD_POLARITY. | The SIO controller works by shifting SGPIO values out on SG0\_DO though a chain of shift registers on the PCB. After shifting a configurable number of SGPIO bits, the SIO controller asserts SG0\_LD, which causes the shift registers to apply the values of the shifted bits to outputs. The SIO controller can also read inputs while shifting out SGPIO values on SG0\_DO by sampling the SG0\_DI input. The values sampled on SG0\_DI are made available to software. If the SIO controller is only used for outputs, the use of the load signal is optional. If the load signal is omitted, simpler shift registers (without load) can be used, however, the outputs of these registers will toggle during shifting. When driving LED outputs, it is acceptable that the outputs will toggle when SGPIO values are updated (shifted through the chain). When the shift frequency is fast, the human eye is not able to see the shifting though the LEDs. The number of shift registers in the chain is configurable. The SIO controller allows enabling of individual ports through SIO\_PORT\_ENA; only enabled ports are shifted out on SG0\_DO. Ports that are not enabled are skipped during shifting of GPIO values. **Note:** SIO\_PORT\_ENA allows skipping of ports in the SGPIO output stream that are not in use. The number of GPIOs per (enabled) port is configurable as well, through SIO\_CFG.SIO\_PORT\_WIDTH this can be set to 1, 2, 3, or 4 bits. The number of bits per port is common for all enabled ports, so the number of shift registers on the PCB must be equal to the number of enabled ports times the number of SGPIOs per port. Enabling of ports and configuration of SGPIOs per port applies to both output mode and input mode. Unlike a regular GPIO port, a single SGPIO position can be used both as output and input. That is, software can control the output of the shift register AND read the input value at the same time. Using SGPIOs as inputs requires load-capable shift registers. Regular shift registers and load-capable shift-registers can be mixed, which is useful when driving LED indications for integrated PHYs while supporting reading of link status from SFP modules, for example. Figure 127 • SIO Timing The SGPIO values are output in bursts followed by assertion of the SG0\_LD signal. Values can be output as a single burst or as continuous bursts separated by a configurable burst gap. The maximum length of a burst is 32 × 4 data cycles. The burst gap is configurable in steps of approximately 1 ms, from 0 ms to 33 ms through SIO\_CFG.SIO\_BURST\_GAP\_DIS and SIO\_CFG.SIO\_BURST\_GAP. A single burst is issued by setting SIO\_CFG.SIO\_SINGLE\_SHOT. The field is automatically cleared by hardware when the burst is finished. To issue continuous bursts, set SIO\_CFG.SIO\_AUTO\_REPEAT. The SIO controller continues to issue bursts until SIO\_CFG.SIO\_AUTO\_REPEAT is cleared. SGPIO output values are configured in SIO\_PORT\_CFG.BIT\_SOURCE. The input value is available in SIO\_INPUT\_DATA. The following illustration shows what happens when the number of SGPIOs per port is configured to two (through SIO\_CFG.SIO\_PORT\_WIDTH). Disabling ports (through SIO\_PORT\_ENA) is handled in the same way as disabling the SGPIO ports. Figure 128 • SIO Timing with SGPIOs Disabled The frequency of the SG0\_CLK clock output is configured through SIO\_CLOCK.SIO\_CLK\_FREQ. The SG0\_LD output is asserted after each burst; this output is asserted for a period of 25 ns to 30 ns. The polarity of SG0\_LD is configured in SIO\_CFG.SIO\_LD\_POLARITY. The SGO\_LD output can be used to ensure that outputs are stable when serial data is being shifted through the registers. This can be done by using the SGO\_LD output to shift the output values into serial-to-parallel registers after the burst is completed. If serial-to-parallel registers are not used, the outputs will toggle while the burst is being shifted through the chain of shift registers. A universal serial-to-parallel shift register outputs the data on a positive-edge load signal, and a universal parallel-to-serial shift register shifts data when the load pin is high, so one common load signal can be used for both input and output serial parallel conversion. The assertion of SG0\_LD happens after the burst to ensure that after power up, the single burst will result in well-defined output registers. Consequently, to sample input values one time, two consecutive bursts must be issued. The first burst results in the input values being sampled by the serial-to-parallel registers, and the second burst shifts the input values into the SIO controller. The port order required in the serial bitstream depends on the physical layout of the shift register chain. Often the input and output port orders must be opposite in the serial streams. The port order of the input and output bitstream is independently configurable in SIO\_CFG.SIO\_REVERSE\_INPUT and SIO\_CFG.SIO\_REVERSE\_OUTPUT. The following illustration shows the port order. Figure 129 • SGPIO Output Order #### 4.8.9.1 Output Modes The output mode of each SGPIO can be individually configured in SIO\_PORT\_CFG.BIT\_SOURCE. The SIO controller features three output modes: - Static - Blink - · Link activity The output mode can additionally be modified with PWM (SIO\_PORT\_CFG.PWM\_SOURCE) and configurable polarity (SIO\_PORT\_CFG.BIT\_POLARITY). **Static Mode** The static mode is used to assign a fixed value to the SGPIO, for example, fixed 0 or fixed 1. **Blink Mode** The blink mode makes the SGPIO blink at a fixed rate. The SIO controller features two blink modes that can be set independently. A SGPIO can then be configured to use either blink mode 0 or blink mode 1. The blink outputs are configured in SIO\_CFG.SIO\_BMODE\_0 and SIO\_CFG.SIO\_BMODE\_1. To synchronize the blink modes between different devices, reset the blink counter using SIO\_CFG.SIO\_BLINK\_RESET. All the SIO controllers on a device must be reset at same time to maintain the synchronization. The burst toggle mode of blink mode 1 toggles the output with every burst. Table 253 • Blink Modes | Register | Description | |--------------|--------------------------------------------------------------------------------------------------------------| | Blink Mode 0 | 0: 20 Hz blink frequency<br>1: 10 Hz blink frequency<br>2: 5 Hz blink frequency<br>3: 2.5 Hz blink frequency | | Blink Mode 1 | 0: 20 Hz blink frequency<br>1: 10 Hz blink frequency<br>2: 5 Hz blink frequency<br>3: Burst toggle | **Link Activity Mode** The link activity mode makes the output blink when there is activity on the port module (Rx or Tx). The following table lists the mapping between the SIO port number and port modules. Table 254 • SIO Controller Port Mapping | SIO Port | SG0 Mapping | |----------|----------------| | 0 | Port module 0 | | 1 | Port module 1 | | 2 | Port module 2 | | 3 | Port module 3 | | 4 | Port module 4 | | 5 | Port module 5 | | 6 | Port module 6 | | 7 | Port module 7 | | 8 | Port module 8 | | 9 | Port module 9 | | 10 | Port module 10 | | 11 | Free | | 12 | Free | | 13 | Free | | 14 | Free | | 15 | Free | | 16 | Free | | 17 | Free | Table 254 • SIO Controller Port Mapping (continued) | SG0 Mapping | |-------------| | Free | | The link activity mode uses an envelope signal to gate the selected blinking pattern (blink mode 0 or blink mode 1). When the envelope signal is asserted, the output blinks, and when the envelope pattern is deasserted, the output is turned off. To ensure that even a single packet makes a visual blink, an activity pulse from the port module is extended to minimum 100 ms. If another packet is sent while the envelope signal is asserted, the activity pulse is extended by another 100 ms. The polarity of the link activity modes can be set in SIO\_PORT\_CFG.BIT\_SOURCE. The following illustration shows the link activity timing. Figure 130 • Link Activity Timing #### 4.8.9.2 SIO Interrupt The SIO controller can generate interrupts based on the value of the input value of the SGPIOs. All interrupts are level sensitive. Interrupts are enabled using the two registers. Interrupts can be individually enabled for each port in SIO\_INTR\_ENA (32 bits) and in SIO\_CFG.SIO\_GPIO\_INTR\_ENA (4 bits) interrupts are enabled for the four inputs per port. In other words, SIO\_CFG.SIO\_GPIO\_INTR\_ENA is common for all 32 ports. The SIO controller has four interrupt registers that each has one bit for each of the 128 GPIOs: - SIO\_INTR\_RAW is high if the corresponding input bit is high (corrected for polarity as configured in SIO\_INTR\_POL). This register changes when the input changes. - SIO\_INTR is high if the condition of the configured trigger mode for the bit is met. The trigger mode can be configured in SIO\_INTR\_TRIGGER0 and SIO\_INTR\_TRIGGER1 between level-triggered, - edge-triggered, falling-edge-triggered, and rising-edge-triggered interrupt. This register is a sticky bit vector and can only be cleared by software. A bit is cleared by writing a 1 to the bit position. - SIO\_INTR\_IDENT is the result of SIO\_INTR with the disabled interrupts (from SIO\_INTR\_ENA and SIO\_GPIO\_INTR\_ENA) removed. This register changes when SIO\_INTR or the enable registers change. The SIO controller has one interrupt output connected to the main interrupt controller, which is asserted when one or more interrupts in SIO\_INTR\_IDENT are active. To determine which SGPIO is causing the interrupt, the CPU must read this register. The interrupt output remains high until all interrupts in SIO\_INTR\_IDENT are cleared (either by clearing SIO\_INTR or disabling the interrupts in SIO\_INTR\_ENA and SIO\_GPIO\_INTR\_ENA). # 4.8.9.3 Loss of Signal Detection The SIO controller can propagate loss of signal detection inputs directly to the signal detection input of the port modules. This is useful when, for example, SFP modules are connected to the device. The mapping between SIO ports and port modules is the same as for the link activity outputs; port 0 is connected to port module 0, port 1 is connected to port module 1, and so on. The value of SGPIO bit 0 of each SIO port is forwarded directly to the loss of signal input on the corresponding port module. The port module must enable the loss of signal input locally. Loss of signal can also be taken directly from overlaid functions on the regular GPIOs. In that case, the input from the SIO controller is ignored. The polarity of the loss of signal input is configured using SIO\_INT\_POL, meaning the same polarity must be used for loss of signal detect and interrupt. ### 4.8.10 Fan Controller The device includes a fan controller that can be used to control and monitor a system fan. A pulse width modulation (PWM) output regulates the fan speed. The fan speed is monitored using a TACHO input. The fan controller is especially powerful when combined with the internal temperature sensor. For more information, see Temperature Sensor, page 364. The following table lists the registers associated with the fan controller. Table 255 • Fan Controller | Register | Description | |---------------------|-------------------------| | DEVCPU_GCB::FAN_CFG | General configuration | | DEVCPU_GCB::FAN_CNT | Fan revolutions counter | The following table lists fan controller pins, which are overlaid on GPIOs. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Table 256 • Fan Controller Pins | Register | I/O | Description | | | | |------------|-----|--------------------------------------|--|--|--| | TACHO/GPIO | l | TACHO input for counting revolutions | | | | | PWM/GPIO | 0 | PWM fan output | | | | The PWM output can be configured to any of the following frequencies in FAN\_CFG.PWM\_FREQ: 10 Hz, 20 Hz, 40 Hz, 60 Hz, 80 Hz, 100 Hz, 120 Hz, or 25 kHz. The low frequencies can be used for driving three-wire fans using a FET/transistor. The 25 kHz frequency can be used for four-wire fans that use the PWM input internally to control the fan. The duty cycle of the PWM output is programmable from 0% to 100%, with 8-bit accuracy. The polarity of the output can be controlled by FAN\_CFG.INV\_POL, so a duty-cycle of 100%, for example, can be either always low or always high. The PWM output pin can be configured to act as a normal output or as an open-collector output, where the output value of the pin is kept low, but the output enable is toggled. The open-collector output mode is enabled by setting FAN CFG.PWM OPEN COL ENA. **Note:** By using open-collector mode, it is possible to externally pull-up to a higher voltage than the maximum GPIO I/O supply. The GPIO pins are 3.3V-tolerable. The speed of the fan is measured using a 16-bit counter that counts the rising edges on the TACHO input. A fan usually gives one to four pulses per revolution, depending on the fan type. The counter value is available in the FAN\_CNT register. Depending on the value of FAN\_CFG.FAN\_STAT\_CFG, the FAN\_CNT register is updated in two different ways: - If FAN\_CFG.FAN\_STAT\_CFG is set, the FAN\_CNT register behaves as a 16-bit wrapping counter that shows the total number of ticks on the TACHO input. - If FAN\_CFG.FAN\_STAT\_CFG is cleared, the FAN\_CNT register is updated one time per second with the number of TACHO ticks received during the last second. Optionally, the TACHO input is gated by the polarity-corrected PWM output by setting FAN\_CFG.GATE\_ENA, so that only TACHO pulses received while the polarity corrected PWM output is high are counted. Glitches on the TACHO input can occur right after the PWM output goes high. As a result, the gate signal is delayed by 10 $\mu$ s when PWM goes high. There is no delay when PWM goes low, and the length of the delay is not configurable. Software must read the counter value in FAN\_CNT and calculate the RPM of the fan. An example of how to calculate the RPM of the fan is if the fan controller is configured to 100 Hz and a 20% duty cycle, each PWM pulse is high in 2 ms and low in 8 ms. If gating is enabled, the gating of the TACHO input is open in 1.99 ms and closed in 8.01 ms. If the fan is turning with 100 RPMs and gives two TACHO pulses per revolution, it will ideally give 200 pulses per minute. TACHO pulses are only counted in 19.99% of the time, so it will give $200 \times 0.1999 = 39.98$ pulses per minute. If the additional 10 $\mu$ s gating time is ignored, the counter value is multiplied by 2.5 to get the RPM value, because there is a 20% duty cycle with two TACHO pulses per revolution. By multiplying with 2.5, the RPM value is calculated to 99.95, which is 0.05% off the correct value (due to the 10 $\mu$ s gating time). # 4.8.11 Temperature Sensor This section provides information about the on-die temperature sensor. When enabled the temperature sensor logic will continually monitor the temperature of the die and make this available for software. The following table lists the registers associated with the temperature monitor. Table 257 • Temperature Sensor Registers | Register | Description | |------------------------|--------------------| | HSIO::TEMP_SENSOR_CTRL | Enabling of sensor | | HSIO::TEMP_SENSOR_STAT | Temperature value | The temperature sensor is enabled by setting TEMP\_SENSOR\_CTRL.SAMPLE\_ENA. The temperature sensor then samples the temperature every 500 µs and shows the current temperature in TEMP\_SENSOR\_STAT. The formula for converting TEMP field value to centigrade temperature is: Temp (°C) = 177.4 - 0.8777 × TEMP\_SENSOR\_STATE.TEMP It takes approximately 500 µs after setting SAMPLE\_ENA until the first temperature sample is ready. The TEMP SENSOR STAT.TEMP VALID field is set when the temperature value is available. # 4.8.12 Memory Integrity Monitor Soft errors happen in all integrated circuits as a result of natural alpha decay, cosmic radiation, or electrical disturbances in the environment in which the device operates. The chance of soft errors happening in a memory (RAM) is higher than for flip-flop based logic, because the memory structures are physically small and changes require less outside force than in flip flops. The device has built-in protection from soft errors by using error correcting code (ECC) on critical memories. In addition, the device allows monitoring and reporting of soft error events. The following table lists the registers associated with the memory integrity monitor. Table 258 • Integrity Monitor Registers | Register | Description | |--------------------------|-------------------------------------------------| | DEVCPU_GCB::MEMITGR_CTRL | Trigger monitor state changes. | | DEVCPU_GCB::MEMITGR_STAT | Current state of the monitor and memory status. | | DEVCPU_GCB::MEMITGR_INFO | Shows indication when in DETECT state. | | DEVCPU_GCB::MEMITGR_IDX | Shows memory index when in DETECT state. | | DEVCPU_GCB::MEMITGR_DIV | Monitor speed. | The memory integrity monitor looks for memory soft-error indications. Correctable (single bit) and non-correctable (multibit or parity) indications are detected during memory read and can be reported to software by the ITGR software interrupt. For information about how to enable the this interrupt, see Interrupt Controller, page 367. The memory integrity monitor operates in three different states: IDLE, LISTEN, and DETECT. After a reset, the monitor starts in the IDLE state. **IDLE** The monitor is deactivated and in quiet mode. In IDLE mode, the memories still correct, detect, and store indications locally, but they are not able to report indications to the monitor. **LISTEN** In the LISTEN state, the monitor looks for indications in the memories. MEMITGR STAT.INDICATION is set (and interrupt is asserted) when indications are detected. **DETECT** DETECT state is used when indications are read from the memories. It means that a valid indication is available in MEMITGR INFO and the corresponding memory index in MEMITGR IDX. The current state of the monitor is reported in MEMITGR\_STAT.MODE\_IDLE, MEMITGR\_STAT.MODE\_DETECT, and MEMITGR\_STAT.MODE\_LISTEN. Software initiates transitions between states by setting the one-shot MEMITGR\_CTRL.ACTIVATE field. It may take some time to transition from one state to the next. The MEMITGR\_CTR.ACTIVATE field is not cleared before the next state is reached (also the MEMITGR\_STAT.MODE\_BUSY field is set while transitioning between states). Figure 131 • Monitor State Diagram The first time after reset that MEMITGR\_CTRL.ACTIVATE is set, the monitor resets the detection logic in all the memories and transitions directly from IDLE to LISTEN state. Before setting MEMITGR\_CTRI.ACTIVATE for the first time, speed up the monitor by setting MEMITGR\_DIV.MEM\_DIV to the value specified in the registers list. The memories of the PCIe MAC are clock-gated and bypassed when PCIe interface is not enabled; enable monitoring of PCIe MAC memories by setting ICPU\_CFG::PCIE\_CFG.MEM\_RING\_CORE\_ENA. This field must not be set when PCIe interface is not enabled. To read out indications, first transition from LISTEN to IDLE, then continue transitioning until the LISTEN state is reached. Every time the monitor ends up in the DETECT state, an indication is available in the MEMITGR\_INFO and MEMITGR\_IDX registers. Each memory stores one indication. Indications are cleared when they are read by way of the monitor. Each indication contains four flags and one memory address. - The MEM\_ERR flag is set when a non-correctable upset is detected and the corresponding address is available in MEM\_ADDR. - The MEM\_ERR\_OVF flag is set when a non-correctable upset is detected for which address could not be stored. - The MEM\_COR flag is set when a correctable upset is detected and the corresponding address is available in MEM\_ADDR. - The MEM\_COR\_OVF flag is set when a correctable upset is detected for which address could not be stored. Information about non-correctable upsets is prioritized over correctable upsets. Address can only be saved when the monitor is in LISTEN mode. The following flowchart shows how the detection logic sets flags and address. Figure 132 • Memory Detection Logic If the MEM\_ERR\_OVF or MEM\_COR\_OVF flag is set, at least one event has occurred for which the address could not be stored. The following table shows ECC-enabled memories in the device, their index, and the recommended approach for handling indications. If the controller reports an index that is not mentioned in the list, the recommended approach is to reboot the device. Table 259 • Memories with Integrity Support | Index | Description | |--------|-------------------------------------------------------------------------| | Others | For unlisted indexes, the recommended approach is to reboot the device. | The VCore-III CPU implements parity protection of all VCore-III cache structures as specified by MIPS architecture. For information about how to enable parity protection and interrupt on parity upsets, see the MIPS documentation. Reading from uninitialized memory locations has a high plausibility of triggering non correctable or correctable indications. This is useful when developing integrity monitor software driver. For example, powering up a system without initializing the VCAPs and reading actions and sticky bits will trigger monitor indications. Note that the contents of memories are not changed by device reset, so power cycle is needed to reset the memories. # 4.8.13 Interrupt Controller This section provides information about the VCore-III interrupt controller. The following table lists the registers associated with the interrupt controller. Table 260 • Interrupt Controller Registers | Register | Description | |----------------------------|---------------------------------------------------------------------| | ICPU_CFG::INTR_RAW | Current value of interrupt inputs | | ICPU_CFG::INTR_BYPASS | Forces non-sticky function | | ICPU_CFG::INTR_TRIGGER | Configures edge or level sensitive events | | ICPU_CFG::INTR_FORCE | Forces events (for software debug) | | ICPU_CFG::INTR_STICKY | Currently logged events | | ICPU_CFG::INTR_ENA | Enables interrupt sources | | ICPU_CFG::INTR_ENA_CLR | Atomic clear of bits in INTR_ENA | | ICPU_CFG::INTR_ENA_SET | Atomic set of bits in INTR_ENA | | ICPU_CFG::INTR_IDENT | Currently enabled and interrupting sources | | ICPU_CFG::DST_INTR_MAP | Mapping of interrupt sources to destinations | | ICPU_CFG::DST_INTR_IDENT | Currently enabled, mapped, and interrupting sources per destination | | ICPU_CFG::DEV_INTR_POL | Polarity of module interrupt inputs | | ICPU_CFG::DEV_INTR_RAW | Current value of module interrupts | | ICPU_CFG::DEV_INTR_BYPASS | Forces non-sticky function for module interrupts | | ICPU_CFG::DEV_INTR_TRIGGER | Configures edge or level sensitive events for module interrupts | | ICPU_CFG::DEV_INTR_STICKY | Currently logged module interrupt events | | ICPU_CFG::DEV_INTR_ENA | Enables module interrupts | | ICPU_CFG::DEV_INTR_IDENT | Currently interrupting and enabled module interrupts | | ICPU_CFG::EXT_SRC_INTR_POL | Polarity of external interrupt inputs. | | ICPU_CFG::EXT_DST_INTR_POL | Polarity of external interrupt outputs. | | ICPU_CFG::EXT_DST_INTR_DRV | Drive mode for external interrupt outputs | The interrupt controller maps interrupt sources from VCore-III and switch core blocks, port modules, and external interrupt inputs to four interrupt destinations. Two interrupt destinations are mapped to the VCore-III CPU, and two can be transmitted from the device using the overlaid functions on GPIOs or using PCIe inband interrupt signaling. The following table lists the available interrupt sources in the device. Table 261 • Interrupt Sources | Source Name | Description | | | | | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | DEV | Aggregated port module interrupt. This interrupt is asserted if there is an active and enabled interrupt from any of the device's port modules. See Port Module Interrupts. This interrupt has bit index 0 in INTR_* and DST_INTR_* registers. | | | | | | EXT_SRC0 | External interrupt source 0. See External Interrupts. This interrupt has bit index 1 in INTR_* and DST_INTR_* registers. | | | | | | EXT_SRC1 | External interrupt source 1. See External Interrupts. This interrupt has bit index 2 in INTR_* and DST_INTR_* registers. | | | | | | TIMER0 | Timer 0 interrupt. See Timers. This interrupt has bit index 3 in INTR_* and DST_INTR_* registers. | | | | | Table 261 • Interrupt Sources (continued) | Source Name | Description | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | TIMER1 | Timer 1 interrupt. See Timers. This interrupt has bit index 4 in INTR_* and DST_INTR_* registers. | | TIMER2 | Timer 2 interrupt. See Timers. This interrupt has bit index 5 in INTR_* and DST_INTR_* registers. | | UART | UART interrupt. See UART Interrupt. This interrupt has bit index 6 in INTR_* and DST_INTR_* registers. | | UART2 | UART2 interrupt. See UART Interrupt. This interrupt has bit index 7 in INTR_* and DST_INTR_* registers. | | TWI | TWI interrupt. See Two-Wire Serial Interface Interrupt. This interrupt has bit index 8 in INTR_* and DST_INTR_* registers. | | TWI2 | TWI2 interrupt. See Two-Wire Serial Interface Interrupt. This interrupt has bit index 9 in INTR_* and DST_INTR_* registers. | | SIMC | Serial Master Controller interrupt. See Serial Master Controller Interrupt. This interrupt has bit index 10 in INTR_* and DST_INTR_* registers. | | SW0 | Software interrupt 0. See Mailbox and Semaphores. This interrupt has bit index 11 in INTR_* and DST_INTR_* registers. | | SW1 | Software interrupt 1. See Mailbox and Semaphores. This interrupt has bit index 12 in INTR_* and DST_INTR_* registers. | | SGPIO0 | Serial GPIO interrupt 0. See SIO Interrupt. This interrupt has bit index 13 in INTR_* and DST_INTR_* registers. | | GPIO | Parallel GPIO interrupt. See GPIO Interrupt. This interrupt has bit index 14 in INTR_* and DST_INTR_* registers. | | MIIMO | MIIM Controller 0 interrupt. See MII Management Interrupt. This interrupt has bit index 15 in INTR_* and DST_INTR_* registers. | | MIIM1 | MIIM Controller 1 interrupt. See MII Management Interrupt. This interrupt has bit index 16 in INTR_* and DST_INTR_* registers. | | FDMA | Frame DMA interrupt, see FDMA Events and Interrupts. This interrupt has bit index 17 in INTR_* and DST_INTR_* registers. | | ANA | Analyzer interrupt. See Interrupt Handling. This interrupt has bit index 18 in INTR_* and DST_INTR_* registers. | | PTP_RDY | Time stamp ready interrupt. See Hardware Time Stamping Module. This interrupt has bit index 19 in INTR_* and DST_INTR_* registers. | | PTP_SYNC | PTP synchronization interrupt. See Master Timer. This interrupt has bit index 20 in INTR_* and DST_INTR_* registers. | | ITGR | Memory integrity interrupt. See Memory Integrity Monitor, page 364. This interrupt has bit index 21 in INTR_* and DST_INTR_* registers. | | XTR_RDY | Extraction data ready interrupt. See Frame Extraction. This interrupt has bit index 22 in INTR_* and DST_INTR_* registers. | | INJ_RDY | Injection ready interrupt. See Frame Injection. This interrupt has bit index 23 in INTR_* and DST_INTR_* registers. | | PCIE | PCIe interrupt. See Power Management. This interrupt has bit index 24 in INTR_* and DST_INTR_* registers. | | OAM_VOP | OAM/VOP interrupt. See Interrupt Controller. This interrupt has bit index 25 in INTR_* and DST_INTR_* registers. | Table 261 • Interrupt Sources (continued) | Source Name | Description | | | | |-------------|---------------------------------------------------------------------|--|--|--| | DPLL | DPLL Timing interrupt. See Interrupt Controller. | | | | | | This interrupt has bit index 26 in INTR_* and DST_INTR_* registers. | | | | The following table lists the available interrupt destinations in the device. Table 262 • Interrupt Destinations | <b>Destination Name</b> | Description | |-------------------------|----------------------------------------------------------------------------------------------------------------------------| | CPU0 | Interrupt 0 to VCore-III CPU. This interrupt has replication index 0 in DST_INTR_* registers. | | CPU1 | Interrupt 1 to VCore-III CPU. This interrupt has replication index 1 in DST_INTR_* registers. | | EXT_DST0 | External interrupt destination 0. See External Interrupts. This interrupt has replication index 2 in DST_INTR_* registers. | | EXT_DST1 | External interrupt destination 1. See External Interrupts. This interrupt has replication index 3 in DST_INTR_* registers. | All interrupts, events, and indications inside in the interrupt controller are active high. If an interrupt source supports polarity correction, it is applied before going into the interrupt controller. If an interrupt destination supports polarity correction, it is applied after leaving the interrupt controller. ## 4.8.13.1 Interrupt Source Configuration Interrupt sources are handled identically inside the interrupt controller. This section describes interrupt source n, which refers to the bit index of that interrupt source in the INTR\_\* and DST\_INTR\_\* registers. The following illustration shows the logic associated with a single interrupt source. Figure 133 • Interrupt Source Logic The current value of an interrupt source is available in INTR\_RAW.INTR\_RAW[n]. INTR\_STICKY.INTR\_STICKY[n] is set when the interrupt controller detects an interrupt. There are two detection methods: - When INTR\_TRIGGER.INTR\_TRIGGER[n] is set to level-activated, the interrupt controller continually sets INTR\_STICKY.INTR\_STICKY[n] for as long as the interrupt source is active. - When INTR\_TRIGGER.INTR\_TRIGGER[n] is set to edge-triggered, the interrupt controller only sets INTR\_STICKY.INTR\_STICKY[n] when the interrupt source changes value. - When INTR\_TRIGGER.INTR\_TRIGGER[n] is set to falling-edge-triggered, the interrupt controller only sets INTR\_STICKY.INTR\_STICKY[n] when the interrupt source changes from active to inactive value. - When INTR\_TRIGGER.INTR\_TRIGGER[n] is set to rising-edge-triggered, the interrupt controller only sets INTR\_STICKY.INTR\_STICKY[n] when the interrupt source changes from inactive to active value. Software can clear INTR\_STICKY.INTR\_STICKY[n] by writing 1 to bit n. However, the interrupt controller will immediately set this bit again if the source input is still active (when INTR\_TRIGGER is 0) or if it sees a triggering event on the source input (when INTR\_TRIGGER different from 0). The interrupt source is enabled in INTR\_ENA.INTR\_ENA[n]. When INTR\_STICKY.INTR\_STICKY[n] is set and the interrupt is enabled, the interrupt is indicated towards the interrupt destinations. For more information, see Interrupt Destination Configuration. An active and enabled interrupt source sets INTR\_IDENT.INTR\_IDENT[n]. On rare occasions it is desirable to bypass the stickiness of interrupt sources and use INTR\_RAW.INTR\_RAW[n] directly instead of INTR\_STICKY.INTR\_STICKY[n]. Set INTR\_BYPASS.INTR\_BYPASS[n] to enable bypass and ignore INTR\_STICKY and INTR\_TRIGGER configurations. **Note:** The bypass function may be useful for some software interrupt handler architectures. It should only be used for interrupt sources that are guaranteed to be sticky in the source block. For example, the GPIO interrupts that are generated from sticky bits in DEVCPU\_GCB::GPIO\_INTR may be applicable for the bypass mode. # 4.8.13.2 Interrupt Destination Configuration The four interrupt destinations are handled identically in the interrupt controller. This section describes destination d, which refers to the replication index of that interrupt in the DST\_INTR\_\* registers. The following illustration shows the logic associated with a single interrupt destination. #### Figure 134 • Interrupt Destination Logic The interrupt destination can enable individual sources for interrupt by writing a mask to DST\_INTR\_MAP[d].DST\_INTR\_MAP. When a source is enabled in DST\_INTR\_MAP then an interrupt from this source will be propagated to the interrupt destination. The currently active and enabled source interrupts for a destination can be seen by reading DST\_INTR\_IDENT[d].DST\_INTR\_IDENT. #### 4.8.13.3 Port Module Interrupts Each port module can generate an interrupt. Because there are too many modules to handle the interrupts in parallel with the other source interrupts in the INTR\_\* registers, the port module interrupts are aggregated in a separate source interrupt hierarchy before being presented to the interrupt controller source logic as the DEV source interrupt. Figure 135 • Port Module Interrupt Logic The module interrupt polarity is configurable in DEV INTR POL.DEV INTR POL[m]. DEV\_INTR\_RAW, DEV\_INTR\_TRIGGER, DEV\_INTR\_STICKY, DEV\_INTR\_BYPASS, DEV\_INTR\_ENA, and DEV\_INTR\_IDENT works in the same way as the INTR\_\* counterparts.For more information, see Interrupt Source Configuration, page 370. The final step when handling module interrupts is an aggregation of all individual module interrupts to the DEV source interrupt. #### 4.8.13.4 External Interrupts The interrupt controller supports two external source interrupts (inputs to the device) and two external destination interrupts (outputs from the device). The external interrupts are mapped to GPIOs using overlaid functions. For more information about overlaid functions on the GPIOs for these signals, see GPIO Overlaid Functions, page 355. Source and destination interrupts works independently from each other and can be used at the same time. The polarity (active high or low) of source and destination interrupts is configured in EXT\_SRC\_INTR\_POL and EXT\_DST\_INTR\_POL respectively. Table 263 • External Interrupt Pins | Register | I/O | Description | |---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRQ0_IN/GPIO | I | External Source Interrupt 0. Polarity is configured in EXT_SRC_INTR_POL.EXT_INTR_POL[0]. | | IRQ1_IN/GPIO | I | External Source Interrupt 1. Polarity is configured in EXT_SRC_INTR_POL.EXT_INTR_POL[1]. | | IRQ0_OUT/GPIO | 0 | External Destination Interrupt 0. Polarity is configured in EXT_DST_INTR_POL.EXT_INTR_POL[0]. This interrupt can also be mapped to GPIO (replaces source interrupt). | | IRQ1_OUT/GPIO | 0 | External Destination Interrupt 1. Polarity is configured in EXT_DST_INTR_POL.EXT_INTR_POL[1]. This interrupt can also be mapped to GPIO (replaces source interrupt). | For destination interrupts it is possible to drive the output pin permanently or emulate open-collector output. - To drive permanently, configure EXT\_INTR\_DRV[e] = 0. - To emulate open collector output, configure EXT\_INTR\_DRV[e] = 1 and EXT\_INTR\_POL[e] = 0. To safely enable open-collector output, the EXT\_INTR\_DRV and EXT\_INTR\_POL registers must be configured before enabling the overlaid function in the GPIO controller. **Note:** Open collector output mode is required when multiple interrupt sources are hooked up to the same interrupt wire on the PCB and the wire is be pulled high with a resistor. Each interrupt source can then drive the wire low via open-collector output when they want to signal interrupt. # 5 Registers Information about the registers for this product is available in the attached Adobe Acrobat file. To view or print the information, double-click the attachment icon. # 6 Electrical Specifications This section provides the DC characteristics, AC characteristics, recommended operating conditions, and stress ratings for the VSC7415 device. # 6.1 DC Characteristics This section contains the DC specifications for the VSC7415 device. #### 6.1.1 Reference Clock The following table lists the DC specifications for the differential reference clock signals. Differential and single-ended modes are supported. Table 264 • Reference Clock Inputs | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |---------------------------------------|------------------|---------|-------------------------------|-------------------|-------| | Input voltage range | $V_{IP}, V_{IN}$ | -25 | | 1200 | mV | | Single-ended input swing | V <sub>SE</sub> | 600 | | 1000 <sup>1</sup> | mV | | Differential peak-to-peak input swing | V <sub>ID</sub> | 200 | | 1200 | mVppd | | Input common-mode voltage | V <sub>CM</sub> | | $^{2}$ / $_{3} \times V_{DD}$ | | mV | <sup>1.</sup> Input common-mode voltage and amplitude must not exceed 1200 mV. # 6.1.2 PLL Clock Output The following table lists the DC specifications for the PLL clock outputs. Applies to CLKOUTPLL and CLKOUTPLL2 pins. Table 265 • PLL Clock Output | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |----------------------------------------|-------------------|----------------------------|---------|-------------------|-------|-------------------------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | | Differential peak-to-peak output swing | V <sub>OD</sub> | 290 | | 510 | mVppd | | | Differential peak-to-peak output swing | V <sub>OD</sub> | 360 | | 635 | mVppd | See note <sup>1</sup> . | | Output common-mode voltage | V <sub>CM</sub> | V <sub>DD A</sub> – 500 mV | | V <sub>DD A</sub> | mV | | <sup>1.</sup> Driver amplitude depends on driver-to-receiver adaptation configured in register. Increased amplitude can be achieved if the receiver is common-mode terminated to V<sub>DD</sub> <sub>A</sub> and if the driver is configured accordingly. #### 6.1.3 DPLL Clocks The following table lists the DC specifications for the DPLL clock outputs. Applies to the CLKOUT[3:0]\_N/P pins. Table 266 • DPLL Clock Outputs | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |-----------------------------------------------------|-------------------|---------|---------|---------|-------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | Differential peak-to-peak output swing <sup>1</sup> | V <sub>OD</sub> | 600 | | 1000 | mVppd | | Output common-mode voltage | V <sub>CM</sub> | | 680 | | mV | <sup>1.</sup> Output swing is register programmable. The following table lists the DC specifications for the DPLL clock inputs. Applies to the CLKIN[3:0]\_N/P pins. Table 267 • DPLL Clock Inputs | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |--------------------------------------------------------------------|-------------------|---------|---------|---------|-------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | Input voltage <sup>1</sup> | V <sub>I</sub> | 100 | | 1200 | mVppd | | Input common-mode voltage, V <sub>DD_HS</sub> = 1.0 V <sup>1</sup> | V <sub>CM</sub> | | 600 | | mV | | Input common-mode voltage, V <sub>DD_HS</sub> = 1.2 V <sup>1</sup> | V <sub>CM</sub> | | 700 | | mV | <sup>1.</sup> Input must be AC-coupled. # 6.1.4 DDR3/DDR3L SDRAM Interface This section provides the DC specifications for the DDR3 and DDR3L interfaces. The DDR3 SDRAM interface supports the requirements of SDRAM devices as described in the JEDEC DDR3 specifications. The SDRAM interface signals are compatible with JESD79-3F (DDR3 SDRAM SPECIFICATION, July 2012) and JESD79-3-1A, January 2013. The SSTL I/O buffers have programmable on-die termination (ODT). #### 6.1.4.1 DDR3 SDRAM Interface The following table lists the DC specifications for the SDRAM interface signals in DDR3 operation. Table 268 • DDR3 SDRAM Signals | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |---------------------------------------|----------------------|------------------------------|------------------------------|------|---------------------------------------------------------| | Input reference voltage <sup>1</sup> | DDR_V <sub>REF</sub> | 49% V <sub>DD_IODDR</sub> | 51% V <sub>DD_IODDR</sub> | V | V <sub>DD_IODDR</sub> = 1.5 V. | | Input voltage high | V <sub>IH(DC)</sub> | DDR_V <sub>REF</sub> + 0.100 | V <sub>DD_IODDR</sub> | V | | | Input voltage low | V <sub>IL(DC)</sub> | -0.3 | DDR_V <sub>REF</sub> – 0.100 | V | | | Output voltage high | V <sub>OH(DC)</sub> | $0.8 \times V_{DD\_IODDR}$ | | V | Not terminated, 1 pF load. | | Output voltage low | V <sub>OL(DC)</sub> | -0.3 | $0.2 \times V_{DD\_IODDR}$ | V | Not terminated, 1 pF load. | | Input leakage current | I <sub>L</sub> | | 40 | μΑ | $0 \text{ V} \leq V_{I} \leq V_{DD\_IODDR}$ . | | Output source DC current <sup>2</sup> | I <sub>OH</sub> | <b>-</b> 6 | | mA | External 40 $\Omega$ termination to $V_{DD\_IODDR}/2$ . | | Output sink DC current <sup>2</sup> | I <sub>OL</sub> | 6 | | mA | External 40 $\Omega$ termination to $V_{DD\_IODDR}/2$ . | DDR\_V<sub>REF</sub> is expected to track variations in V<sub>DD\_IODDR</sub>. Peak-to-peak AC noise on DDR\_V<sub>REF</sub> must not exceed ±2% of DDR\_V<sub>REF</sub>. #### 6.1.4.2 DDR3L SDRAM Interface The following table lists the DC specifications for the SDRAM interface signals in DDR3L operation. Table 269 • DDR3L SDRAM Signals | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------------|----------------------|---------------------------|---------------------------|------|-----------------------------------| | Input reference voltage <sup>1</sup> | DDR_V <sub>REF</sub> | 49% V <sub>DD_IODDR</sub> | 51% V <sub>DD_IODDR</sub> | V | $V_{DD\_IODDR} = 1.35 \text{ V}.$ | <sup>2.</sup> With 34 $\Omega$ output driver impedance. Table 269 • DDR3L SDRAM Signals | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |---------------------------------------|---------------------|-----------------------------|----------------------------|------|-------------------------------------------------------| | Input voltage high | V <sub>IH(DC)</sub> | DDR_V <sub>REF</sub> + 0.09 | V <sub>DD_IODDR</sub> | V | | | Input voltage low | V <sub>IL(DC)</sub> | -0.3 | DDR_V <sub>REF</sub> -0.09 | V | | | Output voltage high | V <sub>OH(DC)</sub> | 0.8 × V <sub>DD_IODDR</sub> | | V | Not terminated, 1 pF load. | | Output voltage low | V <sub>OL(DC)</sub> | | $0.2 \times V_{DD\_IODDR}$ | V | Not terminated, 1 pF load. | | Input leakage current | I <sub>L</sub> | | 40 | μΑ | $0 \text{ V} \leq V_{I} \leq V_{DD\_IODDR}.$ | | Output source DC current <sup>2</sup> | I <sub>OH</sub> | <b>–</b> 6 | | mA | External 40 $\Omega$ termination to $V_{DD\_IODDR}/2$ | | Output sink DC current <sup>2</sup> | I <sub>OL</sub> | 6 | | mA | External 40 $\Omega$ termination to $V_{DD\_IODDR}/2$ | DDR\_V<sub>REF</sub> is expected to track variations in V<sub>DD\_IODDR</sub>. Peak-to-peak AC noise on DDR\_V<sub>REF</sub> must not exceed ±2% of DDR\_V<sub>REF</sub>. # 6.1.5 **SERDES1G** This section describes the DC specifications for the SERDES1G transceiver. The transceiver supports 100BASE-FX, SFP, 1000BASE-KX, and SGMII modes. The following table lists the DC specifications for the 1G transmitter. Applies to the S[4:0] TXN/P pins. Table 270 • 1G Transmitter | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------------------------|----------------------|---------|---------|---------|-------|-------------------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | | Output voltage high | V <sub>OH</sub> | | | 1050 | mV | | | Output voltage low | V <sub>OL</sub> | 0 | | | mV | | | Differential peak-to-peak output voltage <sup>1</sup> | V <sub>O_DIFF</sub> | 300 | | 800 | mVppd | 100BASE-FX, SGMII | | Differential peak-to-peak output voltage <sup>1</sup> | V <sub>O_DIFF</sub> | 500 | | 1200 | mVppd | SFP | | Differential peak-to-peak output voltage <sup>1</sup> | V <sub>O_DIFF</sub> | 800 | | 1100 | mVppd | 1000BASE-KX | | Differential peak-to-peak output voltage with Tx disabled | V <sub>OD_IDLE</sub> | | | 30 | mVppd | | <sup>1.</sup> Output amplitude is configurable in 16 steps. The following table lists the DC specifications for the 1G receiver. Applies to the S[4:0] RXN/P pins. Table 271 • 1G Receiver | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------|----------------------|---------|-------------------------|-------------------|-------|--------------------------------------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | | Absolute input voltage range | V <sub>IN</sub> | -25 | | 1200 | mV | | | Common-mode voltage | V <sub>CM_AC</sub> | 0 | | V <sub>DD_A</sub> | mV | AC-coupled operation <sup>1</sup> | | Common-mode voltage | V <sub>CM_DC</sub> | | 0.7 × V <sub>DD_A</sub> | | mV | DC-coupled operation <sup>2, 3</sup> | | Differential peak-to-peak input voltage | V <sub>IN_DIFF</sub> | 100 | | 1600 | mVppd | See note <sup>4</sup> | <sup>2.</sup> With 34 $\Omega$ output driver impedance. - 1. Compatibility to SGMII transmitters requires external AC-coupling. The maximum common-mode voltage is provided without a differential signal. It is limited by the minimum and maximum input voltage range and the input's signal amplitude. - 2. For information about optional DC-coupling, contact your Microsemi sales representative. - Common-mode termination disabled. The maximum differential peak-to-peak input is limited by the maximum input voltage range. - 4. Applies to all supported modes. For 100BASE-FX, disable internal AC-coupling. ## **6.1.6 SERDES6G** This section provides the DC specifications for the 6G transceiver. The transceiver supports the following modes: - 100BASE-FX - SGMII - SFP - PCle - 2.5G The following table lists the DC specifications for the 6G transmitter. Applies to the PCIE\_TXN/P and S[6:5]\_TXN/P pins. Table 272 • 6G Transmitter | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------------------------|----------------------|---------|---------|--------------------|-------|-----------------------------------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | | Output voltage high | V <sub>OH</sub> | | | V <sub>DD_VS</sub> | mV | | | Output voltage low | V <sub>OL</sub> | 0 | | | mV | | | Differential peak-to-peak output voltage <sup>1</sup> | $V_{O\_DIFF}$ | 300 | | 800 | mVppd | 100BASE-FX,<br>SGMII <sup>2</sup> | | Differential peak-to-peak output voltage <sup>1</sup> | V <sub>O_DIFF</sub> | 500 | | 1200 | mVppd | SFP, 2.5G | | Differential peak-to-peak output voltage <sup>1</sup> | $V_{O\_DIFF}$ | 800 | | 1200 | mVppd | 1000BASE-KX and PCle <sup>3</sup> | | Differential peak-to-peak output voltage with Tx disabled | V <sub>OD_IDLE</sub> | | | 30 | mVppd | | | Output current, driver shorted to GND | T_ISG | | | 40 | mA | | - 1. Drive level depends on register configuration. - 2. Compatibility to SGMII receiver requires AC-coupling. - 3. Compatibility to supported standards require 1.2 V supply for driver. The following table lists the DC specifications for the 6G receiver. Applies to the $PCIE_RXN/P$ and $S[6:5]_RXN/P$ pins. Table 273 • 6G Receiver | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------|----------------------|---------|-----------------------------|---------|-------|------------------------------------------------| | Differential resistance | R <sub>DIFF</sub> | 80 | 100 | 120 | Ω | | | Absolute input voltage range | V <sub>IN</sub> | -25 | | 1200 | mV | | | Common-mode voltage | V <sub>CM</sub> | 0 | Internal<br>V <sub>CM</sub> | | mV | AC-coupled operation <sup>1</sup> | | Common-mode voltage | V <sub>CM</sub> | | V <sub>DD_A</sub> | | mV | DC-coupled operation, load type 2 <sup>1</sup> | | Differential peak-to-peak input voltage | V <sub>IN_DIFF</sub> | 100 | | 1600 | mVppd | See note <sup>2</sup> | - 1. Mode for common-mode termination is specified by configuration register setting. Input amplitude in DC-coupled mode must not exceed maximum input voltage range. For more information about optional DC-coupling, contact your Microsemi representative. - Compatibility to SGMII transmitter requires AC-coupling. # 6.1.7 GPIO, SI, JTAG, and Miscellaneous Signals This section provides the DC specifications for the GPIO, SI, JTAG, and miscellaneous signals. The following I/O signals comply with the specifications provided in this section: Table 274 • I/O Signals | GPIO[36:0] | JTAG_nTRST | nRESET | |------------|--------------|--------| | SI_CLK | JTAG_TMS | | | SI_DI | JTAG_TDO | | | SI_DO | JTAG_TCK | | | SI_nCS0 | JTAG_TDI | | | | JTAG_ICE_nEN | | The outputs and inputs meet or exceed the requirements of the LVTTL and LVCMOS standard, JEDEC JESD8-B (September 1999) standard, unless otherwise stated. The inputs are Schmitt-trigger for noise immunity. Table 275 • GPIO, SI, JTAG, and Miscellaneous Signals DC Specifications | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |----------------------------------|-----------------|---------|---------|---------|------|--------------------------| | Output high voltage <sup>1</sup> | V <sub>OH</sub> | 2.1 | 2.35 | | V | I <sub>OH</sub> = -2 mA | | Output high voltage <sup>1</sup> | V <sub>OH</sub> | 1.7 | 2.0 | | V | I <sub>OH</sub> = -12 mA | | Output low voltage | V <sub>OL</sub> | | | 0.4 | V | I <sub>OL</sub> = 2mA | | Output low voltage | V <sub>OL</sub> | | | 0.7 | V | I <sub>OL</sub> = 12 mA | | Input high voltage | V <sub>IH</sub> | 1.85 | | 3.6 | V | | | Input low voltage | $V_{IL}$ | -0.3 | | 0.8 | V | | | Input high current <sup>2</sup> | I <sub>IH</sub> | | | 10 | μΑ | $V_I = V_{DD\_IO}$ | | Input low current <sup>2</sup> | I <sub>IL</sub> | -100 | | | μΑ | V <sub>I</sub> = 0 V | | Input capacitance | C <sub>I</sub> | | | 10 | pF | | <sup>1.</sup> $V_{DD\ IO}$ = 2.38 V minimum, $V_{DD\ IO}$ = 2.5 typical. #### 6.1.8 Thermal Diode The device includes an on-die diode and internal circuitry for monitoring die temperature (junction temperature). The operation and accuracy of the diode is not guaranteed and should only be used as a reference. The on-die thermal diode requires an external thermal sensor, located on the board or in a stand-alone measurement kit. Temperature measurement using a thermal diode is very sensitive to noise. The following illustration shows a generic application design. <sup>2.</sup> Input high current and input low current equals the maximum leakage current, excluding the current in the built-in pull resistors. Figure 136 • Thermal Diode #### **Isolated Sensor Circuit** #### **Grounded Sensor Circuit** Note: Microsemi does not support or recommend operation of the thermal diode under reverse bias. The following table provides the diode parameter and interface specifications with the pins connected internally to VSS in the device. Table 276 • Thermal Diode Parameters | Parameter | Symbol | Typical | Maximum | Unit | |-----------------------|-----------------|-----------------------|---------|------| | Forward bias current | I <sub>FW</sub> | See note <sup>1</sup> | 1 | mA | | Diode ideality factor | n | 1.008 | | | 1. Typical value is device dependent. The ideality factor, n, represents the deviation from ideal diode behavior as exemplified by the following diode equation: $$I_{FW} = I_{S}(e^{(qV_{D})/(nkT)} - 1)$$ where, $I_S$ = saturation current, q = electron charge, $V_D$ = voltage across the diode, k = Boltzmann constant, and T = absolute temperature (Kelvin). ### 6.2 AC Characteristics This section provides the AC specifications for the VSC7415 device. #### 6.2.1 Reference Clock The signal applied to the REFCLK differential inputs must comply with the requirements listed in the following tables at the pin of the device. The following table lists the AC specifications for the REFCLK reference clock. Table 277 • REFCLK Reference Clock | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |---------------------------------------|--------|----------|---------|---------|------|----------------------------| | REFCLK frequency<br>REFCLK_CONF = 100 | f | –100 ppm | 25 | 100 ppm | MHz | | | REFCLK frequency<br>REFCLK_CONF = 000 | f | –100 ppm | 125 | 100 ppm | MHz | | | REFCLK frequency<br>REFCLK_CONF = 001 | f | –100 ppm | 156.25 | 100 ppm | MHz | | | REFCLK frequency REFCLK_CONF = 010 | f | –100 ppm | 250 | 100 ppm | MHz | | | Clock duty cycle | | 40 | | 60 | % | Measured at 50% threshold. | Table 277 • REFCLK Reference Clock (continued) | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |---------------------------------------------------------------------------------------------------|---------------------------------|---------|---------|----------------------------|------|----------------------------------------------------------| | Rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | | | 0.5 | ns | Within ±200 mV relative to $V_{DD} \times {}^2/_3$ . | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth from 10 kHz to<br>100 kHz | | | | 0.3 | dB | REFCLK = 25 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth from 100 kHz to<br>4 MHz | | | | 1 | dB | REFCLK = 25 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth above 4 MHz | | | | 1 – 20 × log<br>(f/4 MHz) | dB | REFCLK = 25 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth from 10 kHz to<br>300 kHz | | | | 0.3 | dB | REFCLK ≥ 125 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth from 300 kHz to<br>3 MHz | | | | 0.6 | dB | REFCLK ≥ 125 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth from 3 MHz to<br>12 MHz | | | | 2 | dB | REFCLK ≥ 125 MHz | | Jitter transfer from REFCLK to<br>SERDES10G/clock outputs,<br>bandwidth above 12 MHz | | | | 2 – 20 × log<br>(f/12 MHz) | dB | REFCLK ≥ 125 MHz | | REFCLK input peak-to-peak jitter, bandwidth from 2.5 kHz to 10 MHz <sup>1</sup> | | | | 20 | ps | To meet G.8262 1G SyncE jitter generation specification. | <sup>1.</sup> Peak-to-peak values are typically higher than the RMS value by a factor of 10 to 14. The following table lists the AC specifications for the REFCLK2 reference clock. Table 278 • REFCLK2 Reference Clock | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------|--------|----------|---------|---------|------|----------------------------| | REFCLK2 frequency<br>REFCLK2_CONF = 100 | f | –100 ppm | 25 | 100 ppm | MHz | | | REFCLK2 frequency<br>REFCLK2_CONF= 000 | f | –100 ppm | 125 | 100 ppm | MHz | | | REFCLK2 frequency REFCLK2_CONF = 001 | f | –100 ppm | 156.25 | 100 ppm | MHz | | | REFCLK2 frequency<br>REFCLK2_CONF = 010 | f | –100 ppm | 250 | 100 ppm | MHz | | | Clock duty cycle | | 40 | | 60 | % | Measured at 50% threshold. | Table 278 • REFCLK2 Reference Clock (continued) | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |------------------------------------------------------------------------------------------------|---------------------------------|---------|---------|--------------------------|-------------------|------------------------------------------------------| | Rise time and fall time, differential mode | t <sub>R</sub> , t <sub>F</sub> | | | 0.5 | ns | Within ±200 mV relative to $V_{DD} \times {}^2/_3$ . | | Rise time and fall time, 25 MHz single-ended mode | t <sub>R</sub> , t <sub>F</sub> | | | 2 | ns | Within ±200 mV relative to $V_{DD} \times {}^2/_3$ . | | Jitter transfer from REFCLK2 to<br>SERDES10G/clock outputs, bandwidth<br>from 300 kHz to 3 MHz | | | | 0.6 | dB | | | Jitter transfer from REFCLK2 to<br>SERDES10G/clock outputs, bandwidth<br>from 3 MHz to 12 MHz | | | | 2 | dB | | | Jitter transfer from REFCLK2 to SERDES10G/clock outputs, bandwidth above 12 MHz | | | | 2-20 × log<br>(f/12 MHz) | dB | | | REFCLK2 input RMS jitter, 12 kHz to 10 MHz | | | | 1 | ps <sub>RMS</sub> | | The following illustration shows jitter transfer curves from REFCLK and REFCLK2 to all high-speed outputs. Figure 137 • REFCLK/REFCLK2 Jitter Transfer Curves ## 6.2.2 PLL Clock Outputs The following table lists the AC specifications for the PLL outputs. Applies to the CLKOUTPLL and CLKOUTPLL2 pins. Table 279 • PLL Clock Outputs | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |------------------|--------|---------|---------|------|-----------| | Output frequency | | | 625 | MHz | | Table 279 • PLL Clock Outputs | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------------------------|---------------------------------|---------|---------|------|------------------------------| | Clock duty cycle | t <sub>C</sub> | 45 | 55 | % | Measured at 50% threshold | | Rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | 100 | 300 | ps | 20% to 80% of V <sub>S</sub> | | Intrapair skew | t <sub>SKEW</sub> | | 100 | ps | | | RMS jitter, bandwidth from 12 kHz to 500 kHz | | | 20 | ps | | | RMS jitter, bandwidth from 500 kHz to 15 MHz | | | 4 | ps | | | RMS jitter, bandwidth from 15 MHz to 40 MHz | | | 20 | ps | | | RMS jitter, bandwidth from 40 MHz to 80 MHz | | | 100 | ps | | #### 6.2.3 DPLL Clocks The following table lists the AC specifications for the DPLL outputs. Applies to the CLKOUT[3:0]\_N/P pins. The specifications are valid with AC-coupled, $100~\Omega$ differential load and output frequency of 250 MHz, unless otherwise noted. Table 280 • DPLL Clock Outputs | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |-----------------------------------------|---------------------------------|---------|---------|------|------------------------------| | Output frequency | f | 1 | 250 | MHz | | | Clock duty cycle | t <sub>C</sub> | 45 | 55 | % | Measured at 50% threshold | | Rise time and fall time <sup>1</sup> | t <sub>R</sub> , t <sub>F</sub> | 30 | 300 | ps | 20% to 80% of V <sub>S</sub> | | RMS jitter, 1.544 MHz | | | 3 | ps | 12 kHz to 700 kHz | | Peak-to-peak jitter, 1.544 MHz | | | 25 | ps | 12 kHz to 700 kHz | | RMS jitter, 2.048 MHz | | | 3 | ps | 12 kHz to 1 MHz | | Peak-to-peak jitter, 2.048 MHz | | | 25 | ps | 12 kHz to 1 MHz | | RMS jitter, 25 MHz | | | 5 | ps | 12 kHz to 10 MHz | | RMS jitter, >100 MHz, REFCLK2 = 25 MHz | | | 3 | ps | 12 kHz to 20 MHz | | RMS jitter, >100 MHz, REFCLK2 = 125 MHz | | | 1.5 | ps | 12 kHz to 20 MHz | <sup>1.</sup> Edge rate is programmable. The following table lists the AC specifications for the DPLL inputs. Applies to the CLKIN[3:0] N/P pins. Table 281 • DPLL Clock Inputs | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |------------------------------|----------------------|---------|---------|-------|---------------------------| | Input frequency <sup>1</sup> | f | 1 | 250 | MHz | | | Clock duty cycle | t <sub>C</sub> | 40 | 60 | % | Measured at 50% threshold | | Differential input voltage | V <sub>IN_DIFF</sub> | 100 | 1200 | mVppd | | <sup>1.</sup> When GPIO pins are used as clock inputs for the DPLL, the maximum frequency is 20 MHz. #### 6.2.4 Jitter Transfer The following table shows the jitter transfer from the input to output of the VSC7415 device when configured in different SyncE operating modes. The input can be any Ethernet port or any clock input. The output can be any Ethernet port or any clock output. Table 282 • Jitter Transfer | Parameter | Minimum | Maximum | Unit | Condition | |----------------------------------------------------------|---------|---------|-----------|-----------| | -3 dB filter bandwidth, EEC Option 1 mode | 1 | 10 | Hz | | | Jitter transfer from inputs to output, EEC Option 1 mode | | 0.1 | dB | f <10 Hz | | Jitter transfer from inputs to output, EEC Option 1 mode | | -20 | dB/decade | f >10 Hz | | -3 dB filter bandwidth, EEC Option 2 mode | 0.05 | 0.10 | Hz | | | Jitter transfer from inputs to output, EEC Option 2 mode | | 0.1 | dB | f <0.1 Hz | | Jitter transfer from inputs to output, EEC Option 2 mode | | -20 | dB/decade | f >0.1 Hz | | -3 dB filter bandwidth, 1 millihertz (mHz) filter mode | 0.5 | 1 | mHz | | | Jitter transfer from inputs to output, 1 mHz filter mode | | 0.1 | dB | f <1 mHz | | Jitter transfer from inputs to output, 1 mHz filter mode | | -20 | dB/decade | f >1 mHz | #### 6.2.5 **SERDES1G** This section describes the AC specifications for the SERDES1G transceiver. The transceiver supports 100BASE-FX, SFP, 1000BASE-KX, and SGMII modes. The following table lists the AC characteristics for the 1G transmitter. Applies to S[4:0]\_TXN/P pins. Table 283 • 100BASE-FX, SGMII, SFP, 1000BASE-KX Transmitter | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------------|---------------------------------|----------------|-------------------------------|-------------------|--------------------------------------------------| | Data rate | | 125 – 100 ppm | 125 + 100 ppm | Mbps | 100BASE-FX. | | Data rate | | 1.25 – 100 ppm | 1.25 + 100 ppm | Gbps | SGMII, SFP, 1000BASE-KX. | | Differential output return loss | RLO <sub>SDD22</sub> | | <b>–10</b> | dB | 50 MHz to 625 MHz. | | Differential output return loss | RLO <sub>SDD22</sub> | | -10 + 10 x log<br>(f/625 MHz) | dB | 625 MHz to 1250 MHz. | | Rise time and fall time <sup>1</sup> | t <sub>R</sub> , t <sub>F</sub> | 60 | 300 | ps | 20% to 80%. | | Interpair skew | t <sub>SKEW</sub> | | 20 | ps | | | Deterministic jitter | DJ | | 80 | ps | Measured according to IEEE 802.3 Clause 38.5. | | Total jitter | TJ | | 192 | ps | Measured according to IEEE 802.3 Clause 38.5. | | Wideband SyncE jitter | WJT | | 0.5 | UI <sub>P-P</sub> | Measured according to ITU-T G.8262, section 8.3. | <sup>1.</sup> Slew rate is programmable. The following table lists AC characteristics for the 1G receiver. Applies to the S[4:0]\_RXN/P pins. Table 284 • 100BASE-FX, SGMII, SFP, 1000BASE-KX Receiver | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |-------------------------------------------------|----------------------|----------------|-------------------------------|-------------------|--------------------------------------------------------------------------------| | Data rate | | 125 – 100 ppm | 125 + 100 ppm | Mbps | 100BASE-FX. | | Data rate | | 1.25 – 100 ppm | 1.25 + 100 ppm | Gbps | SGMII, SFP, 1000BASE-KX. | | Differential input return loss | RLI <sub>SDD11</sub> | | -10 | dB | 50 MHz to 625 MHz. | | Differential input return loss | RLI <sub>SDD11</sub> | | -10 + 10 x log<br>(f/625 MHz) | dB | 625 MHz to 1250 MHz. | | Jitter tolerance, total <sup>1</sup> | TOL <sub>TJ</sub> | 600 | | ps | SGMII, SFP, 1000BASE-KX.<br>Measured according to<br>IEEE 802.3 Clause 38.6.8. | | Jitter tolerance,<br>deterministic <sup>1</sup> | TOL <sub>DJ</sub> | 370 | | ps | SGMII, SFP, 1000BASE-KX.<br>Measured according to<br>IEEE 802.3 Clause 38.6.8. | | Jitter tolerance, duty cycle distortion | TOL <sub>DCD</sub> | 1.4 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | | Jitter tolerance, data dependent | TOL <sub>DDJ</sub> | 2.2 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | | Jitter tolerance, random | TOL <sub>RJ</sub> | 2.27 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | | Wideband SyncE jitter tolerance | WJT | 312.5 | | UI <sub>P-P</sub> | 10 Hz to 12.1 Hz. Measured according to ITU-T G.8262, section 9.2. | | Wideband SyncE jitter tolerance | WJT | 3750/f | | Ul <sub>P-P</sub> | 12.1 Hz to 2.5 kHz (f) Measured according to ITU-T G.8262, section 9.2. | | Wideband SyncE jitter tolerance | WJT | 1.5 | | UI <sub>P-P</sub> | 2.5 kHz to 50 kHz.<br>Measured according to ITU-T<br>G.8262, section 9.2. | <sup>1.</sup> Jitter requirements represent high-frequency jitter (above 637 kHz) and not low-frequency jitter or wander. ### **6.2.6 SERDES6G** This section describes the AC specifications for the 6G transceiver. The transceiver supports the following modes: - 100BASE-FX - SGMII - SFP - 2.5G - PCle - 1000BASE-KX The following table lists the AC characteristics for the 6G transmitter in 100BASE-FX, SGMII, SFP, 2.5G, and 1000BASE-KX modes. Applies to the $S[6:5]_TXN/P$ pins. Table 285 • 100BASE-FX, SGMII, SFP, 2.5G, 1000BASE-KX Transmitter | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------------|---------------------------------|------------------|-------------------------------|-------------------|-------------------------------------------------| | Data rate | | 125 – 100 ppm | 125 + 100 ppm | Mbps | 100BASE-FX | | Data rate | | 1.25 – 100 ppm | 1.25 + 100 ppm | Gbps | SGMII, SFP, 1000BASE-KX | | Data rate | | 3.125 – 100 ppm | 3.125 + 100 ppm | Gbps | 2.5G | | Differential output return loss | RLO <sub>SDD22</sub> | | -10 | dB | 50 MHz to 625 MHz | | Differential output return loss | RLO <sub>SDD22</sub> | | -10 + 10 x log<br>(f/625 MHz) | dB | 625 MHz to 1250 MHz | | Rise time and fall time <sup>1</sup> | t <sub>R</sub> , t <sub>F</sub> | 60 | 320 | ps | 20% to 80% | | Interpair skew | t <sub>SKEW</sub> | | 20 | ps | | | Random jitter | RJ | | 0.15 | UI <sub>P-P</sub> | At BER 10 <sup>-12</sup> | | Deterministic jitter | DJ | | 0.10 | UI <sub>P-P</sub> | | | Total jitter | TJ | | 0.25 | UI <sub>P-P</sub> | | | Wideband SyncE jitter | TWJ | | 0.5 | UI <sub>P-P</sub> | Measured according to ITU-T G.8262, section 8.3 | | Eye mask | X1 | | 0.125 | UI | | | Eye mask | X2 | | 0.325 | UI | | | Eye mask | Y1 | 350 <sup>2</sup> | | mV | | | Eye mask | Y2 | | 800 | mV | | <sup>1.</sup> Slew rate is programmable. The following table lists AC characteristics for the 6G receiver operating in 100BASE-FX, SGMII, SFP, 2.5G, and 1000BASE-KX modes. Applies to the S[6:5]\_RXN/P pins. Table 286 • 100BASE-FX, SGMII, SFP, 2.5G, 1000BASE-KX Receiver | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |-------------------------------------------------|----------------------|-----------------|-------------------------------|-------------------|--------------------------------------------------------| | Data rate | | 125 – 100 ppm | 125 + 100 ppm | Mbps | 100BASE-FX. | | Data rate | | 1.25 – 100 ppm | 1.25 + 100 ppm | Gbps | SGMII, SFP, 1000BASE-KX. | | Data rate | | 3.125 – 100 ppm | 3.125 + 100 ppm | Gbps | 2.5G. | | Differential input return loss | RLI <sub>SDD11</sub> | | -10 | dB | 50 MHz to 625 MHz. | | Differential input return loss | RLI <sub>SDD11</sub> | | -10 + 10 x log<br>(f/625 MHz) | dB | 625 MHz to 1250 MHz. | | Jitter tolerance, total <sup>1</sup> | TOL <sub>TJ</sub> | 600 | | ps | Measured according to IEEE 802.3 Clause 38.6.8. | | Jitter tolerance,<br>deterministic <sup>1</sup> | TOL <sub>DJ</sub> | 370 | | ps | Measured according to IEEE 802.3 Clause 38.6.8. | | Jitter tolerance, duty cycle distortion | TOL <sub>DCD</sub> | 1.4 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | <sup>2.</sup> Compatibility to supported standard requires $V_{DD\_VS} = 1.2 \text{ V}$ . Table 286 • 100BASE-FX, SGMII, SFP, 2.5G, 1000BASE-KX Receiver (continued) | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------------|--------------------|---------|---------|-------------------|--------------------------------------------------------------------------| | Jitter tolerance, data dependent | TOL <sub>DDJ</sub> | 2.2 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | | Jitter tolerance, random | TOL <sub>RJ</sub> | 2.27 | | ns <sub>P-P</sub> | 100BASE-FX. Measured according to ISO/IEC 9314-3:1990. | | Wideband SyncE jitter tolerance | WJT | 312.5 | | UI <sub>P-P</sub> | 10 Hz to 12.1 Hz.<br>Measured according to ITU-T<br>G.8262, section 9.2. | | Wideband SyncE jitter tolerance | WJT | 3750/f | | UI <sub>P-P</sub> | 12.1 Hz to 2.5 kHz (f). Measured according to ITU-T G.8262, section 9.2. | | Wideband SyncE jitter tolerance | WJT | 1.5 | | UI <sub>P-P</sub> | 2.5 kHz to 50 kHz. Measured according to ITU-T G.8262, section 9.2. | <sup>1.</sup> Jitter requirements represent high-frequency jitter (above 637 kHz) and not low-frequency jitter or wander. The following table lists the AC characteristics for the 6G transmitter operating in PCIe mode. Applies to the PCIE\_TXN/P pins. Table 287 • PCle Transmitter | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |---------------------------------------------------------|---------------------------------|------------------|---------|---------------|-------------------|-----------------------------------| | Data rate | | 2.5 – 300 ppm | | 2.5 + 300 ppm | Gbps | | | Differential output return loss | RLO <sub>SDD22</sub> | | | -10 | dB | 50 MHz to 1.25 GHz | | Common-mode return loss | RLO <sub>SCC22</sub> | | | <b>–</b> 6 | dB | 50 MHz to 1.25 GHz | | De-emphasized<br>differential output<br>voltage (ratio) | Tode | -3 | -3.5 | -4 | dB | | | Rise time and fall time <sup>1</sup> | t <sub>R</sub> , t <sub>F</sub> | 60 | | | ps | 20% to 80%.<br>Recommended value. | | Total jitter | TJ | | | 0.25 | UI <sub>P-P</sub> | | | Differential amplitude | V <sub>TX_DIFF_PP</sub> | 800 <sup>2</sup> | | 1200 | $mV_{P-P}$ | | <sup>1.</sup> Slew rate is programmable. Configure accordingly for compliance to supported standard. The following table lists the AC characteristics for the 6G receiver operating in PCIe mode. Applies to the PCIE\_RXN/P pins. Table 288 • PCIe Receiver | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------|----------------------|---------------|---------------|------|---------------------| | Data rate | | 2.5 – 300 ppm | 2.5 + 300 ppm | Gbps | | | Differential input return loss | RLI <sub>SDD11</sub> | | -10 | dB | 50 MHz to 1.25 GHz. | | Common-mode return loss | RLI <sub>SCC11</sub> | | -6 | dB | 80 MHz to 1.25 GHz. | <sup>2.</sup> Compatibility to supported standard requires $V_{DD\ VS}$ = 1.2 V supply for driver. Table 288 • PCle Receiver (continued) | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |------------------------|--------|---------|---------|-------------------|-----------| | Total jitter tolerance | TJ | | 0.60 | UI <sub>P-P</sub> | | | Eye mask | R_X1 | | 0.30 | UI | | | Eye mask | R_X2 | | 0.70 | UI | | | Eye mask | R_Y1 | 85 | | mV | | | Eye mask | R_Y2 | | 600 | mV | | ### 6.2.7 Reset Timing The nRESET signal waveform and the required measurement points for the timing specification are shown in the following illustration. Figure 138 • nRESET Signal Timing Specifications The signal applied to the nRESET input must comply with the specifications listed in the following table at the reset pin of the device. Table 289 • nRESET Timing Specifications | Parameter | Symbol | Minimum | Maximum | Unit | |-----------------------------------------------------------------|--------------------|---------|---------|------| | nRESET assertion time after power supplies and clock stabilizes | t <sub>W</sub> | 2 | | ms | | Recovery time from reset inactive to device fully active | t <sub>REC</sub> | | 10 | ms | | nRESET pulse width | t <sub>W(RL)</sub> | 100 | | ns | | Hold time for GPIO-mapped strapping pins relative to nRESET | t <sub>HCFG</sub> | 50 | | ns | ## 6.2.8 MII Management All AC specifications for the MII Management (MIIM) interface meet or exceed the requirements of IEEE 802.3-2002 (clause 22.2-4). All MIIM AC timing requirements are specified relative to the input low and input high threshold levels. The following illustration shows the MIIM waveforms and required measurement points for the signals. Figure 139 • MIIM Timing Diagram The set up time of MDIO relative to the rising edge of MDC is defined as the length of time between when the MDIO exits and remains out of the switching region and when MDC enters the switching region. The hold time of MDIO relative to the rising edge of MDC is defined as the length of time between when MDC exits the switching region and when MDIO enters the switching region. The MIIM signals are GPIO alternate functions. For more information, see GPIO Overlaid Functions, page 355. All MIIM signals comply with the specifications in the following table. The MDIO signal requirements are requested at the pin of the device. Table 290 • MIIM Timing Specifications | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------------|--------------------|---------|---------|------|-------------------------------| | MDC frequency <sup>1</sup> | f | 0.488 | 20.83 | MHz | | | MDC cycle time <sup>2</sup> | t <sub>C</sub> | 48 | 2048 | ns | | | MDC time high | t <sub>W(CH)</sub> | 20 | | ns | C <sub>L</sub> = 50 pF | | MDC time low | t <sub>W(CL)</sub> | 20 | | ns | C <sub>L</sub> = 50 pF | | MDIO setup time to MDC on write | t <sub>SU(W)</sub> | 15 | | ns | C <sub>L</sub> = 50 pF | | MDIO hold time from MDC on write | t <sub>H(W)</sub> | 15 | | ns | C <sub>L</sub> = 50 pF | | MDIO setup time to MDC on read | t <sub>SU(R)</sub> | 30 | | ns | C <sub>L</sub> = 50 pF on MDC | | MDIO hold time from MDC on read | t <sub>H(R)</sub> | 0 | | ns | C <sub>L</sub> = 50 pF | For the maximum value, the device supports an MDC clock speed of up to 20 MHz for faster communication with the PHYs. If the standard frequency of 2.5 MHz is used, the MIIM interface is designed to meet or exceed the IEEE 802.3 requirements of the minimum MDC high and low times of 160 ns and an MDC cycle time of minimum 400 ns, which is not possible at faster speeds. ## 6.2.9 Serial Interface (SI) Boot Master Mode The following table lists the timing specifications for SI boot master mode. Table 291 • SI Boot Timing Specifications for Master Mode | Parameter | Symbol | Minimum | Maximum | Unit Condition | |------------------|--------------------|---------|-----------------|----------------| | Clock frequency | f | | 25 <sup>1</sup> | MHz | | Clock cycle time | t <sub>C</sub> | 40 | | ns | | Clock time high | t <sub>W(CH)</sub> | 16 | | ns | | Clock time low | t <sub>W(CL)</sub> | 16 | | ns | <sup>2.</sup> Calculated as $t_C = 1/f$ . Table 291 • SI Boot Timing Specifications for Master Mode (continued) | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------------|---------------------------------|---------|---------|------|---------------------------------------------------------------------------------| | Clock rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | | 10 | ns | Between V <sub>IL(MAX)</sub> and V <sub>IH(MIN)</sub> . C <sub>L</sub> = 30 pF. | | SI_DO setup time to clock | t <sub>SU(DO)</sub> | 10 | | ns | | | SI_DO hold time from clock | t <sub>H(DO)</sub> | 10 | | ns | | | Enable active before first clock | t <sub>LEAD</sub> | 10 | | ns | | | Enable inactive after clock | t <sub>LAG</sub> | 5 | | ns | | | SI_DI setup time to clock | t <sub>SU(DI)</sub> | 22 | | ns | | | SI_DI hold time from clock | t <sub>H(DI)</sub> | -2 | | ns | | <sup>1.</sup> Frequency is programmable. The startup frequency is 8.1 MHz. ### 6.2.10 Serial Interface (SI) Master Mode All serial interface (SI) timing requirements for master mode are specified relative to the input low and input high threshold levels. The following illustration shows the timing parameters and measurement points. Figure 140 • SI Timing Diagram for Master Mode All SI signals comply with the specifications shown in the following table. The SI input timing requirements are requested at the pins of the device. Table 292 • SI Timing Specifications for Master Mode | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------------|---------------------------------|---------|-----------------|------|----------------------------------------------------------| | Clock frequency | f | | 25 <sup>1</sup> | MHz | | | Clock cycle time | t <sub>C</sub> | 40 | | ns | | | Clock time high | t <sub>W(CH)</sub> | 16 | | ns | | | Clock time low | t <sub>W(CL)</sub> | 16 | | ns | | | Clock rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | | 10 | ns | Between $V_{IL(MAX)}$ and $V_{IH(MIN)}$ . $C_L$ = 30 pF. | | SI_DO setup time to clock | t <sub>SU(DO)</sub> | 10 | | ns | | | SI_DO hold time from clock | t <sub>H(DO)</sub> | 10 | | ns | | | Enable active before first clock | t <sub>LEAD</sub> | 10 | | ns | | | Enable inactive after clock | t <sub>LAG</sub> | 15 | | ns | | | SI_DI setup time to clock | t <sub>SU(DI)</sub> | 15 | | ns | | Table 292 • SI Timing Specifications for Master Mode (continued) | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |----------------------------|--------------------|---------|---------|------|-----------| | SI_DI hold time from clock | t <sub>H(DI)</sub> | 0 | | ns | | <sup>1.</sup> Frequency is programmable. The startup frequency is 4 MHz. ### 6.2.11 Serial Interface (SI) for Slave Mode All serial interface (SI) slave mode timing requirements are specified relative to the input low and input high threshold levels. The following illustrations show the timing parameters and measurement points for SI input and output data. Figure 141 • SI Input Data Timing Diagram for Slave Mode Figure 142 • SI Output Data Timing Diagram for Slave Mode All SI signals comply with the specifications shown in the following table. The SI input timing requirements are requested at the pins of the device. Table 293 • SI Timing Specifications for Slave Mode | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |------------------|--------------------|---------|---------|------|-----------| | Clock frequency | f | | 25 | MHz | | | Clock cycle time | t <sub>C</sub> | 40 | | ns | | | Clock time high | t <sub>W(CH)</sub> | 16 | | ns | | Table 293 • SI Timing Specifications for Slave Mode (continued) | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------------------------------|---------------------|-----------------------|---------|------|---------------------------| | Clock time low | t <sub>W(CL)</sub> | 16 | | ns | | | SI_DI setup time to clock | t <sub>SU(DI)</sub> | 4 | | ns | | | SI_DI hold time from clock | t <sub>H(DI)</sub> | 4 | | ns | | | Enable active before first clock | t <sub>LEAD</sub> | 10 | | ns | | | Enable inactive after clock (input cycle) <sup>1</sup> | t <sub>LAG1</sub> | 25 | | ns | | | Enable inactive after clock (output cycle) | t <sub>LAG2</sub> | See note <sup>2</sup> | | ns | | | Enable inactive width | t <sub>W(EH)</sub> | 20 | | ns | | | SI_DO valid after clock | t <sub>V(C)</sub> | | 25 | ns | C <sub>L</sub> = 30 pF. | | SI_DO hold time from clock | t <sub>H(DO)</sub> | 0 | | ns | C <sub>L</sub> = 0 pF. | | SI_DO disable time <sup>3</sup> | t <sub>DIS1</sub> | | 20 | ns | See Figure 142, page 390. | | SI_DO disable time <sup>3</sup> | t <sub>DIS2</sub> | | 20 | ns | See Figure 142, page 390. | t<sub>LAG1</sub> is defined only for write operations to the device, not for read operations. Figure 143 • SI\_DO Disable Test Circuit #### 6.2.12 DDR SDRAM Interface This section provides the AC characteristics for the DDR3 and DDR3L SDRAM interface. The following illustration shows the DDR3/DDR3L SDRAM input timing diagram. Figure 144 • DDR SDRAM Input Timing Diagram The following table lists the AC specifications for the DDR3 and DDR3L SDRAM input signals. Table 294 • DDR3/DDR3L SDRAM Input Signal AC Characteristics | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-------------------------|--------------|------------------------------|---------|-----------------------|------|-----------| | DDR3 input voltage high | $V_{IH(AC)}$ | DDR_V <sub>REF</sub> + 0.175 | | $V_{DD\_IODDR} + 0.3$ | V | | The last rising edge on the clock is necessary for the external master to read in the data. The lag time depends on the necessary hold time on the external master data input. <sup>3.</sup> Pin begins to float when a 300 mV change from the loaded $V_{OH}$ or $V_{OL}$ level occurs. Table 294 • DDR3/DDR3L SDRAM Input Signal AC Characteristics (continued) | Parameter | Symbol | Minimum | Typical | Maximum | Unit | Condition | |-----------------------------------------------------------------|---------------------|----------------------------------------|-------------------------|-------------------------------------|------|---------------------------| | DDR3 input voltage low | V <sub>IL(AC)</sub> | -0.3 | | DDR_V <sub>REF</sub> - 0.175 | V | | | DDR3 differential input voltage | V <sub>ID(AC)</sub> | 0.4 | | V <sub>DD_IODDR</sub> | V | | | DDR3 differential crosspoint voltage | V <sub>IX(AC)</sub> | 0.5 × V <sub>DD_IODDR</sub> –<br>0.175 | | 0.5 × V <sub>DD_IODDR</sub> + 0.175 | V | | | DDR3L input voltage high | V <sub>IH(AC)</sub> | DDR_V <sub>REF</sub> + 0.160 | | V <sub>DD_IODDR</sub> + 0.3 | V | | | DDR3L input voltage low | V <sub>IL(AC)</sub> | -0.3 | | DDR_V <sub>REF</sub> - 0.160 | V | | | DDR3L differential input voltage | V <sub>ID(AC)</sub> | 0.4 | | V <sub>DD_IODDR</sub> | V | | | DDR3L differential crosspoint voltage | V <sub>IX(AC)</sub> | 0.5 × V <sub>DD_IODDR</sub> –<br>0.160 | | 0.5 × V <sub>DD_IODDR</sub> + 0.160 | V | | | DDR_DQ[7:0] input setup time relative to DDR_LDQS <sup>1</sup> | t <sub>DS</sub> | 350 | | | ps | | | DDR_DQ[15:8] input setup time relative to DDR_UDQS <sup>1</sup> | t <sub>DS</sub> | 350 | | | ps | | | DDR_DQ[7:0] input hold time relative to DDR_LDQS <sup>1</sup> | t <sub>DH</sub> | 250 | | | ps | | | DDR_DQ[15:8] input hold time relative to DDR_UDQS <sup>1</sup> | t <sub>DH</sub> | 250 | | | ps | | | Quarter period offset from clock edge | t <sub>90</sub> | | 0.25 × t <sub>CLK</sub> | | | t <sub>CLK</sub> = 3.2 ns | <sup>1.</sup> These requirements are dependent on the operation frequency of the DDR SDRAM interface. Stated limits are for DDR3-800. The following illustration shows the timing diagram for the DDR3 and DDR3L SDRAM outputs. Figure 145 • DDR SDRAM Output Timing Diagram The following table lists the AC characteristics for the DDR3 and DDR3L SDRAM output signals. Table 295 • DDR3/DDR3L SDRAM Output Signal AC Characteristics | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |--------------------------------------------------------------------------------------------------|---------------------|------------------------|---------|------------------------|------| | DDR_CK cycle time 312.5 MHz (DDR800) <sup>1</sup> | t <sub>CLK</sub> | | 3.20 | | ns | | DDR_CK/CKn duty cycle | | 48 | | 52 | % | | DDR_A, DDR_BA, DDR_CKE, DDR_nRAS, DDR_nCAS, and DDR_nWE output setup time relative to DDR_CK/CKn | t <sub>AS</sub> | 700 | | | ps | | DDR_A, DDR_BA, DDR_CKE, DDR_nRAS, DDR_nCAS, and DDR_nWE output hold time relative to DDR_CK/CKn | t <sub>AH</sub> | 800 | | | ps | | DDR_CK/CKn to DDR_DQS skew | t <sub>CLKDQS</sub> | -400 | | 400 | ps | | DDR_DQ[7:0]/DDR_LDM output setup time relative to DDR_LDQS | t <sub>DS</sub> | 400 | | | ps | | DDR_DQ[15:8]/DDR_UDM output setup time relative to DDR_UDQS | t <sub>DS</sub> | 400 | | | ps | | DDR_DQ[7:0]/DDR_LDM output hold time relative to DDR_LDQS | t <sub>DH</sub> | 500 | | | ps | | DDR_DQ[15:8]/DDR_UDM output hold time relative to DDR_UDQS | t <sub>DH</sub> | 500 | | | ps | | DDR_DQS preamble start | t <sub>DQSPRE</sub> | 0.4 × t <sub>CLK</sub> | | 0.6 × t <sub>CLK</sub> | ps | | DDR_DQS postamble end | t <sub>DQSPST</sub> | 0.4 × t <sub>CLK</sub> | | 0.6 × t <sub>CLK</sub> | ps | <sup>1.</sup> Timing reference is DDR\_CK/DDR\_CKn crossing ±0.1 V. The following illustration shows the test load circuit for the DDR3 outputs. Figure 146 • Test Load Circuit for DDR3 Outputs #### 6.2.13 JTAG Interface All AC specifications for the JTAG interface meet or exceed the requirements of IEEE 1149.1-2001. The following illustration shows the JTAG transmit and receive waveforms and required measurement points for the different signals. Figure 147 • JTAG Interface Timing Diagram All JTAG signals comply with the specifications in the following table. The JTAG receive signal requirements are requested at the pin of the device. The JTAG\_nTRST signal is asynchronous to the clock and does not have a setup or hold time requirement. Table 296 • JTAG Interface AC Specifications | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |-------------------------------------|---------------------|---------|---------|------|------------------------------| | JTAG_TCK frequency | f | | 10 | MHz | | | JTAG_TCK cycle time | t <sub>C</sub> | 100 | | ns | | | JTAG_TCK high time | t <sub>W(CH)</sub> | 40 | | ns | | | JTAG_TCK low time | t <sub>W(CL)</sub> | 40 | | ns | | | Setup time to JTAG_TCK rising | t <sub>SU</sub> | 10 | | ns | | | Hold time from JTAG_TCK rising | t <sub>H</sub> | 10 | | ns | | | TDO valid after JTAG_TCK falling | t <sub>V(C)</sub> | | 28 | ns | C <sub>L</sub> = 10 pF | | TDO hold time from JTAG_TCK falling | t <sub>H(TDO)</sub> | 0 | | ns | C <sub>L</sub> = 0 pF | | JTAG_TDO disable time <sup>1</sup> | t <sub>DIS</sub> | | 30 | ns | See Figure 148,<br>page 394. | | JTAG_nTRST time low | t <sub>W(TL)</sub> | 30 | | ns | | <sup>1.</sup> The pin begins to float when a 300 mV change from the actual $V_{OH}/V_{OL}$ level occurs. The following illustration shows the test circuit for the TDO disable time. Figure 148 • Test Circuit for TDO Disable Time ### 6.2.14 Serial Inputs/Outputs This section provides the AC characteristics for the serial I/O signals: SG0\_CLK, SG0\_DO, SG0\_DI, and SG0\_LD. These signals are GPIO alternate functions. For more information, see GPIO Overlaid Functions, page 355. The serial I/O timing diagram is shown in the following illustration. Figure 149 • Serial I/O Timing Diagram The following table lists the serial I/O timing specifications. Applies to the GPIO\_[3:0] pins when used as serial I/O. Table 297 • Serial I/O Timing Specifications | Parameter | Symbol | Minimum | Maximum | Unit | |---------------------------------------------|------------------------|---------|---------|------| | Clock frequency <sup>1</sup> | f | | 25 | MHz | | SG0_CLK clock pulse width | t <sub>W(CLK)</sub> | 40 | 60 | % | | SG0_DO valid after clock falling | t <sub>V(DO)</sub> | | 6 | ns | | SG0_DO hold time from clock falling | t <sub>H(DO)</sub> | | 6 | ns | | SG0_LD propagation delay from clock falling | t <sub>PD(LATCH)</sub> | 40 | | ns | | SG0_LD width | t <sub>W(LATCH)</sub> | 10 | | ns | | SG0_DI setup time to clock | t <sub>SU(DI)</sub> | 25 | | ns | | SG0_DI hold time from clock | t <sub>H(DI)</sub> | 4 | | ns | <sup>1.</sup> The SIO clock frequency is programmable. ### 6.2.15 Recovered Clock Outputs This section provides the AC characteristics for the recovered clock output signals, RCVRD\_CLK[3:0]. These signals are GPIO alternate functions. For more information about the GPIO pin mapping, see GPIO Overlaid Functions, page 355. The following illustration shows the test circuit for the recovered clock output signals. Figure 150 • Test Circuit for Recovered Clock Output Signals The following table lists the AC specifications for the recovered clock outputs. Table 298 • Recovered Clock Output AC Specifications | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |------------------------------------------------------------------------------------------------------------------|---------------------------------|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------| | RCVRD_CLK[3:0] clock frequency | f | | 161.33 | MHz | | | Clock duty cycle | t <sub>C</sub> | 40 | 60 | % | Measured at 50% threshold. | | RCVRD_CLK[3:0] rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | | 1.5 | ns | | | Squelching delay from SGMII signal to RCVRD_CLK[3:0] | | | 200 | ns | Squelch enabled. | | RCVRD_CLK[3:0] peak-to-peak jitter,<br>bandwidth between 12 kHz and 10 MHz <sup>1</sup> ,<br>60 second gate time | | | 200 | ps | Jitter-free input to SerDes Rx. Connected to DPLL in free-run mode or connected to DPLL TX clock in free-run mode. | | RCVRD_CLK[3:0] peak-to-peak jitter,<br>bandwidth between 10 MHz and<br>80 MHz <sup>1</sup> , 60 second gate time | | | 200 | ps | Jitter-free input to SerDes Rx.<br>Connected to DPLL in free-run<br>mode or connected to DPLL<br>TX clock in free-run mode. | <sup>1.</sup> Maximum jitter on the recovered signal. #### 6.2.16 Two-Wire Serial Interface This section provides the AC specifications for the two-wire serial interface signals TWI\_SCL and TWI\_SDA. The two-wire serial interface signals are GPIO alternate functions. For more information about the GPIO pin mapping, see GPIO Overlaid Functions, page 355. The two-wire serial interface signals are compatible with the Philips I2C-BUS specifications, except for the minimum rise time and fall time requirements for fast mode. Figure 151 • Two-Wire Serial Read Timing Diagram Figure 152 • Two-Wire Serial Write Timing Diagram The following table lists the AC specifications for the serial interface. Standard mode is defined as 100 kHz and fast mode is 400 kHz. The data in this table assumes that the software-configurable two-wire interface timing parameters, SS\_SCL\_HCNT, SS\_SCL\_LCNT, FS\_SCL\_HCNT, and FS\_SCL\_LCNT, are set to valid values for the selected speed. Table 299 • Two-Wire Serial Interface AC Specifications | | | Standard I | Mode | Fast Mode | ı | | | |-----------------------------------------------------------------------------|---------------------|------------|---------|-----------|---------|------|------------------------------------------------------------------| | Parameter | Symbol | Minimum | Maximum | Minimum | Maximum | Unit | Condition | | TWI_SCL clock frequency | f | | 100 | | 400 | kHz | | | TWI_SCL low period | t <sub>LOW</sub> | 4.7 | | 1.3 | | μs | | | TWI_SCL high period | t <sub>HIGH</sub> | 4.0 | | 0.6 | | μs | | | TWI_SCL and TWI_SDA rise time | | | 1000 | | 300 | ns | | | TWI_SCL and TWI_SDA fall time | | | 300 | | 300 | ns | | | TWI_SDA setup time to TWI_SCL fall | t <sub>SU_DAT</sub> | 250 | | 100 | 300 | ns | | | TWI_SDA hold time to TWI_SCL fall <sup>1</sup> | t <sub>HD_DAT</sub> | 300 | 3450 | 300 | 900 | ns | 300 ns delay<br>enabled in<br>ICPU_CFG::TWI_<br>CONFIG register. | | Setup time for repeated START condition | t <sub>SU_STA</sub> | 4.7 | | 0.6 | | μs | | | Hold time after repeated START condition | t <sub>HD_STA</sub> | 4.0 | | 0.6 | | μs | | | Bus free time between STOP and START conditions | t <sub>BUF</sub> | 4.7 | | 1.3 | | μs | | | Clock to valid data out <sup>2</sup> | t <sub>VD_DAT</sub> | 300 | | 300 | | ns | | | Pulse width of spike<br>suppressed by input filter<br>on TWI_SCL or TWI_SDA | | 0 | 5 | 0 | 5 | ns | | An external device must provide a hold time of at least 300 ns for the TWI\_SDA signal to bridge the undefined region of the falling edge of the TWI\_SCL signal. Some external devices may require more data in hold time (target device's t<sub>HD\_DAT</sub>) than what is provided by t<sub>VD\_DAT</sub>, for example, 300 ns to 900 ns. The minimum value of t<sub>VD\_DAT</sub> is adjustable; the value given represents the recommended minimum value, which is enabled in ICPU\_CFG::TWI\_CONFIG.TWI\_DELAY\_ENABLE. #### 6.2.17 IEEE 1588 Time Tick Outputs This section provides the AC specifications for the IEEE 1588 time tick output signals PTP\_[3:0]. The PTP signals are GPIO alternate functions. For more information, see GPIO Overlaid Functions, page 355. Table 300 • IEEE1588 Time Tick Output AC Specifications | Parameter | Symbol | Minimum | Maximum | Unit | Condition | |--------------------------------------------------------------------------------|---------------------------------|---------|---------|------|----------------------------| | PTP[3:0] frequency <sup>1</sup> | f | | 25 | MHz | | | Clock duty cycle <sup>2</sup> | | 45 | 55 | % | Measured at 50% threshold. | | PTP[3:0] rise time and fall time | t <sub>R</sub> , t <sub>F</sub> | 1 | | ns | 20% to 80% threshold. | | PTP[3:0] peak-to-peak jitter, bandwidth between 12 kHz and 10 MHz <sup>3</sup> | | | 200 | ps | | | PTP[3:0] peak-to-peak jitter, bandwidth between 10 MHz and 80 MHz <sup>3</sup> | | | 200 | ps | | <sup>1.</sup> Frequency is programmable. ### 6.3 Current and Power Consumption This section provides the current and power consumption requirements for the VSC7415 device. ### 6.3.1 Current Consumption The following tables show the operating current for the device. Typical current consumption values are over a full traffic load, nominal process and supply voltages, and at 25 °C case temperature. Maximum current consumption values are over full traffic load and worst-case process, temperature, and supply settings. The following table shows current consumption values for the device. Table 301 • Operating Current | Parameter | Symbol | Typical | Maximum<br>(T <sub>J_MAX</sub> = 110 °C) | Maximum<br>(T <sub>J_MAX</sub> = 125 °C) | Unit | |------------------------------------------------------------------------|-----------------------|---------|------------------------------------------|------------------------------------------|------| | V <sub>DD</sub> operating current, 1.0 V | I <sub>DD</sub> | 1.4 | 2.5 | 3.3 | Α | | V <sub>DD_A</sub> operating current, 1.0 V | I <sub>DD_A</sub> | 1.3 | 1.6 | 1.6 | Α | | V <sub>DD_HS</sub> operating current, 1.0 V | I <sub>DD_HS</sub> | 0.24 | 0.25 | 0.25 | Α | | V <sub>DD_VS</sub> operating current, 1.0 V or 1.2 V | I <sub>DD_VS</sub> | 0.15 | 0.15 | 0.15 | Α | | V <sub>DD_AL</sub> operating current, 1.0 V | I <sub>DD_AL</sub> | 0.04 | 0.06 | 0.06 | Α | | V <sub>DD_AH</sub> operating current, 2.5 V | I <sub>DD_AH</sub> | 0.25 | 0.25 | 0.25 | Α | | V <sub>DD_IODDR</sub> operating current <sup>1</sup> , 1.35 V or 1.5 V | I <sub>DD_IODDR</sub> | 0.08 | 0.18 | 0.18 | Α | | V <sub>DD_IO</sub> operating current <sup>2</sup> , 2.5 V | I <sub>DD_IO</sub> | 0.05 | 0.065 | 0.065 | Α | DDR3 on-die termination is disabled. Both high and low clock periods are configured to the identical value using DEVCPU\_PTP::PIN\_WF\_HIGH\_PERIOD and DEVCPU\_PTP::PIN\_WF\_LOW\_PERIOD. <sup>3.</sup> Timing corrections performed by register writes and high/low periods that do not match a fixed number of 156.25 MHz clock cycles will create jitter up to 3.5 ns. Unloaded pins. #### 6.3.2 Power Consumption The following table shows power consumption values when the device is at maximum configuration; all interfaces and functions enabled (2 × cuPHY + 2 × GbE (dual media), 2 × GbE, 2 × 2.5 GbE, 4 × DPLL. For information about core clock frequency selection, see Low Power Mode, page 305. Table 302 • Power Consumption | Parameter | Typical | Maximum<br>(T <sub>J_MAX</sub> = 110 °C) | Maximum<br>(T <sub>J_MAX</sub> = 125 °C) | Unit | |----------------------------------------------|---------|------------------------------------------|------------------------------------------|------| | Power consumption, clock frequency = 156 MHz | 4.0 | 6.2 | 6.5 | W | | Power consumption, clock frequency = 52 MHz | 3.3 | 5.1 | 5.4 | W | The following table shows typical power consumption reductions for reduced configurations compared to maximum configurations. Table 303 • Power Consumption, Reduced Configuration | Parameter | Typical | Unit | |----------------------------------------------------------|---------|------| | Power consumption reduction for each cuPHY port disabled | 0.3 | W | | Power consumption reduction for each DPLL port disabled | 0.3 | W | ### 6.3.3 Power Supply Sequencing During power on and off, $V_{DD\_A}$ , $V_{DD\_HS}$ , and $V_{DD\_VS}$ must never be more than 300 mV above $V_{DD}$ . $V_{DD\_HS}$ and $V_{DD\_VS}$ must be powered, even if the associated interface is not used. These power supplies must not remain at ground or left floating. A maximum delay of 100 ms from $V_{DD\_IODDR}$ to $V_{DD}$ is recommended. There is no requirement from $V_{DD}$ to $V_{DD\_IODDR}$ . The $V_{DD\_IODDR}$ supply can remain at ground or left floating if not used. If $V_{DD\_IODDR}$ is grounded, DDR\_Vref must also be grounded. There are no sequencing requirements for V<sub>DD</sub> <sub>IO</sub>. The nRESET and JTAG\_nTRST inputs must be held low until all power supply voltages have reached their recommended operating condition values. ### 6.4 Operating Conditions The following table shows the recommended operating conditions. Table 304 • Recommended Operating Conditions | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |-------------------------------------------------------------------|--------------------|---------|---------|---------|------| | Power supply voltage for core supply | V <sub>DD</sub> | 0.95 | 1.0 | 1.05 | V | | Power supply voltage for analog circuits | V <sub>DD_A</sub> | 0.95 | 1.0 | 1.05 | V | | Power supply voltage for 10G interface, 1.0 V | V <sub>DD_HS</sub> | 0.95 | 1.0 | 1.05 | V | | Power supply voltage for 1G and 6G interfaces, 1.0 V <sup>1</sup> | V <sub>DD_VS</sub> | 0.95 | 1.0 | 1.05 | V | | Power supply voltage for 1G and 6G interfaces, 1.2 V | V <sub>DD_VS</sub> | 1.14 | 1.2 | 1.26 | V | | Power supply voltage for copper PHY analog circuits | $V_{DD\_AL}$ | 0.95 | 1.0 | 1.05 | V | | Power supply voltage for copper PHY interface | V <sub>DD_AH</sub> | 2.375 | 2.5 | 2.625 | V | | Power supply voltage for DDR3 interface | $V_{DD\_IODDR}$ | 1.425 | 1.5 | 1.575 | V | | Power supply voltage for DDR3L interface | $V_{DD\_IODDR}$ | 1.28 | 1.35 | 1.45 | V | Table 304 • Recommended Operating Conditions (continued) | Parameter | Symbol | Minimum | Typical | Maximum | Unit | |-----------------------------------------------------|--------------|-------------|---------|---------|------| | Power supply voltage for GPIO and miscellaneous I/O | $V_{DD\_IO}$ | 2.375 | 2.5 | 2.625 | V | | Operating temperature <sup>2</sup> | T | <b>–</b> 40 | | 125 | °C | V<sub>DD\_VS</sub> should be powered with the 1.2 V supply to meet 1000BASE-KX, XAUI, 10GBASE-CX4, 10GBASE-KX4, and PCIe specifications ### 6.5 Stress Ratings **Warning** Stresses listed in the following table may be applied to devices one at a time without causing permanent damage. Functionality at or exceeding the values listed is not implied. Exposure to these values for extended periods may affect device reliability. Table 305 • Stress Ratings | Parameter | Symbol | Minimum | Maximum | Unit | |-----------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|---------|------| | Power supply voltage for core supply | $V_{DD}$ | -0.3 | 1.10 | V | | Power supply voltage for analog circuits | $V_{DD\_A}$ | -0.3 | 1.10 | V | | Power supply voltage for 10G interface | V <sub>DD_HS</sub> | -0.3 | 1.32 | V | | Power supply voltage for 1G and 6G interfaces | V <sub>DD_VS</sub> | -0.3 | 1.32 | V | | Power supply voltage for copper PHY analog circuits | $V_{DD\_AL}$ | -0.3 | 1.10 | V | | Power supply voltage for copper PHY interface | $V_{DD\_AH}$ | -0.3 | 2.75 | V | | Power supply voltage for DDR I/O buffers | V <sub>DD_IODDR</sub> | -0.3 | 1.98 | V | | Power supply voltage for GPIO and miscellaneous I/O | $V_{DD\_IO}$ | -0.3 | 2.75 | V | | Storage temperature | T <sub>S</sub> | <b>-</b> 55 | 125 | °C | | Electrostatic discharge voltage, charged device model | V <sub>ESD_CDM</sub> | -500 | 500 | V | | Electrostatic discharge voltage, human body model, CLKOUTPLL2_N and CLKOUTPLL2_P pins | V <sub>ESD_HBM</sub> | <b>–1750</b> | 1750 | V | | Electrostatic discharge voltage, human body model, all pins except the CLKOUTPLL2_N and CLKOUTPLL2_P pins | V <sub>ESD_HBM</sub> | See note <sup>1</sup> | | V | This device has completed all required testing as specified in the JEDEC standard JESD22-A114, Electrostatic Discharge (ESD) Sensitivity Testing Human Body Model (HBM), and complies with a Class 2 rating. The definition of Class 2 is any part that passes an ESD pulse of 2000 V, but fails an ESD pulse of 4000 V. **Warning** This device can be damaged by electrostatic discharge (ESD) voltage. Microsemi recommends that all integrated circuits be handled with appropriate precautions. Failure to observe proper handling and installation procedures may adversely affect reliability of the device. <sup>2.</sup> Minimum specification is ambient temperature, and the maximum is junction temperature. # 7 Pin Descriptions The VSC7415 device has 324 pins, which are described in this section. The pin information is also provided as an attached Microsoft Excel file, so that you can copy it electronically. In Adobe Reader, double-click the attachment icon. ### 7.1 Pin Diagram The following illustration is a representation of the VSC7415 device, as seen from the top view looking through the device. For clarity, the device is shown in two halves, the top left and the top right. Figure 153 • Pin Diagram, Top Left | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | |---|-------------|--------------|--------------|------------|--------------|----------|----------|----------|----------| | Α | VSS_65 | REFCLK_N | REFCLK_P | S5_RXN | S4_RXN | S3_RXN | S2_RXN | S1_RXN | SO_RXN | | В | CLKOUTPLL_N | CLKOUTPLL_P | S6_TXN | S5_RXP | S4_RXP | S3_RXP | S2_RXP | S1_RXP | SO_RXP | | С | S6_RXN | S6_RXP | S6_TXP | S5_TXN | S4_TXN | S3_TXN | S2_TXN | S1_TXN | SO_TXN | | D | PCIE_TXN | PCIE_TXP | VDD_VS_1 | S5_TXP | S4_TXP | S3_TXP | S2_TXP | S1_TXP | SO_TXP | | Ε | PCIE_RXN | PCIE_RXP | VDD_VS_2 | VDD_VS_3 | VDD_VS_4 | VDD_VS_5 | VDD_VS_6 | VDD_1 | VDD_2 | | F | CLKINO_N | CLKINO_P | CLKOUTO_N | CLKOUTO_P | VDD_A_1 | VDD_A_2 | VSS_1 | VSS_2 | VSS_3 | | G | CLKIN1_N | CLKIN1_P | CLKOUT1_N | CLKOUT1_P | VDD_A_3 | VSS_7 | VSS_8 | VSS_9 | VSS_10 | | Н | VSS_14 | VSS_15 | VDD_HS_1 | VDD_A_4 | VDD_11 | VSS_16 | VSS_17 | VSS_18 | VSS_19 | | J | CLKOUT2_N | CLKOUT2_P | VSS_23 | VDD_A_5 | VDD_13 | VSS_24 | VSS_25 | VSS_26 | VSS_27 | | K | VSS_31 | VSS_32 | VDD_HS_2 | VDD_A_6 | VDD_15 | VSS_33 | VSS_34 | VSS_35 | VSS_36 | | L | CLKIN2_N | CLKIN2_P | VSS_40 | VDD_A_7 | VDD_17 | VSS_41 | VSS_42 | VSS_43 | VSS_44 | | M | VSS_48 | VSS_49 | VDD_HS_3 | VDD_A_8 | VDD_19 | VSS_50 | VSS_51 | VSS_52 | VSS_53 | | N | CLKOUT3_N | CLKOUT3_P | VSS_57 | VDD_A_9 | VDD_22 | VDD_23 | VDD_24 | VDD_25 | VDD_26 | | Р | VSS_58 | VSS_59 | VDD_HS_4 | RESERVED_4 | RESERVED_3 | VDD_IO_1 | VDD_IO_2 | VDD_IO_3 | VDD_IO_4 | | R | CLKIN3_N | CLKIN3_P | VSS_60 | JTAG_nTRST | VSS_64 | SI_DI | GPIO_0 | GPIO_4 | GPIO_8 | | Т | VSS_61 | VSS_62 | VDD_HS_5 | JTAG_TMS | JTAG_ICE_nEN | SI_DO | GPIO_1 | GPIO_5 | GPIO_9 | | U | REFCLK2_N | REFCLK2_P | VSS_63 | JTAG_TDI | JTAG_TDO | SI_nCS0 | GPIO_2 | GPIO_6 | GPIO_10 | | ٧ | VSS_67 | CLKOUTPLL2_N | CLKOUTPLL2_P | JTAG_TCK | nRESET | SI_CLK | GPIO_3 | GPIO_7 | GPIO_11 | Figure 154 • Pin Diagram, Top Right | | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | | |---|---------------|---------------|----------|----------|-------------|----------|------------|-----------|------------|---| | | P1_DON | P1_D1N | P1_D2N | P1_D3N | PO_DON | P0_D1N | P0_D2N | PO_D3N | VSS_66 | Α | | | P1_D0P | P1_D1P | P1_D2P | P1_D3P | PO_DOP | P0_D1P | P0_D2P | P0_D3P | RESERVED_0 | В | | | VDD_AL_1 | VDD_AL_2 | VDD_AL_3 | VDD_AL_4 | VDD_AH_1 | VDD_AH_2 | VDD_AH_3 | VDD_AH_4 | RESERVED_1 | С | | , | SERDES_Rext_1 | SERDES_Rext_0 | REF_Rext | REF_FILT | THERMDC | THERMDA | DDR_DQ13 | DDR_DQ10 | DDR_DQ8 | D | | | VDD_3 | VDD_4 | VDD_5 | VDD_6 | VDD_7 | DDR_DQ15 | DDR_UDM | DDR_UDQSn | DDR_UDQS | Е | | | VSS_4 | VSS_5 | VSS_6 | VDD_8 | VDD_9 | DDR_DQ14 | DDR_DQ9 | DDR_DQ11 | DDR_DQ12 | F | | | VSS_11 | VSS_12 | VSS_13 | VDD_10 | VDD_IODDR_1 | DDR_nCS1 | RESERVED_2 | DDR_nWE | DDR_CKE | G | | | VSS_20 | VSS_21 | VSS_22 | VDD_12 | VDD_IODDR_2 | DDR_BA2 | DDR_BA0 | DDR_BA1 | DDR_A10 | Н | | | VSS_28 | VSS_29 | VSS_30 | VDD_14 | VDD_IODDR_3 | DDR_A1 | DDR_A3 | DDR_A5 | DDR_A7 | J | | | VSS_37 | VSS_38 | VSS_39 | VDD_16 | VDD_IODDR_4 | DDR_A9 | DDR_A12 | DDR_CK | DDR_CKn | Κ | | | VSS_45 | VSS_46 | VSS_47 | VDD_18 | VDD_IODDR_5 | DDR_A11 | DDR_A4 | DDR_A6 | DDR_A8 | L | | | VSS_54 | VSS_55 | VSS_56 | VDD_20 | VDD_21 | DDR_A13 | DDR_nCS0 | DDR_nCAS | DDR_A0 | М | | | VDD_27 | VDD_28 | VDD_29 | VDD_30 | VDD_31 | DDR_A2 | DDR_A15 | DDR_A14 | DDR_nRAS | N | | | VDD_IO_5 | VDD_IO_6 | VDD_IO_7 | VDD_IO_8 | VDD_32 | DDR_ODT | DDR_DQ7 | DDR_DQ0 | DDR_DQ2 | Р | | | GPIO_12 | GPIO_16 | GPIO_20 | GPIO_24 | GPIO_28 | DDR_DQ5 | DDR_DQ6 | DDR_LDQS | DDR_LDQSn | R | | _ | GPIO_13 | GPIO_17 | GPIO_21 | GPIO_25 | GPIO_29 | GPIO_32 | DDR_LDM | DDR_DQ4 | DDR_DQ1 | Т | | | GPIO_14 | GPIO_18 | GPIO_22 | GPIO_26 | GPIO_30 | GPIO_33 | GPIO_35 | DDR_Rext | DDR_DQ3 | U | | _ | GPIO_15 | GPIO_19 | GPIO_23 | GPIO_27 | GPIO_31 | GPIO_34 | GPIO_36 | DDR_Vref | VSS_68 | ٧ | # 7.2 Pins by Function This section contains the functional pin descriptions for the VSC7415 device. The following table lists the definitions for the pin type symbols. Table 306 • Pin Type Symbol Definitions | Symbol | Pin Type | Description | |--------|-----------------|--------------------------------------------------| | A | Analog input | Analog input for sensing variable voltage levels | | ABIAS | Analog bias | Analog bias pin | | DIFF | Differential | Differential signal pair | | I | Input | Input signal | | 0 | Output | Output signal | | I/O | Bidirectional | Bidirectional input or output signal | | OZ | 3-state output | Output | | LVDS | Input or output | Low voltage differential signal | | LVCMOS | Input or output | Low voltage CMOS signal | | 3V | | 3.3 V-tolerant | | ST | Schmitt-trigger | Input has Schmitt-trigger circuitry | Table 306 • Pin Type Symbol Definitions (continued) | Symbol | Pin Type | Description | |--------|--------------------------|-----------------------------------| | TD | Termination differential | Internal differential termination | ### 7.2.1 DDR SDRAM Interface The following table lists the pins associated with the DDR3/DDR3L SDRAM interface. Table 307 • DDR3/DDR3L SDRAM Pins | Name | I/O | Type | Level | Description | |-----------------------|-----|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DDR_A[15:0] | 0 | | SSTL | SDRAM address outputs. | | | | | | Provide row and column addresses to the SDRAM. | | DDR_BA[2:0] | 0 | | SSTL | SDRAM bank address outputs. | | | | | | DDR_BA[2:0] define to which bank an ACTIVE, READ, WRITE, or PRECHARGE command is applied. | | DDR_CK | 0 | DIFF | SSTL | SDRAM differential clock. Differential clock to external SDRAM. | | DDR_CKn | | | | DDR_CK is the true part of the differential signal. | | | | | | DDR_CKn is the complement part. | | DDR_CKE | 0 | | SSTL | SDRAM clock enable. | | | | | | 0: Disables clock in external SDRAM. | | | | | | 1: Enables clock in external SDRAM. | | DDR_nCS[1:0] | 0 | | SSTL | SDRAM chip selects. Active low. | | DDR_DQ[15:0] | I/O | | SSTL | SDRAM data bus. | | DDR_LDM | 0 | | SSTL | SDRAM data mask outputs. | | DDR_UDM | | | | DDR_LDM and DDR_UDM are mask signals for data written to the SDRAM. DDR_LDM corresponds to data on DDR_DQ[7:0], and DDR_UDM corresponds to data on DDR_DQ[15:8]. | | DDR_LDQS | I/O | DIFF, TD | SSTL | SDRAM differential data strobes. | | DDR_LDQSn | | | | Bidirectional differential signal that follows data direction. Used by | | DDR_UDQS<br>DDR_UDQSn | | | | SDRAM to capture data on write operations. Edge-aligned with data from SDRAM during read operations and used by the device to capture data. | | _ | | | | DDR_LDQS corresponds to data on DDR_DQ[7:0], and DDR_UDQS corresponds to data on DDR_DQ[15:8]. | | DDR_nRAS | 0 | | SSTL | SDRAM command outputs. | | DDR_nCAS<br>DDR_nWE | | | | DDR_nRAS, DDR_nCAS, and DDR_nWE (along with DDR_nCS) define the command being entered. | | DDR_ODT | 0 | | SSTL | Control signal for the attached DDR3/DDR3L SDRAM devices on-<br>die termination. | | DDR_Rext | | ABIAS | Analog | External DDR impedance calibration. | | | | | | Connect the pin through an external 240 $\Omega$ ±1% resistor to ground. | | DDR_Vref | | ABIAS | Analog | Input reference voltage. | | | | | | Provides the input switching reference voltage to the SSTL DDR signals. | #### 7.2.2 DPLL Clock The following table lists the pins for the DPLL clock. Table 308 • DPLL Clock Pins | Name | I/O | Level | Description | |-----------------|-----|-------|----------------------------------| | CLKIN[3:0]_N/P | 1 | CML | Differential DPLL clock inputs. | | CLKOUT[3:0]_N/P | 0 | CML | Differential DPLL clock outputs. | ### 7.2.3 General-Purpose Inputs and Outputs The following table lists the general-purpose I/O (GPIO) pins. Leave GPIO pins unconnected when not in use. Many of the GPIO pins serve multiple functions. For more information about the overlaid functions and how to configure them, GPIO Overlaid Functions, page 355. Table 309 • GPIO Pins | Name | I/O | Level | Description | |-------------|-----|-------|-------------------------------------| | GPIO_[36:0] | I/O | CMOS | General-purpose inputs and outputs. | #### 7.2.4 JTAG Interface The following table lists the pins associated with the JTAG interface. The JTAG interface can be connected to the boundary scan TAP controller or the internal VCore-III TAP controller for software debug as described under the JTAG\_ICE\_nEN signal. The JTAG signals are not 5 V tolerant. Table 310 • JTAG Interface Pins | Name | I/O | Type | Level | Description | |--------------|-----|--------|-------|----------------------------------------------------------------------------------------------------------------------------------| | JTAG_ICE_nEN | I | ST, 3V | CMOS | 0: Enables VCore-III debug interface over the JTAG interface. | | | | | | 1: Enables normal JTAG I/O over the JTAG interface. | | | | | | JTAG_ICE_nEN should be pulled either high or low using a resistor of 10 k $\Omega$ or less to enable the desired operating mode. | | JTAG_nTRST | I | ST, 3V | CMOS | JTAG test reset, active low. For normal device operation, JTAG_nTRST should be pulled low. | | JTAG_TCK | I | ST, 3V | CMOS | JTAG clock. | | JTAG_TDI | I | ST, 3V | CMOS | JTAG test data in. | | JTAG_TDO | 0 | OZ, 3V | CMOS | JTAG test data out. | | JTAG_TMS | I | ST, 3V | CMOS | JTAG test mode select. | ### 7.2.5 MII Management Interface The following table lists the pins associated with the MII Management interface. The MIIM signals are GPIO alternate functions. For more information about the GPIO pin mapping, see GPIO Overlaid Functions, page 355. Table 311 • MII Management Interface Pins | Name | I/O | Туре | Level | Description | |-------|-----|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MDC1 | I/O | 3V | CMOS | Management data clock. | | | | | | MDC1 is sourced by the station management entity (the device) to the PHY as the timing reference for transfer of information on the MDIO1 signal. MDC1 is an aperiodic signal. | | MDIO1 | I/O | 3V | CMOS | Management data input/output. | | | | | | MDIO1 is a bidirectional signal between a PHY and the device, used to transfer control and status information. Control information is driven by the device synchronously with respect to MDC1 and is sampled synchronously by the PHY. Status information is driven by the PHY synchronously with respect to MDC1 and is sampled synchronously by the device. | ### 7.2.6 Miscellaneous The following table lists the pins associated with a particular interface or facility on the device. Table 312 • Miscellaneous Pins | Name | I/O | Туре | Level | Description | |-------------------|-----|--------|--------|-----------------------------------------------------------------------------------------------------| | nRESET | I | 3V | CMOS | Global device reset, active low. | | REF_FILT | | ABIAS | Analog | Copper media reference filter pin. Connect a 1.0 µF external capacitor between pin and ground. | | REF_Rext | | ABIAS | Analog | Copper media reference external pin. Connect a 2.0 k $\Omega$ (1%) resistor between pin and ground. | | RESERVED_0 | | Analog | Analog | Leave floating or connect to test point. | | RESERVED_1 | | | | | | RESERVED_2 | 0 | | SSTL | Leave floating. | | RESERVED_3 | | Analog | Analog | Tie to V <sub>SS</sub> . | | RESERVED_4 | | | | | | SERDES_Rext_[1:0] | | Analog | Analog | Analog bias calibration. | | | | | | Connect an external 620 $\Omega$ ±1% resistor between SERDES_Rext_1 and SERDES_Rext_0. | | THERMDA | | Analog | Analog | Thermal diode anode (p-junction). | | THERMDC | | Analog | Analog | Thermal diode cathode (n-junction). Connected on-die to $V_{\mbox{\scriptsize SS}}.$ | ### 7.2.7 PCI Express Interface The following table lists the pins associated with PCI Express (PCIe). Table 313 • PCI Express Interface Pins | Name | I/O | Туре | Level | Description | |----------|-----|----------|-------|---------------------------------| | PCIE_RXN | I | DIFF, TD | CML | Differential PCIe data inputs. | | PCIE_RXP | | | | | | PCIE_TXN | 0 | DIFF | CML | Differential PCIe data outputs. | | PCIE_TXP | | | | | ## 7.2.8 Power Supplies and Ground The following table lists the power supply and ground pins. Table 314 • Power Supply and Ground Pins | Name | Type | Description | |-----------------|--------|---------------------------------------------------------------| | VDD_[32:1] | Power | 1.0 V power supply voltage for core | | VDD_A_[9:1] | Power | 1.0 V power supply voltage for analog circuits | | VDD_AH_[4:1] | Power | 2.5 V power supply for copper PHY interface | | VDD_AL_[4:1] | Power | 1.0 V power supply for copper PHY analog circuits | | VDD_HS_[5:1] | Power | 1.0 V or 1.2 V power supply for SERDES10G | | VDD_IO_[8:1] | Power | 2.5 V power supply for GPIO and miscellaneous I/Os | | VDD_IODDR_[5:1] | Power | 1.35 V or 1.5 V power supply for DDR3/DDR3L interface | | VDD_VS_[6:1] | Power | 1.0 V or 1.2 V power supply voltage for SERDES1G and SERDES6G | | VSS_[68:1] | Ground | Ground reference | #### **7.2.9 SERDES1G** The following table lists the pins that use the SERDES1G differential macro. For information about the protocols and data rates supported by the SERDES1G macro, see Supported SerDes Interfaces, page 29. Table 315 • SERDES1G Pins | Name | I/O | Type | Level | Description | |------------|-----|------|-------|-----------------------------------------| | S4_RXN | I | TD | LVDS | Differential 1G NPI data inputs. | | S4_RXP | | | | | | S4_TXN | 0 | | LVDS | Differential 1G NPI data outputs. | | S4_TXP | | | | | | S[3:2]_RXN | I | TD | LVDS | Differential 1G data inputs. | | S[3:2]_RXP | | | | | | S[3:2]_TXN | 0 | | LVDS | Differential 1G data outputs. | | S[3:2]_TXP | | | | | | S[1:0]_RXN | I | TD | LVDS | Differential 1G data inputs/dual media. | | S[1:0]_RXP | | | | | Table 315 • SERDES1G Pins (continued) | Name | I/O | Туре | Level | Description | |------------|-----|------|-------|------------------------------------------| | S[1:0]_TXN | 0 | | LVDS | Differential 1G data outputs/dual media. | | S[1:0]_TXP | | | | | #### 7.2.10 **SERDES6G** The following table lists the pins that use the SERDES6G differential macro. For information about the protocols and data rates supported by the SERDES6G macro, see Table 6, page 29. Table 316 • SERDES6G Pins | Name | I/O | Туре | Level | Description | |------------|-----|------|-------|----------------------------| | S[6:5]_RXN | I | TD | CML | Differential data inputs. | | S[6:5]_RXP | | | | 1G/2.5G | | S[6:5]_TXN | 0 | | CML | Differential data outputs. | | S[6:5]_TXP | | | | 1G/2.5G | #### 7.2.11 Serial CPU Interface The serial CPU interface (SI) can be used as a serial slave, master, or boot interface. As a slave interface, it allows external CPUs to access internal registers. As a master interface, it allows the device to access external devices using a programmable protocol. The serial CPU interface also allows the internal VCore-III CPU system to boot from an attached serial memory device when the VCore\_CFG signals are set appropriately. The following table lists the pins associated with the serial CPU interface (SI). Table 317 • Serial CPU Interface Pins | Name | I/O | Туре | Level | Description | |---------|-----|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------| | SI_CLK | I/O | ST, 3V | LVCMOS | Slave mode: Input receiving serial interface clock from external master. | | | | | | Master mode: Output driven with clock to external device. | | | | | | Boot mode: Output driven with clock to external serial memory device. | | SI_DI | I | ST, 3V | LVCMOS | Slave mode: Input receiving serial interface data from external master. | | | | | | Master mode: Input data from external device. | | | | | | Boot mode: Input boot data from external serial memory device. | | SI_DO | 0 | OZ, 3V | LVCMOS | Slave mode: Output transmitting serial interface data to external master. | | | | | | Master mode: Output data to external device. | | | | | | Boot mode: Output boot control data to external serial memory device. | | SI_nCS0 | I/O | ST, 3V | LVCMOS | Slave mode: Input used to enable SI slave interface. | | | | | | 0 = Enabled | | | | | | 1 = Disabled | | | | | | Master mode: Output driven low while accessing external device. | | | | | | Boot mode: Output driven low while booting from EEPROM or serial flash to internal VCore-III CPU system. Released when booting is completed. | ### 7.2.12 System Clock Interface The following table lists the pins associated with the system clock interface. Table 318 • System Clock Interface Pins | Name | I/O | Type | Level | Description | |------------------------|-----|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CLKOUTPLL_N | 0 | | LVDS | PLL clock output. Leave floating if not used. | | CLKOUTPLL_P | | | | | | CLKOUTPLL2_N | 0 | | LVDS | PLL2 clock output. Leave floating if not used. | | CLKOUTPLL2_P | | | | | | REFCLK_N | I | TD | LVDS | Reference clock inputs. | | REFCLK_P | | | LVCMOS | The inputs can be either differential or single-ended. | | REFCLK2_N<br>REFCLK2_P | | | | In differential mode (LVDS), REFCLK_P/REFCLK2_P is the true part of the differential signal, and REFCLK_N/REFCLK_N is the complement part of the differential signal. | | | | | | In single-ended mode (LVCMOS), REFCLK_P/REFCLK2_P is used as single-ended LVTTL input. REFCLK_N/REFCLK2_N should be left floating, and the PLL registers must be configured for single-ended operation. | | | | | | Required applied frequency depends on REFCLK_CONF[2:0] and REFCLK2_CONF[2:0] input state. | ### 7.2.13 Twisted Pair Interface The following table lists the pins associated with the twisted pair interface. Table 319 • Twisted Pair Interface Pins | Name | I/O | Type | Description | |--------|-----|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P0_D0P | I/O | A <sub>DIFF</sub> | Tx/Rx channel A positive signal. | | P1_D0P | | | Positive differential signal connected to the positive primary side of the transformer. This pin signal forms the positive signal of the A data channel. In all three speeds, these pins generate the secondary side signal, normally connected to RJ-45 pin 1. | | P0_D0N | I/O | A <sub>DIFF</sub> | Tx/Rx channel A negative signal. | | P1_D0N | | | Negative differential signal connected to the negative primary side of the transformer. This pin signal forms the negative signal of the A data channel. In all three speeds, these pins generate the secondary side signal, normally connected to RJ-45 pin 2. | | P0_D1P | I/O | A <sub>DIFF</sub> | Tx/Rx channel B positive signal. | | P1_D1P | | | Positive differential signal connected to the positive primary side of the transformer. This pin signal forms the positive signal of the B data channel. In all three speeds, these pins generate the secondary side signal, normally connected to RJ-45 pin 3. | | P0_D1N | I/O | A <sub>DIFF</sub> | Tx/Rx channel B negative signal. | | P1_D1N | | | Negative differential signal connected to the negative primary side of the transformer. This pin signal forms the negative signal of the B data channel. In all three speeds, these pins generate the secondary side signal, normally connected to RJ-45 pin 6. | | P0_D2P | I/O | A <sub>DIFF</sub> | Tx/Rx channel C positive signal. | | P1_D2P | | | Positive differential signal connected to the positive primary side of the transformer. This pin signal forms the positive signal of the C data channel. In 1000-Mbps mode, these pins generate the secondary side signal, normally connected to RJ-45 pin 4 (pins not used in 10/100 Mbps modes). | Table 319 • Twisted Pair Interface Pins (continued) | Name | I/O | Type | Description | |--------|-----|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P0_D2N | I/O | A <sub>DIFF</sub> | Tx/Rx channel C negative signal. | | P1_D2N | | | Negative differential signal connected to the negative primary side of the transformer. This pin signal forms the negative signal of the C data channel. In 1000-Mbps mode, these pins generate the secondary side signal, normally connected to RJ-45 pin 5 (pins not used in 10/100 Mbps modes). | | P0_D3P | I/O | A <sub>DIFF</sub> | Tx/Rx channel D positive signal. | | P1_D3P | | | Positive differential signal connected to the positive primary side of the transformer. This pin signal forms the positive signal of the D data channel. In 1000-Mbps mode, these pins generate the secondary side signal, normally connected to RJ-45 pin 7 (pins not used in 10/100 Mbps modes). | | P0_D3N | I/O | A <sub>DIFF</sub> | Tx/Rx channel D negative signal. | | P1_D3N | | | Negative differential signal connected to the negative primary side of the transformer. This pin signal forms the negative signal of the D data channel. In 1000-Mbps mode, these pins generate the secondary side signal, normally connected to RJ-45 pin 8 (pins not used in 10/100 Mbps modes). | ## 7.3 Pins by Number This section provides a numeric list of the pins. | A1 | VSS_65 | |------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | A2 | REFCLK_N | | A3 | REFCLK_P | | A4 | S5_RXN | | <b>A</b> 5 | S4_RXN | | A6 | S3_RXN | | A7 | S2_RXN | | A8 | S1_RXN | | A9 | S0_RXN | | A10 | P1_D0N | | A11 | P1_D1N | | A12 | P1_D2N | | A13 | P1_D3N | | A14 | PO_DON | | A15 | PO_D1N | | A16 | PO_D2N | | A17 | PO_D3N | | A18 | VSS_66 | | В1 | CLKOUTPLL_N | | | | | B2 | CLKOUTPLL_P | | B2<br>B3 | CLKOUTPLL_P<br>S6_TXN | | | | | В3 | S6_TXN | | B3<br>B4 | S6_TXN<br>S5_RXP | | B3<br>B4<br>B5 | S6_TXN S5_RXP S4_RXP | | B3<br>B4<br>B5<br>B6 | S6_TXN S5_RXP S4_RXP S3_RXP | | B3<br>B4<br>B5<br>B6<br>B7 | S6_TXN S5_RXP S4_RXP S3_RXP S2_RXP | | B3<br>B4<br>B5<br>B6<br>B7<br>B8 | S6_TXN S5_RXP S4_RXP S3_RXP S2_RXP S1_RXP | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9 | S6_TXN S5_RXP S4_RXP S3_RXP S2_RXP S1_RXP S0_RXP | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP | | B3 B4 B5 B6 B7 B8 B9 B10 B11 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P | | B3 B4 B5 B6 B7 B8 B9 B10 B11 B12 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9<br>B10<br>B11<br>B12 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P P1_D3P | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9<br>B10<br>B11<br>B12<br>B13 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P P1_D3P P0_D0P | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9<br>B10<br>B11<br>B12<br>B13<br>B14 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P P1_D3P P0_D0P P0_D1P | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9<br>B10<br>B11<br>B12<br>B13<br>B14<br>B15 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P P1_D3P P0_D0P P0_D1P P0_D2P | | B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9<br>B10<br>B11<br>B12<br>B13<br>B14<br>B15<br>B16<br>B17 | \$6_TXN \$5_RXP \$4_RXP \$3_RXP \$2_RXP \$1_RXP \$0_RXP P1_D0P P1_D1P P1_D2P P1_D3P P0_D0P P0_D1P P0_D2P P0_D3P | | С3 | S6_TXP | |-----|---------------| | C4 | S5_TXN | | C5 | S4_TXN | | C6 | S3_TXN | | C7 | S2_TXN | | C8 | S1_TXN | | C9 | S0_TXN | | C10 | VDD_AL_1 | | C11 | VDD_AL_2 | | C12 | VDD_AL_3 | | C13 | VDD_AL_4 | | C14 | VDD_AH_1 | | C15 | VDD_AH_2 | | C16 | VDD_AH_3 | | C17 | VDD_AH_4 | | C18 | RESERVED_1 | | D1 | PCIE_TXN | | D2 | PCIE_TXP | | D3 | VDD_VS_1 | | D4 | S5_TXP | | D5 | S4_TXP | | D6 | S3_TXP | | D7 | S2_TXP | | D8 | S1_TXP | | D9 | S0_TXP | | D10 | SERDES_Rext_1 | | D11 | SERDES_Rext_0 | | D12 | REF_Rext | | D13 | REF_FILT | | D14 | THERMDC | | D15 | THERMDA | | D16 | DDR_DQ13 | | D17 | DDR_DQ10 | | D18 | DDR_DQ8 | | E1 | PCIE_RXN | | E2 | PCIE_RXP | | E3 | VDD_VS_2 | | E4 | VDD_VS_3 | | E5 | VDD_VS_4 | |-----|-----------| | E6 | VDD_VS_5 | | E7 | VDD_VS_6 | | E8 | VDD_1 | | E9 | VDD_2 | | E10 | VDD_3 | | E11 | VDD_4 | | E12 | VDD_5 | | E13 | VDD_6 | | E14 | VDD_7 | | E15 | DDR_DQ15 | | E16 | DDR_UDM | | E17 | DDR_UDQSn | | E18 | DDR_UDQS | | F1 | CLKINO_N | | F2 | CLKINO_P | | F3 | CLKOUTO_N | | F4 | CLKOUTO_P | | F5 | VDD_A_1 | | F6 | VDD_A_2 | | F7 | VSS_1 | | F8 | VSS_2 | | F9 | VSS_3 | | F10 | VSS_4 | | F11 | VSS_5 | | F12 | VSS_6 | | F13 | VDD_8 | | F14 | VDD_9 | | F15 | DDR_DQ14 | | F16 | DDR_DQ9 | | F17 | DDR_DQ11 | | F18 | DDR_DQ12 | | G1 | CLKIN1_N | | G2 | CLKIN1_P | | G3 | CLKOUT1_N | | G4 | CLKOUT1_P | | G5 | VDD_A_3 | | G6 | VSS_7 | ### Pins by number (continued) | G7 VSS_8 G8 VSS_9 G8 VSS_9 G8 VSS_9 G9 VSS_10 G10 VSS_11 J15 DDR_A1 M1 VSS_48 G10 VSS_11 J15 DDR_A1 M2 VSS_49 G11 VSS_12 J16 DDR_A3 M3 VDD_HS_3 G12 VSS_13 J17 DDR_A5 M4 VDD_A_8 G13 VDD_10 J18 DDR_A7 M5 VDD_19 G14 VDD_10DDR_1 K1 VSS_31 M6 VSS_50 G15 DDR_nCS1 K2 VSS_32 M7 VSS_51 G16 RESERVED_2 K3 VDD_HS_2 G17 DDR_NWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_A_1 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_CCO H7 VSS_17 K12 VSS_39 M17 DDR_CCO H8 VSS_16 K13 VDD_16 M8 VSS_17 K12 VSS_39 M16 DDR_CO H17 VSS_17 K12 VSS_39 M17 DDR_CO H3 VDD_A0 H9 VSS_15 K10 VSS_16 K11 VSS_38 M16 DDR_CO H17 VSS_17 K12 VSS_39 M17 DDR_CO H18 DDR_A0 H9 VSS_19 K14 VDD_10DDR_4 H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_P H11 VSS_21 K16 DDR_A12 N3 VSS_57 H15 DDR_BA0 H16 DDR_BA0 H17 DDR_CA H18 DDR_A2 H19 DDR_BA1 H19 DDR_BA1 H19 DDR_BA1 H19 DDR_BA1 H19 DDR_BA2 H10 DDR_BA2 H10 DDR_BA2 H10 DDR_BA2 H11 VSS_21 H10 DDR_BA2 H11 VSS_21 H10 DDR_BA2 H11 VSS_21 H11 VSS_22 K17 DDR_CK H13 DDR_BA2 H14 VDD_12 H15 DDR_BA2 H15 DDR_BA2 H16 DDR_BA2 H17 DDR_A13 H19 DDR_BA3 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 VSS_21 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 H19 VSS_21 H19 VSS_21 H19 VSS_21 H19 VSS_21 H19 VSS_21 H19 DDR_BA3 H19 VSS_21 VSS_22 H19 VSS_22 H19 VSS_23 H19 DDR_HA3 H19 VSS_25 H | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------|-----------|-------------|--------------|-----------| | G9 VSS_10 J14 VDD_IODDR_3 M1 VSS_48 G10 VSS_11 J15 DDR_A1 M2 VSS_49 G11 VSS_12 J16 DDR_A3 M3 VDD_LA_B G12 VSS_13 J17 DDR_A5 M4 VDD_A_B G13 VDD_10 J18 DDR_A7 M5 VDD_19 G14 VDD_10DDR_1 K1 VSS_31 M6 VSS_55 G15 DDR_nCS1 K2 VSS_32 M7 VSS_55 G16 RESERVED_2 K3 VDD_HS_2 M8 VSS_52 G17 DDR_nWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H3 VDD_HS_1 K8 VSS_33 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 | G7 | VSS_8 | J12 | VSS_30 | _ <u>L17</u> | DDR_A6 | | G10 VSS_11 | G8 | VSS_9 | J13 | VDD_14 | L18 | DDR_A8 | | G11 VSS_12 | G9 | VSS_10 | J14 | VDD_IODDR_3 | <u>M1</u> | VSS_48 | | G12 VSS_13 | G10 | VSS_11 | J15 | DDR_A1 | <u>M2</u> | VSS_49 | | G13 VDD_10 | G11 | VSS_12 | J16 | DDR_A3 | M3 | VDD_HS_3 | | G14 VDD_IODDR_1 K1 VSS_31 M6 VSS_50 G15 DDR_nCS1 K2 VSS_32 M7 VSS_51 G16 RESERVED_2 K3 VDD_HS_2 M8 VSS_52 G17 DDR_nWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_nCSO H7 VSS_17 K12 VSS_39 M17 DDR_nCAS H8 VSS_18 K13 VDD_16 M18 DDR_AO H9 VSS_19 K14 VDD_IODDR_4 N1 CLKOUT3_N H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_P H11 VSS_21 K16 DDR_A12 N3 VSS_57 H11 VSS_21 K16 DDR_A12 N3 VSS_57 H14 VDD_IODDR_2 K18 DDR_CKn N4 VDD_A9 H11 VSS_21 K18 DDR_CKn N5 VDD_22 H14 VDD_IODDR_2 L1 CLKIN2_N | G12 | VSS_13 | J17 | DDR_A5 | M4 | VDD_A_8 | | G15 DDR_nCS1 K2 VSS_32 M7 VSS_51 G16 RESERVED_2 K3 VDD_HS_2 M8 VSS_52 G17 DDR_nWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_nCSO H7 VSS_17 K12 VSS_39 M17 DDR_nCAS H8 VSS_18 K13 VDD_16 M18 DDR_AO H9 VSS_19 K14 VDD_IODDR_4 N1 CLKOUT3_N H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_P H11 VSS_21 K16 DDR_A12 N3 VSS_57 H12 VSS_22 K17 DDR_CK N4 VDD_A9 H11 VSS_21 K16 DDR_A12 N3 VSS_67 H12 VSS_22 K17 DDR_CK N4 VDD_A9 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H15 DDR_BA2 L2 CLKIN2_P N | G13 | VDD_10 | J18 | DDR_A7 | <u>M5</u> | VDD_19 | | G16 RESERVED_2 K3 VDD_HS_2 M8 VSS_52 G17 DDR_NWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_38 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_A13 H6 VSS_16 K11 VSS_38 M17 DDR_ACSO H7 VSS_17 K12 VSS_38 M17 DDR_ACSO H8 VSS_18 K13 VDD_16 M18 DDR_ACSO H9 VSS_19 K14 VDD_10DR_4 N1 CLKOUT3_N H10 | G14 | VDD_IODDR_1 | <u>K1</u> | VSS_31 | <u>M6</u> | VSS_50 | | G17 DDR_nWE K4 VDD_A_6 M9 VSS_53 G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_nCSO H7 VSS_17 K12 VSS_39 M17 DDR_nCSO H8 VSS_18 K13 VDD_16 M18 DDR_A0 H9 VSS_19 K14 VDD_IODDR_4 N1 CLKOUT3_N H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_P H11 VSS_21 K16 DDR_A12 N3 VSS_57 H12 VSS_22 K17 DDR_CK N4 VDD_A_9 H13 VDD_12 K18 DDR_CK N4 VDD_A_9 H14 VDD_IODDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N | G15 | DDR_nCS1 | K2 | VSS_32 | M7 | VSS_51 | | G18 DDR_CKE K5 VDD_15 M10 VSS_54 H1 VSS_14 K6 VSS_33 M11 VSS_55 H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_A13 H8 VSS_17 K12 VSS_39 M17 DDR_A0 H9 VSS_17 K12 VSS_39 M17 DDR_A0 H9 VSS_19 K14 VDD_16 M18 DDR_A0 H9 VSS_19 K14 VDD_16DDR_4 N1 CLKOUT3_N H10 VSS_221 K15 DDR_A9 N2 CLKOUT3_N H11 <td< td=""><td>G16</td><td>RESERVED_2</td><td>K3</td><td>VDD_HS_2</td><td><u>M8</u></td><td>VSS_52</td></td<> | G16 | RESERVED_2 | K3 | VDD_HS_2 | <u>M8</u> | VSS_52 | | H1 | G17 | DDR_nWE | K4 | VDD_A_6 | M9 | VSS_53 | | H2 VSS_15 K7 VSS_34 M12 VSS_56 H3 VDD_HS_1 K8 VSS_35 M13 VDD_20 H4 VDD_A_4 K9 VSS_36 M14 VDD_21 H5 VDD_11 K10 VSS_37 M15 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_A13 H6 VSS_16 K11 VSS_38 M16 DDR_A13 H6 VSS_16 K12 VSS_39 M17 DDR_ACS H8 VSS_18 K13 VDD_16 M18 DDR_AO H9 VSS_19 K14 VDD_10DDR_4 N1 CLKOUT3_N H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_N H11 VSS_21 K16 DDR_A12 N3 VSS_57 H11 VSS_22 K17 DDR_CK N4 VDD_A_9 H13 VDD_12 K18 DDR_CKn N5 VDD_22 H14 | G18 | DDR_CKE | K5 | VDD_15 | M10 | VSS_54 | | H3 | H1 | VSS_14 | K6 | VSS_33 | M11 | VSS_55 | | H4 | H2 | VSS_15 | K7 | VSS_34 | M12 | VSS_56 | | H5 | НЗ | VDD_HS_1 | K8 | VSS_35 | M13 | VDD_20 | | H6 | H4 | VDD_A_4 | K9 | VSS_36 | M14 | VDD_21 | | H7 | H5 | VDD_11 | K10 | VSS_37 | M15 | DDR_A13 | | H8 | Н6 | VSS_16 | K11 | VSS_38 | M16 | DDR_nCS0 | | H9 VSS_19 K14 VDD_IODDR_4 N1 CLKOUT3_N H10 VSS_20 K15 DDR_A9 N2 CLKOUT3_P H11 VSS_21 K16 DDR_A12 N3 VSS_57 H12 VSS_22 K17 DDR_CK N4 VDD_A_9 H13 VDD_12 K18 DDR_CKN N5 VDD_22 H14 VDD_10DDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 | H7 | VSS_17 | K12 | VSS_39 | M17 | DDR_nCAS | | H10 | Н8 | VSS_18 | K13 | VDD_16 | M18 | DDR_A0 | | H11 VSS_21 K16 DDR_A12 N3 VSS_57 H12 VSS_22 K17 DDR_CK N4 VDD_A_9 H13 VDD_12 K18 DDR_CKn N5 VDD_22 H14 VDD_IODDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | Н9 | VSS_19 | K14 | VDD_IODDR_4 | N1 | CLKOUT3_N | | H12 VSS_22 K17 DDR_CK N4 VDD_A_9 H13 VDD_12 K18 DDR_CKn N5 VDD_22 H14 VDD_IODDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_28 L15 DDR_A11 P2 VSS_59 | H10 | VSS_20 | K15 | DDR_A9 | N2 | CLKOUT3_P | | H13 VDD_12 K18 DDR_CKn N5 VDD_22 H14 VDD_IODDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_28 L15 DDR_A11 P2 VSS_59 | H11 | VSS_21 | K16 | DDR_A12 | N3 | VSS_57 | | H14 VDD_IODDR_2 L1 CLKIN2_N N6 VDD_23 H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H12 | VSS_22 | K17 | DDR_CK | N4 | VDD_A_9 | | H15 DDR_BA2 L2 CLKIN2_P N7 VDD_24 H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H13 | VDD_12 | K18 | DDR_CKn | N5 | VDD_22 | | H16 DDR_BA0 L3 VSS_40 N8 VDD_25 H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H14 | VDD_IODDR_2 | L1 | CLKIN2_N | N6 | VDD_23 | | H17 DDR_BA1 L4 VDD_A_7 N9 VDD_26 H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H15 | DDR_BA2 | L2 | CLKIN2_P | N7 | VDD_24 | | H18 DDR_A10 L5 VDD_17 N10 VDD_27 J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H16 | DDR_BA0 | L3 | VSS_40 | N8 | VDD_25 | | J1 CLKOUT2_N L6 VSS_41 N11 VDD_28 J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_10DDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H17 | DDR_BA1 | L4 | VDD_A_7 | N9 | VDD_26 | | J2 CLKOUT2_P L7 VSS_42 N12 VDD_29 J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | H18 | DDR_A10 | <u>L5</u> | VDD_17 | N10 | VDD_27 | | J3 VSS_23 L8 VSS_43 N13 VDD_30 J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J1 | CLKOUT2_N | L6 | VSS_41 | N11 | VDD_28 | | J4 VDD_A_5 L9 VSS_44 N14 VDD_31 J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J2 | CLKOUT2_P | L7 | VSS_42 | N12 | VDD_29 | | J5 VDD_13 L10 VSS_45 N15 DDR_A2 J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J3 | VSS_23 | L8 | VSS_43 | <u>N</u> 13 | VDD_30 | | J6 VSS_24 L11 VSS_46 N16 DDR_A15 J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J4 | VDD_A_5 | L9 | VSS_44 | <u>N</u> 14 | VDD_31 | | J7 VSS_25 L12 VSS_47 N17 DDR_A14 J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J5 | VDD_13 | L10 | VSS_45 | N15 | DDR_A2 | | J8 VSS_26 L13 VDD_18 N18 DDR_nRAS J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J6 | VSS_24 | L11 | VSS_46 | <u>N</u> 16 | DDR_A15 | | J9 VSS_27 L14 VDD_IODDR_5 P1 VSS_58 J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J7 | VSS_25 | L12 | VSS_47 | N17 | DDR_A14 | | J10 VSS_28 L15 DDR_A11 P2 VSS_59 | J8 | VSS_26 | L13 | VDD_18 | N18 | DDR_nRAS | | <del></del> | J9 | VSS_27 | L14 | VDD_IODDR_5 | P1 | VSS_58 | | J11 VSS_29 L16 DDR_A4 P3 VDD_HS_4 | J10 | VSS_28 | L15 | DDR_A11 | P2 | VSS_59 | | | J11 | VSS_29 | L16 | DDR_A4 | P3 | VDD_HS_4 | ### Pins by number (continued) | <br>P4 | RESERVED_4 | |--------|--------------| | P5 | | | | | | P6 | VDD_IO_1 | | P7 | VDD_IO_2 | | P8 | VDD_IO_3 | | P9 | VDD_IO_4 | | P10 | VDD_IO_5 | | P11 | VDD_IO_6 | | P12 | VDD_IO_7 | | P13 | VDD_IO_8 | | P14 | VDD_32 | | P15 | DDR_ODT | | P16 | DDR_DQ7 | | P17 | DDR_DQ0 | | P18 | DDR_DQ2 | | R1 | CLKIN3_N | | R2 | CLKIN3_P | | R3 | VSS_60 | | R4 | JTAG_nTRST | | R5 | VSS_64 | | R6 | SI_DI | | R7 | GPIO_0 | | R8 | GPIO_4 | | R9 | GPIO_8 | | R10 | GPIO_12 | | R11 | GPIO_16 | | R12 | GPIO_20 | | R13 | GPIO_24 | | R14 | GPIO_28 | | R15 | DDR_DQ5 | | R16 | DDR_DQ6 | | R17 | DDR_LDQS | | R18 | DDR_LDQSn | | T1 | VSS_61 | | T2 | VSS_62 | | T3 | VDD_HS_5 | | T4 | JTAG_TMS | | T5 | JTAG_ICE_nEN | | T6 | SI_DO | | T7 | GPIO_1 | | T8 | GPIO_5 | | T9 | GPIO_9 | |------------|--------------| | T10 | GPIO_13 | | T11 | GPIO_17 | | T12 | GPIO_21 | | T13 | GPIO_25 | | T14 | GPIO_29 | | T15 | GPIO_32 | | T16 | DDR_LDM | | T17 | DDR_DQ4 | | T18 | DDR_DQ1 | | U1 | REFCLK2_N | | U2 | REFCLK2_P | | U3 | VSS_63 | | U4 | JTAG_TDI | | U5 | JTAG_TDO | | U6 | SI_nCS0 | | U7 | GPIO_2 | | U8 | GPIO_6 | | U9 | GPIO_10 | | U10 | GPIO_14 | | U11 | GPIO_18 | | <u>U12</u> | GPIO_22 | | U13 | GPIO_26 | | <u>U14</u> | GPIO_30 | | U15 | GPIO_33 | | U16 | GPIO_35 | | U17 | DDR_Rext | | U18 | DDR_DQ3 | | V1 | VSS_67 | | V2 | CLKOUTPLL2_N | | V3 | CLKOUTPLL2_P | | V4 | JTAG_TCK | | V5 | nRESET | | V6 | SI_CLK | | V7 | GPIO_3 | | V8 | GPIO_7 | | V9 | GPIO_11 | | V10 | GPIO_15 | | V11 | GPIO_19 | | V12 | GPIO_23 | | V13 | GPIO_27 | | V14 | GPIO_31 | |-----|----------| | V15 | GPIO_34 | | V16 | GPIO_36 | | V17 | DDR_Vref | | V18 | VSS_68 | | | | ## 7.4 Pins by Name This section provides an alphabetic list of the pins. | CLKINO_N | F1 | |--------------|-----| | CLKINO_P | F2 | | CLKIN1_N | G1 | | CLKIN1_P | G2 | | CLKIN2_N | L1 | | CLKIN2_P | L2 | | CLKIN3_N | R1 | | CLKIN3_P | R2 | | CLKOUTO_N | F3 | | CLKOUTO_P | F4 | | CLKOUT1_N | G3 | | CLKOUT1_P | G4 | | CLKOUT2_N | J1 | | CLKOUT2_P | J2 | | CLKOUT3_N | N1 | | CLKOUT3_P | N2 | | CLKOUTPLL_N | B1 | | CLKOUTPLL_P | B2 | | CLKOUTPLL2_N | V2 | | CLKOUTPLL2_P | V3 | | DDR_A0 | M18 | | DDR_A1 | J15 | | DDR_A2 | N15 | | DDR_A3 | J16 | | DDR_A4 | L16 | | DDR_A5 | J17 | | DDR_A6 | L17 | | DDR_A7 | J18 | | DDR_A8 | L18 | | DDR_A9 | K15 | | DDR_A10 | H18 | | DDR_A11 | L15 | | DDR_A12 | K16 | | DDR_A13 | M15 | | DDR_A14 | N17 | | DDR_A15 | N16 | | DDR_BA0 | H16 | | DDR_BA1 | H17 | | | | | H15 | |-----| | K17 | | G18 | | K18 | | P17 | | T18 | | P18 | | U18 | | T17 | | R15 | | R16 | | P16 | | D18 | | F16 | | D17 | | F17 | | F18 | | D16 | | F15 | | E15 | | T16 | | R17 | | R18 | | M17 | | M16 | | G15 | | N18 | | G17 | | P15 | | U17 | | E16 | | E18 | | E17 | | V17 | | R7 | | T7 | | U7 | | V7 | | | | GPIO_4 | R8 | |--------------|-----| | GPIO_5 | T8 | | GPIO_6 | U8 | | GPIO_7 | V8 | | GPIO_8 | R9 | | GPIO_9 | T9 | | GPIO_10 | U9 | | GPIO_11 | V9 | | GPIO_12 | R10 | | GPIO_13 | T10 | | GPIO_14 | U10 | | GPIO_15 | V10 | | GPIO_16 | R11 | | GPIO_17 | T11 | | GPIO_18 | U11 | | GPIO_19 | V11 | | GPIO_20 | R12 | | GPIO_21 | T12 | | GPIO_22 | U12 | | GPIO_23 | V12 | | GPIO_24 | R13 | | GPIO_25 | T13 | | GPIO_26 | U13 | | GPIO_27 | V13 | | GPIO_28 | R14 | | GPIO_29 | T14 | | GPIO_30 | U14 | | GPIO_31 | V14 | | GPIO_32 | T15 | | GPIO_33 | U15 | | GPIO_34 | V15 | | GPIO_35 | U16 | | GPIO_36 | V16 | | JTAG_ICE_nEN | T5 | | JTAG_nTRST | R4 | | JTAG_TCK | V4 | | JTAG_TDI | U4 | | JTAG_TDO | U5 | #### Pins by name (continued) | JTAG_TMS | T4 | |------------|-----| | nRESET | V5 | | PO_DON | A14 | | P0_D0P | B14 | | P0_D1N | A15 | | P0_D1P | B15 | | PO_D2N | A16 | | P0_D2P | B16 | | PO_D3N | A17 | | P0_D3P | B17 | | P1_D0N | A10 | | P1_D0P | B10 | | P1_D1N | A11 | | P1_D1P | B11 | | P1_D2N | A12 | | P1_D2P | B12 | | P1_D3N | A13 | | P1_D3P | B13 | | PCIE_RXN | E1 | | PCIE_RXP | E2 | | PCIE_TXN | D1 | | PCIE_TXP | D2 | | REF_FILT | D13 | | REF_Rext | D12 | | REFCLK_N | A2 | | REFCLK_P | А3 | | REFCLK2_N | U1 | | REFCLK2_P | U2 | | RESERVED_0 | B18 | | RESERVED_1 | C18 | | RESERVED_2 | G16 | | RESERVED_3 | P5 | | RESERVED_4 | P4 | | S0_RXN | Α9 | | S0_RXP | В9 | | S0_TXN | С9 | | S0_TXP | D9 | | S1_RXN | A8 | | S1_RXP | B8 | | S1_TXN | C8 | | S1_TXP | D8 | | S2_RXN | A7 | |-------------------------------------------------------------------------------------|-----------------------------------------------------| | S2_RXP | В7 | | S2_TXN | C7 | | S2_TXP | D7 | | S3_RXN | A6 | | S3_RXP | B6 | | S3_TXN | C6 | | S3_TXP | D6 | | S4_RXN | <b>A</b> 5 | | S4_RXP | B5 | | S4_TXN | C5 | | S4_TXP | D5 | | S5_RXN | A4 | | S5_RXP | B4 | | S5_TXN | C4 | | S5_TXP | D4 | | S6_RXN | C1 | | S6_RXP | C2 | | S6_TXN | В3 | | S6_TXP | С3 | | SERDES_Rext_0 | D11 | | SERDES_Rext_1 | D10 | | SI_CLK | V6 | | SI_DI | R6 | | SI_DO | T4 | | | T6 | | SI_nCS0 | U6 | | SI_nCS0<br>THERMDA | | | - | U6 | | THERMDA THERMDC VDD_1 | U6<br>D15 | | THERMDA THERMDC VDD_1 | U6<br>D15<br>D14 | | THERMDA<br>THERMDC | U6<br>D15<br>D14<br>E8 | | THERMDA THERMDC VDD_1 VDD_2 | U6 D15 D14 E8 E9 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 | U6 D15 D14 E8 E9 E10 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 | U6 D15 D14 E8 E9 E10 E11 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 | U6 D15 D14 E8 E9 E10 E11 E12 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 | U6 D15 D14 E8 E9 E10 E11 E12 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 VDD_7 | U6 D15 D14 E8 E9 E10 E11 E12 E13 E14 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 VDD_7 VDD_8 | U6 D15 D14 E8 E9 E10 E11 E12 E13 E14 F13 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 VDD_7 VDD_8 VDD_9 | U6 D15 D14 E8 E9 E10 E11 E12 E13 E14 F13 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 VDD_7 VDD_8 VDD_9 VDD_10 | U6 D15 D14 E8 E9 E10 E11 E12 E13 E14 F13 F14 G13 | | THERMDA THERMDC VDD_1 VDD_2 VDD_3 VDD_4 VDD_5 VDD_6 VDD_7 VDD_8 VDD_9 VDD_10 VDD_11 | U6 D15 D14 E8 E9 E10 E11 E12 E13 E14 F13 F14 G13 H5 | | VDD_14 | J13 | |----------|-----| | VDD_15 | K5 | | VDD_16 | K13 | | VDD_17 | L5 | | VDD_18 | L13 | | VDD_19 | M5 | | VDD_20 | M13 | | VDD_21 | M14 | | VDD_22 | N5 | | VDD_23 | N6 | | VDD_24 | N7 | | VDD_25 | N8 | | VDD_26 | N9 | | VDD_27 | N10 | | VDD_28 | N11 | | VDD_29 | N12 | | VDD_30 | N13 | | VDD_31 | N14 | | VDD_32 | P14 | | VDD_A_1 | F5 | | VDD_A_2 | F6 | | VDD_A_3 | G5 | | VDD_A_4 | H4 | | VDD_A_5 | J4 | | VDD_A_6 | K4 | | VDD_A_7 | L4 | | VDD_A_8 | M4 | | VDD_A_9 | N4 | | VDD_AH_1 | C14 | | VDD_AH_2 | C15 | | VDD_AH_3 | C16 | | VDD_AH_4 | C17 | | VDD_AL_1 | C10 | | VDD_AL_2 | C11 | | VDD_AL_3 | C12 | | VDD_AL_4 | C13 | | VDD_HS_1 | Н3 | | VDD_HS_2 | К3 | | VDD_HS_3 | М3 | | VDD_HS_4 | P3 | | VDD_HS_5 | Т3 | | | | ## Pins by name (continued) | VDD_IO_1 | P6 | |-------------|-----| | VDD_IO_2 | P7 | | VDD_IO_3 | P8 | | VDD_IO_4 | P9 | | VDD_IO_5 | P10 | | VDD_IO_6 | P11 | | VDD_IO_7 | P12 | | VDD_IO_8 | P13 | | VDD_IODDR_1 | G14 | | VDD_IODDR_2 | H14 | | VDD_IODDR_3 | J14 | | VDD_IODDR_4 | K14 | | VDD_IODDR_5 | L14 | | VDD_VS_1 | D3 | | VDD_VS_2 | E3 | | VDD_VS_3 | E4 | | VDD_VS_4 | E5 | | VDD_VS_5 | E6 | | VDD_VS_6 | E7 | | VSS_1 | F7 | | VSS_2 | F8 | | VSS_3 | F9 | | VSS_4 | F10 | | VSS_5 | F11 | | VSS_6 | F12 | | VSS_7 | G6 | | VSS_8 | G7 | | VSS_9 | G8 | | VSS_10 | G9 | | VSS_11 | G10 | | VSS_12 | G11 | | VSS_13 | G12 | | VSS_14 | H1 | | VSS_15 | H2 | | VSS_16 | H6 | | VSS_17 | H7 | | VSS_18 | Н8 | | VSS_19 | Н9 | | VSS_20 | H10 | | VSS_21 | H11 | | VSS_22 | H12 | | | | | VSS_ | _23 | J3 | |------|-----|-----| | VSS_ | _24 | J6 | | VSS_ | _25 | J7 | | VSS_ | _26 | J8 | | VSS_ | _27 | J9 | | VSS_ | _28 | J10 | | VSS_ | _29 | J11 | | VSS_ | _30 | J12 | | VSS_ | _31 | K1 | | VSS_ | _32 | K2 | | VSS_ | _33 | K6 | | VSS_ | _34 | K7 | | VSS_ | _35 | K8 | | VSS_ | _36 | K9 | | VSS_ | _37 | K10 | | VSS_ | _38 | K11 | | VSS_ | _39 | K12 | | VSS_ | _40 | L3 | | VSS_ | _41 | L6 | | VSS_ | _42 | L7 | | VSS_ | _43 | L8 | | VSS_ | _44 | L9 | | VSS_ | _45 | L10 | | VSS_ | _46 | L11 | | VSS_ | _47 | L12 | | VSS_ | _48 | M1 | | VSS_ | _49 | M2 | | VSS_ | _50 | M6 | | VSS_ | _51 | M7 | | VSS_ | _52 | M8 | | VSS_ | _53 | M9 | | VSS_ | _54 | M10 | | VSS_ | _55 | M11 | | VSS_ | _56 | M12 | | VSS_ | _57 | N3 | | VSS_ | _58 | P1 | | VSS_ | _59 | P2 | | VSS_ | _60 | R3 | | VSS_ | _61 | T1 | | VSS_ | _62 | T2 | | VSS_ | _63 | U3 | | VSS_64 | R5 | |--------|-----| | VSS_65 | A1 | | VSS_66 | A18 | | VSS_67 | V1 | | VSS_68 | V18 | # 8 Package Information The VSC7415XMT package is a lead-free (Pb-free), 324-pin, plastic ball grid array (BGA) with a 19 mm × 19 mm body size, 1 mm pin pitch, and 1.8 mm maximum height. Lead-free products from Microsemi comply with the temperatures and profiles defined in the joint IPC and JEDEC standard IPC/JEDEC J-STD-020. For more information, see the IPC and JEDEC standard. This section provides the package drawing, thermal specifications, and moisture sensitivity rating for the VSC7415 device. ## 8.1 Package Drawing The following illustration shows the package drawing for the VSC7415 device. The drawing contains the top view, bottom view, side view, detail views, dimensions, tolerances, and notes. Figure 155 • Package Drawing Top View #### **Bottom View** ## Notes - 1. All dimensions and tolerances are in millimeters (mm). Primary datum Z and seating plane are defined by the spherical crowns of the solder balls. - Dimension is measured at the maximum solder ball diameter, parallel to primary datum Z. - 4. Radial true position is represented by typical values. #### Dimensions | Reference | Minimum | Nominal | Maximum | |-----------|---------|-----------|---------| | Α | 1.54 | 1.67 | 1.80 | | A1 | 0.31 | | 0.43 | | D | | 19.00 BSC | | | E | | 19.00 BSC | | | D1 | | 17.00 BSC | | | E1 | | 17.00 BSC | | | е | | 1.00 BSC | | | b | 0.44 | | 0.64 | # 8.2 Thermal Specifications Thermal specifications for this device are based on the JEDEC JESD51 family of documents. These documents are available on the JEDEC Web site at www.jedec.org. The thermal specifications are modeled using a four-layer test board with two signal layers, a power plane, and a ground plane (2s2p PCB). For more information about the thermal measurement method used for this device, see the JESD51-1 standard. Table 320 . Thermal Resistances | Symbol | °C/W | Parameter | |---------------------------|-------|--------------------------------------------------------------| | $\theta_{JCtop}$ | 2.89 | Die junction to package case top | | $\theta_{JB}$ | 8.65 | Die junction to printed circuit board | | $\theta_{JA}$ | 15.94 | Die junction to ambient | | θ <sub>JMA</sub> at 1 m/s | 13.3 | Die junction to moving air measured at an air speed of 1 m/s | | θ <sub>JMA</sub> at 2 m/s | 12.36 | Die junction to moving air measured at an air speed of 2 m/s | To achieve results similar to the modeled thermal measurements, the guidelines for board design described in the JESD51 family of publications must be applied. For information about applications using BGA packages, see the following: - JESD51-2A, Integrated Circuits Thermal Test Method Environmental Conditions, Natural Convection (Still Air) - JESD51-6, Integrated Circuit Thermal Test Method Environmental Conditions, Forced Convection (Moving Air) - JESD51-8, Integrated Circuit Thermal Test Method Environmental Conditions, Junction-to-Board - JESD51-9, Test Boards for Area Array Surface Mount Package Thermal Measurements ## 8.3 Moisture Sensitivity This device is rated moisture sensitivity level 4 as specified in the joint IPC and JEDEC standard IPC/JEDEC J-STD-020. For more information, see the IPC and JEDEC standard. # 9 Design Guidelines This section provides information about design guidelines for the VSC7415 device. # 9.1 Power Supplies The following guidelines apply to designing power supplies for use with the VSC7415 device. - Make at least one unbroken ground plane (GND). - Use the power and ground plane combination as an effective power supply bypass capacitor. The capacitance is proportional to the area of the two planes and inversely proportional to the separation between the planes. Typical values with a 0.25 mm (0.01 inch) separation are 100 pF/in2. This capacitance is more effective than a capacitor of equivalent value, because the planes have no inductance or Equivalent Series Resistance (ESR). - Do not cut up the power or ground planes in an effort to steer current paths. This usually produces more noise, not less. Furthermore, place vias and clearances in a configuration that maintains the integrity of the plane. Groups of vias spaced close together often overlap clearances. This can form a large slot in the plane. As a result, return currents are forced around the slot, which increases the loop area and EMI emissions. Signals should never be placed on a ground plane, because the resulting slot forces return currents around the slot. - Vias connecting power planes to the supply and ground balls must be at least 0.25 mm (0.010 inch) in diameter, preferably with no thermal relief and plated closed with copper or solder. Use separate (or even multiple) vias for each supply and ground ball. # 9.2 Power Supply Decoupling Each power supply voltage should have both bulk and high-frequency decoupling capacitors. Recommended capacitors are as follows: - For bulk decoupling, use 10 μF high capacity and low ESR capacitors or equivalent, distributed across the board. - For high-frequency decoupling, use 0.1 μF high frequency (for example, X7R) ceramic capacitors placed on the side of the PCB closest to the plane being decoupled, and as close as possible to the power ball. A larger value in the same housing unit produces even better results. - Use surface-mounted components for lower lead inductance and pad capacitance. Smaller form factor components are best (that is, 0402 is better than 0603). ## 9.2.1 Reference Clock The device reference clock can be a 25 MHz, 125 MHz, 156.25 MHz, or 250 MHz clock signal. It can be either a differential reference clock or a single-ended clock. However, 25 MHz single-ended operation is not recommended to achieve 10G SFP+ jitter specification requirements. For more information, see Reference Clock, page 374. ## 9.2.2 Single-Ended REFCLK Input An external resistor network is required to use a single-ended reference clock. The network limits the amplitude and adjusts the center of the swing. Depending on the clock driver output impedance, the resistor values may need to be adjusted so that the REFCLK\_P signal meets requirements. For information about these requirements, see Table 264, page 374. The following illustrations show configurations for a single-ended reference clock. Figure 156 • 2.5 V CMOS Single-Ended REFCLK Input Resistor Network Figure 157 • 3.3 V CMOS Single-Ended REFCLK Input Resistor Network ## 9.3 Interfaces This section provides general recommendations for all interfaces and information related to the specific interfaces on the device. ## 9.3.1 General Recommendations High-speed signals require excellent frequency and phase response up to the third harmonic. The best designs provide excellent frequency and phase response up to the seventh harmonic. The following recommendations can improve signal quality and minimize transmission distances: - · Keep traces as short as possible. Initial component placement should be considered very carefully. - The impedance of the traces must match the impedance of the termination resistors, connectors, and cable. This reduces reflections due to impedance mismatches. - Differential impedance must be maintained in a 100 $\Omega$ differential application. Routing two 50 $\Omega$ traces is not adequate. The two traces must be separated by enough distance to maintain differential impedance. When routing differential pairs, keep the two trace lengths identical. Differences in trace lengths translate directly into signal skew. Note that the differential impedance may be affected when separations occur. - Keep differential pair traces on the same layer of the PCB to minimize impedance discontinuities. In other words, avoid using vias. - Do not group all the passive components together. The pads of the components add capacitance to the traces. At the frequencies encountered, this can result in unwanted reductions in impedance. Use surface-mounted 0603 (or smaller) components to reduce this effect. - · Eliminate or reduce stub lengths. - Reduce, if not eliminate, vias to minimize impedance discontinuities. Remember that vias and their clearance holes in the power/ground planes can cause impedance discontinuities in nearby signals. Keep vias away from other traces. - Keep signal traces away from other signals that might capacitively couple noise into the signals. A good rule of thumb is to keep the traces apart by ten times the width of the trace. - Do not route digital signals from other circuits across the area of the high-speed transmitter and receiver signals. - Using grounded guard traces is typically not effective for improving signal quality. A ground plane is more effective. However, a common use of guard traces is to route them during the layout, but remove them prior to design completion. This has the benefit of enforcing keep-out areas around sensitive high-speed signals so that vias and other traces are not accidentally placed incorrectly. When signals in a differential pair are mismatched, the result is a common-mode current. In a well-designed system, common-mode currents should make up less than one percent of the total differential currents. Mode currents represent a primary source of EMI emissions. To reduce common-mode currents, route differential traces so that their lengths are the same. For example, a 5-mm (0.2-inch) length mismatch between differential signals having the rise and fall times of 200 ps results in the common-mode current being up to 18% of the differential current. **Note:** Care must be taken when choosing proper components (such as the termination resistors) in the designing of the layout of a printed circuit board, because of the high application frequency. The use of surface-mount components is highly recommended to minimize parasitic inductance and lead length of the termination resistor. Matching the impedance of the PCB traces, connectors, and balanced interconnect media is also highly recommended. Impedance variations along the entire interconnect path must be minimized, because they degrade the signal path and may cause reflections of the signal. ## 9.3.2 SerDes Interfaces (SGMII, 2.5G) The SGMII interface consists of a Tx and Rx differential pair operating at 1250 Mbps. The 2.5G interface consists of a Tx and Rx differential pair operating at 3125 Mbps. The SerDes signals can be routed on any PCB trace layer with the following constraints: - Tx output signals in a pair should have matched electrical lengths. - Rx input signals in a pair should have matched electrical lengths. - SerDes Tx and Rx pairs must be routed as 100 Ω differential traces with ground plane as reference. - Keep differential pair traces on the same layer of the PCB to minimize impedance discontinuities. In other words, avoid the use of vias wherever possible. - AC-coupling of Tx and Rx may be needed, depending on the attached PHY or module. External AC-coupling is recommended for use with most PHYs. SFP modules have internal AC-coupling, so they do not require additional AC-coupling capacitors. If AC-coupled, the VSC7415 SerDes inputs are self-biased. It is recommended to use small form factor capacitors, 0402 or smaller, to reduce the impedance mismatch caused by the capacitor pads. - To reduce the crosstalk between pairs or other PCB lines, it is recommended that the spacing on each side of the pair be larger than four times the track width. The characteristic impedance of the pairs must predominantly be determined by the distance to the reference plane, and not the distance to neighboring traces. ## 9.3.3 Serial Interface If the serial CPU interface is not used, all input signals can be left floating. The SI bus consists of the SI\_CLK clock signal, the SI\_DO and SI\_DI data signals, and the SI\_nCS0 device select signal. When routing the SI\_CLK signal, be sure to create clean edges. If the SI bus is connected to more than one slave device, route it in a daisy-chain configuration with no stubs. Terminate the SI\_CLK signal properly to avoid reflections and double clocking. If it is not possible (or desirable) to route the bus in a daisy-chain configuration, the SI\_CLK signal should be buffered and routed in a star topology from the buffers. Each buffered clock should be terminated at its source. ## 9.3.4 PCI Express Interface The VSC7415 device does not accept spread spectrum modulated PCIe input. Although the device only supports PCI Express Base Specification Revision 1.1, the PCIe transmitter and receiver support the PCI Express Base Specification Revision 2.0 Electrical sub-block specifications under the following conditions: - Only 2.5 gigatransfers per second (GT/s) is supported. - Full swing output signaling is only supported when $V_{DD\_VS}$ = 1.2 V. - Low swing signaling is supported for $V_{DD\ VS}$ = 1.2 V and $V_{DD\ VS}$ = 1.0 V. During PCIe startup (VCORE\_CFG = 1001), only low swing signaling with no de-emphasis is supported, regardless of the $V_{DD, VS}$ voltage. After startup, configure the PCIe interface as desired. ## 9.3.5 Two-Wire Serial Interface The two-wire serial interface is capable of suppressing small amplitude glitches less than 5 ns in duration, which is less than the 50 ns duration often quoted for similar interfaces. Because the two-wire serial implementation uses Schmitt-triggered inputs, the VSC7415 device has a greater tolerance to low amplitude noise. For glitch-free operation, select the proper pull-up resistor value to ensure that the transition time through the input switching region is less than 5 ns given the line's total capacitive load. For capacitive loads up to 40 pF, a pull-up resistor of 510 $\Omega$ or less ensures glitch-free operation for noise levels up to 700 mV peak-to-peak. ### 9.3.6 DDR3 SDRAM Interface The DDR3 SDRAM interface is designed to interface with 8-bit or 16-bit DDR SDRAM devices. The maximum amount of physical memory that can be addressed is one gigabyte. Possible combinations of memory modules are: - One 8-bit device, connect to CS0 byte lane 0. - Two 8-bit devices, connect to CS0 and both byte lanes. - Four 8-bit devices, connect to both chip-selects and both byte lanes. - One 16-bit device, connect to CS0 and both byte lanes. - Two 16-bit devices, connect to both chip-selects and both byte lanes. When using a single 8-bit device, the memory controller must be configured for 8-bit mode. All other configurations use 16-bit mode. All signals on this interface must be connected one-to-one with the corresponding signals on the DDR SDRAM device. When using only one 8-bit device, the DDR\_UDQS, DDR\_UDQSn, DDR\_UDM, and DDR\_DQ[15:8] signals must be left unconnected. When using DDR2 SDRAM devices that has only four banks, the DDR\_BA[2] signal must be left unconnected. When using four 8-bit devices or two 16-bit devices, the CS1 memory modules must be placed inbetween the VSC7415 device and the CS0 memory modules so that the DDR-DQS, DDR-DM, and DDR DQ signals pass the CS1 devices first before reaching the CS0 devices. The placement of the VSC7415 interface signals is optimized for point-to-point routing directly to a single DDR3 16-bit SDRAM. Figure 158 • 16-Bit DDR3 SDRAM Point-to-Point Routing Because reflections are absorbed by the devices, keep the physical distance of all the SDRAM interface signals as low as possible. Omit external discrete termination on the address, command, control and clock lines. When routing the DDR interface, attention must be paid to the skew, primary concern is skew within the byte lane between the differential strobe and the single-ended signals. Skew recommendations for the DDR interface are listed in the following table. Table 321 • Recommended Skew Budget | Description | Signal | Maximum Skew | |-------------------------|--------------------|--------------| | Skew within byte lane 0 | DDR_LDQS/DDR_LDQSn | 50 ps | Table 321 • Recommended Skew Budget | Description | Signal | Maximum Skew | |------------------------------------------------------|---------------------------------------------------------------------------------------|--------------| | Skew within byte lane 1 | DDR_UDQS/DDR_UDQSn | 50 ps | | Skew within address, command, and control bus | DDR_CK/DDR_CKn DDR_nRAS DDR_CKE DDR_ODT[1:0] DDR_nCAS DDR_nWE DDR_BA[2:0] DDR_A[15:0] | 100 ps | | Skew between control bus clock and byte lane 0 clock | DDR_CK/DDR_CKn<br>DDR_LDQS/DDR_LDQSn | 1250 ps | | Skew between control bus clock and byte lane 1 clock | DDR_CK/DDR_CKn<br>DDR_UDQS/DDR_UDQSn | 1250 ps | | Control bus differential clock intra-pair skew | DDR_CK/DDR_CKn | 5 ps | ### Power supply recommendations: - Use a shared voltage reference between the VSC7415's device's DDR\_Vref supply and the DDR device's reference voltage. - Generate the DDR\_Vref from the $V_{DD\_IODDR}$ supply using a resistor divider with value of 1 k $\Omega$ and an accuracy of 1% or better. - Use a decoupling capacitance of at least 0.1 μF on the supply in a manner similar to V<sub>DD\_IODDR</sub> and V<sub>SS</sub> to ensure tracking of supply variations; however, the time constant of the resistor divider and decoupling capacitance should not exceed the nRESET assertion time after power on. - V<sub>DD\_IODDR</sub> pins must not share vias. Use at least one via for each V<sub>DD\_IODDR</sub> pin. The extra inductance from sharing vias may cause bit errors in the DDR interface. ## Routing recommendations: - DDR\_CK/DDR\_CKn must be routed as a differential pair with a 100 $\Omega$ differential characteristic impedance. - DDR\_xDQS/DDR\_xDQSn must be routed as a differential pair with a 100 $\Omega$ differential characteristic impedance. - To minimize crosstalk, the characteristic impedance of the single-ended signals should be determined predominantly by the distance to the reference plane and not the distance to the neighboring traces. - The crosstalk should be below –20 dB. - If the DDR interface is not used, connect V<sub>DD\_IODDR</sub> and DDR\_V<sub>REF</sub> to ground. Leave all other DDR signals unconnected (floating). V<sub>DD\_IODDR</sub> can also be left floating; however, DDR\_V<sub>REF</sub> must also be left floating. ## 9.3.7 Thermal Diode External Connection The internal on-die thermal diode can be used with an external temperature monitor to easily and accurately measure the junction temperature of this device. The thermal diode is extremely sensitive to noise. To minimize the temperature measurement errors, follow these guidelines: - Route the THERMDC and THERMDA signals as a differential pair with a differential impedance less than 100 Ω. - Place the external temperature monitor as close as is possible to this device. - Add a 47 $\Omega$ resistor in series with the external temperature monitor supply to filter noise. - When using a grounded sensor circuit, place a de-coupling capacitor between the external temperature monitor supply pin and the THERMDC signal. For more information about using a grounded sensor circuit, see Figure 136, page 379. Place the capacitor close to the external temperature sensor, as shown in the following illustration. Connect the external temperature monitor $V_{SS}$ pin directly to the THERMDC pin, which has the connection to $V_{SS}$ , as shown in the following illustration. Do not connect the external temperature monitor $V_{SS}$ pin to the global $V_{SS}$ plane. Figure 159 • External Temperature Monitor Connection # 10 Design Considerations This section provides information about design considerations for the VSC7415 device. #### **EEC Controller WTR timer cannot be stopped** It is not possible to disable the wait-to-restore-timer if the timer has been started. The Wait-to-restore timers can be implemented in the application software. #### EEC output clock locking to selected Input clock is delayed The output clocks controlled by one of the EEC controllers will not lock to the selected input clock until the EEC controller enters the Locked and HO acquired state. A software workaround exists that minimizes the delay in the transition from free-run to locked to only 1 second. #### EEC hold off timer does not work as intended The EEC hold off timer does not work as intended. The implementation of the hold off timer in software solves the issue. #### Half-duplex is not working on the internal CuPHY interfaces Half-duplex operation is possible on all SerDes interfaces. Half-duplex does not work for port 0 and 1 if the internal CuPHY is used. Use external CuPHY interfaces for half-duplex operation on CuPHY interfaces. For fiber, SGMII operation half-duplex is working correctly. # 11 Ordering Information The VSC7415XMT package is a lead-free (Pb-free), 324-pin, plastic ball grid array (BGA) with a 19 mm × 19 mm body size, 1 mm pin pitch, and 1.8 mm maximum height. The following table lists the ordering information for the VSC7415 device. Table 322 • Ordering Information | Part Order Number | Description | |-------------------|-----------------------------------------------------------------------------------------------------------| | VSC7415XMT | Lead-free, 324-pin, plastic BGA with a 19 mm × 19 mm body size, 1 mm pin pitch, and 1.8 mm maximum height |