

# BCM571X/BCM5720 NetXtreme/NetLink BCM571X/BCM5720 Family Programmer's Guide

**Programmer's Guide** 

Copyright © 2010–2023 Broadcom. All Rights Reserved. The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries. For more information, go to <a href="https://www.broadcom.com">www.broadcom.com</a>. All trademarks, trade names, service marks, and logos referenced herein belong to their respective companies.

Broadcom reserves the right to make changes without further notice to any products or data herein to improve reliability, function, or design. Information furnished by Broadcom is believed to be accurate and reliable. However, Broadcom does not assume any liability arising out of the application or use of this information, nor the application or use of any product or circuit described herein, neither does it convey any license under its patent rights nor the rights of others.

# **Table of Contents**

| Chap | pter 1: Introduction                 | 27 |
|------|--------------------------------------|----|
| 1.1  | About this Document                  | 27 |
|      | 1.1.1 Purpose and Audience           | 27 |
|      | 1.1.2 Document Conventions           | 27 |
|      | 1.1.3 References                     | 28 |
| 1.2  | Product Features                     | 29 |
| 1.3  | Revision Levels                      | 30 |
| 1.4  | Programming the Ethernet Controllers | 31 |
| Chap | pter 2: Hardware Architecture        | 32 |
| 2.1  | Theory of Operation                  | 32 |
| 2.2  | 2 Overview of Features               | 33 |
| 2.3  | Receive Data Path                    | 35 |
|      | 2.3.1 RX Engine                      | 35 |
|      | 2.3.2 RX FIFO                        | 35 |
|      | 2.3.3 Rules Checker                  | 36 |
|      | 2.3.4 RX List Initiator              | 36 |
| 2.4  | Transmit Data Path                   | 37 |
|      | 2.4.1 TX MAC                         | 37 |
|      | 2.4.2 TX FIFO                        | 37 |
| 2.5  | 5 DMA Read                           | 37 |
|      | 2.5.1 Read Engine                    | 37 |
|      | 2.5.2 Read FIFO                      | 38 |
|      | 2.5.3 Buffer Manager                 | 38 |
| 2.6  | 5 DMA Write                          | 38 |
|      | 2.6.1 Write Engine                   | 38 |
|      | 2.6.2 Write FIFO                     | 39 |
|      | 2.6.3 Buffer Manager                 | 39 |
| 2.7  | ' LED Control                        | 39 |
| 2.8  | B Memory Arbiter                     | 40 |
| 2.9  | Host Coalescing                      | 41 |
|      | 2.9.1 Host Coalescing Engine         |    |
|      | 2.9.2 MSI FIFO                       | 42 |
|      | 2.9.3 Status Block                   | 42 |
| 2.1  | 0 10BT/100BTx/1000BASE-T Transceiver | 42 |
|      | 2.10.1 Auto-Negotiation              | 42 |
|      | 2.10.2 Automatic MDI Crossover       | 42 |
| 2.1  | 1 PHY Control                        | 43 |

| 2.11.1 MII Block                                                   | 43 |
|--------------------------------------------------------------------|----|
| 2.11.2 GMII Block                                                  | 44 |
| 2.11.3 MDIO Register Interface                                     | 46 |
| 2.11.3.1 Management Data Clock                                     | 46 |
| 2.11.3.2 Management Data Input/Output                              | 46 |
| 2.11.3.3 Management Data Interrupt                                 | 46 |
| 2.11.3.4 Management Register Block                                 | 46 |
| Chapter 3: NVRAM Configuration                                     | 47 |
| 3.1 Overview                                                       | 47 |
| 3.2 Self-Boot                                                      | 47 |
| Chapter 4: Common Data Structures                                  | 48 |
| 4.1 Theory of Operation                                            |    |
| 4.2 Descriptor Rings                                               | 48 |
| 4.2.1 Producer and Consumer Indices                                | 49 |
| 4.2.2 Ring Control Blocks                                          | 50 |
| 4.2.2.1 Send Ring Control Blocks                                   | 50 |
| 4.2.2.2 Receive Ring Control Blocks                                | 51 |
| 4.2.3 Send Rings                                                   | 52 |
| 4.2.3.1 Send Buffer Descriptors                                    | 54 |
| 4.2.3.1.1 Standard (Not Large Segment Offload)                     |    |
| 4.2.3.1.2 Large Segment Offload (LSO) Send BD                      |    |
| 4.2.4 Receive Rings                                                |    |
| 4.2.4.1 Receive Producer Ring                                      |    |
| 4.2.4.2 Receive Return Rings                                       |    |
| 4.2.4.3 Receive Buffer Descriptors                                 |    |
| 4.2.4.4 Additional Ring Information for the BCM571X/BCM5720 Family |    |
| 4.3 Status Block                                                   |    |
| 4.3.1 Status Block Format                                          |    |
| 4.3.1.1 INTx/MSI — Legacy Mode Status Block Format                 |    |
| 4.3.1.2 Single-Vector or INTx — RSS Mode Status Block Format       |    |
| 4.3.1.3 Multivector RSS Mode Status Block Format                   |    |
| 4.3.1.4 Status Block and INT MailBox Addresses                     |    |
| Chapter 5: Receive Data Flow                                       |    |
| 5.1 Introduction                                                   |    |
| 5.2 Receive Producer Ring                                          |    |
| 5.2.1 Setup of Producer Rings Using RCBs                           |    |
| 5.2.1.1 Receive Producer Ring RCB—Register Offset 0x2450–0x245f    |    |
| 5.2.1.1.1 Other Considerations Relating to Producer Ring Setup     |    |
| 5.2.1.2 RCB Setup Pseudo Code                                      |    |
| J.Z.Z. NCCCIVE DUILEI DESCHDIOIS                                   | n9 |

|      | 5.2.3 Management of Rx Producer Rings with Mailbox Registers and Status Block | 70 |
|------|-------------------------------------------------------------------------------|----|
|      | 5.2.3.1 Status Block                                                          | 70 |
|      | 5.2.3.2 Mailbox                                                               | 70 |
|      | 5.2.3.2.1 Receive BD Producer Ring Producer Index                             | 70 |
| 5.3  | Receive Return Rings                                                          | 71 |
|      | 5.3.1 Management of Return Rings with Mailbox Registers and Status Block      | 72 |
|      | 5.3.2 Host Buffer Allocation                                                  | 72 |
|      | 5.3.3 Receive Rules Setup and Frame Classification                            | 73 |
|      | 5.3.3.1 Receive Rules Configuration Register                                  | 73 |
|      | 5.3.3.2 Receive List Placement Rules Array                                    | 74 |
|      | 5.3.3.3 Class of Service Example                                              | 75 |
| 5.4  | Checksum Calculation                                                          | 76 |
| 5.5  | VLAN Tag Strip                                                                | 76 |
| 5.6  | RX Data Flow Diagram                                                          | 78 |
| 5.7  | Receive Side Scaling                                                          | 79 |
|      | 5.7.1 Overview                                                                | 79 |
|      | 5.7.2 Functional Description                                                  | 79 |
|      | 5.7.3 RSS Parameters                                                          | 80 |
|      | 5.7.3.1 Hash Function                                                         | 80 |
|      | 5.7.3.2 Hash Type                                                             | 80 |
|      | 5.7.3.3 Hash Mask                                                             | 80 |
|      | 5.7.3.4 Indirection Table                                                     | 80 |
|      | 5.7.3.5 Secret Hash Key                                                       | 80 |
|      | 5.7.4 RSS Initialization                                                      | 80 |
|      | 5.7.5 RSS Rx Packet Flow                                                      | 82 |
| Chap | oter 6: Transmit Data Flow                                                    | 83 |
| 6.1  | Introduction                                                                  | 83 |
| 6.2  | Send Rings                                                                    | 83 |
|      | 6.2.1 Ring Control Block                                                      | 85 |
|      | 6.2.2 Host-Based Send Ring                                                    | 86 |
| 6.3  | Checksum Offload                                                              | 86 |
| 6.4  | Large Segment Offload                                                         | 88 |
|      | 6.4.1 QuickStart                                                              | 88 |
|      | 6.4.2 LSO-Related Hardware Control Bits                                       | 89 |
|      | 6.4.3 Send Buffer Descriptor                                                  | 90 |
|      | 6.4.3.1 Host Address                                                          | 90 |
|      | 6.4.3.2 Length[15:0]                                                          | 90 |
|      | 6.4.3.3 VLAN Tag[15:0]                                                        |    |
|      | 6.4.3.4 HdrLen[7:0]                                                           | 90 |
|      | 6.4.3.5 MSS[13:0]                                                             |    |

| 6.4.3.6 Flags                                                  |     |
|----------------------------------------------------------------|-----|
| 6.4.4 LSO Limitations                                          |     |
| 6.4.5 Additional LSO Notes                                     | 92  |
| 6.4.5.1 Example TCP-segmentation-related (LSO) register values | 92  |
| 6.5 Jumbo Frames                                               | 93  |
| 6.5.1 Affected Data Structures                                 | 94  |
| 6.5.1.1 Extended RX Buffer Descriptor (BD)                     | 94  |
| 6.5.1.2 Receive Jumbo Producer Ring                            | 96  |
| 6.5.1.3 Ring Control Blocks                                    | 97  |
| 6.5.1.4 Receive Return Ring(s)                                 | 98  |
| 6.5.1.5 Send Buffer Descriptor                                 | 98  |
| 6.5.1.6 Status Block                                           | 99  |
| 6.5.1.7 Misc BD Memory                                         | 100 |
| 6.5.2 Device Driver Interface                                  | 100 |
| 6.5.2.1 Send Interface                                         | 100 |
| 6.5.2.2 Receive Interface                                      | 101 |
| 6.5.2.3 Large Segment Offload (LSO/TSO)                        | 103 |
| 6.5.3 Summary of Register Settings to Support Jumbo Frames     | 104 |
| 6.6 Scatter/Gather                                             | 105 |
| 6.7 VLAN Tag Insertion                                         | 105 |
| 6.8 TX Data Flow Diagram                                       | 106 |
| 6.9 Reset                                                      | 109 |
| 6.10 MAC Address Setup/Configuration                           | 110 |
| 6.11 Packet Filtering                                          | 110 |
| 6.11.1 Multicast Hash Table Setup/Configuration                | 110 |
| 6.11.2 Ethernet CRC Calculation                                | 111 |
| 6.11.3 Generating CRC                                          | 111 |
| 6.11.4 Checking CRC                                            | 111 |
| 6.11.5 Initializing the MAC Hash Registers                     | 111 |
| 6.11.6 Promiscuous Mode Setup/Configuration                    | 113 |
| 6.11.7 Broadcast Setup/Configuration                           | 113 |
| Chapter 7: Device Control                                      | 114 |
| 7.1 Initialization Procedure                                   | 114 |
| 7.2 Device Reset Procedure                                     | 120 |
| 7.3 Device Closing Procedure                                   | 121 |
| 7.4 Energy Efficient Ethernet <sup>™</sup>                     | 122 |
| Chapter 8: IEEE1588                                            |     |
| 8.1 IEEE1588 Time Sync Introduction                            |     |
| 8 2 NetXtreme Time Sync Assist                                 | 125 |

|      | 8.2.1 Coexistence                                         | 125 |
|------|-----------------------------------------------------------|-----|
|      | 8.2.2 PTP Link Delay Measurement                          | 126 |
|      | 8.2.3 PTP Time Synchronization Messaging                  | 126 |
| 8.3  | Hardware Description                                      | 127 |
|      | 8.3.1 EAV Reference Clock/Counter                         | 128 |
| 8.4  | EAV Reference Corrector                                   | 129 |
|      | 8.4.1 Time Watchdogs                                      | 129 |
|      | 8.4.2 Divided EAV Reference Clock Output                  | 129 |
| 8.5  | Transmit Time Stamping Service                            | 130 |
| 8.6  | Receive Time Stamp and Sequence ID Registers              | 131 |
| 8.7  | ' Time Sync Registers                                     | 133 |
|      | 8.7.1 GRC MODE REG [0x6800]                               | 133 |
|      | 8.7.2 EAV REF COUNT CAPTURE LSB REG [Offset 0x6900]       | 133 |
|      | 8.7.3 EAV REF COUNT CAPTURE MSB REG [Offset 0x6904]       | 133 |
|      | 8.7.4 EAV REF CLOCK CONTROL REG [Offset 0x6908]           | 133 |
|      | 8.7.5 EAV REF-COUNT SNAP-SHOT LSB[0] REG [Offset 0X6910]  | 134 |
|      | 8.7.6 EAV REF-COUNT SNAP-SHOT MSB[0] REG [Offset 0X6914]  | 135 |
|      | 8.7.7 EAV REF CORRECTOR REG [Offset 0x6928]               | 135 |
|      | 8.7.8 TX TIME STAMP LSB REG [Offset 0x05C0]               | 135 |
|      | 8.7.9 TX TIME STAMP MSB REG [Offset 0X05C4]               | 135 |
|      | 8.7.10 RX TIME STAMP LSB REG [Offset 0X06B0]              | 135 |
|      | 8.7.11 RX TIME STAMP MSB REG [Offset 0x06B4]              |     |
|      | 8.7.12 RX PTP SEQUENCE ID REG [Offset 0X06B8]             | 136 |
|      | 8.7.13 RX LOCK TIMER LSB REG [Offset 0x06C0]              | 136 |
|      | 8.7.14 RX LOCK TIMER MSB REG [Offset 0x06C4]              |     |
|      | 8.7.15 RX PTP CONTROL REG [Offset 0X06C8]                 | 136 |
|      | 8.7.16 TX TIME WATCHDOG LSB[0] REG [Offset 0x6918]        | 137 |
|      | 8.7.17 TX TIME WATCHDOG MSB[0] REG [Offset 0x691C]        |     |
|      | 8.7.18 TX TIME WATCHDOG LSB[1] REG [Offset 0x6920]        |     |
|      | 8.7.19 TX TIME WATCHDOG MSB[1] REG [Offset 0x6924]        |     |
|      | 8.7.20 EAV REF-COUNT SNAP-SHOT LSB[1] REG [Offset 0X6930] |     |
|      | 8.7.21 EAV REF-COUNT SNAP-SHOT MSB[1] REG [Offset 0X6934] |     |
| Chap | pter 9: PCI                                               | 139 |
| 9.1  | Configuration Space                                       | 139 |
|      | 9.1.1 Description                                         | 139 |
|      | 9.1.2 Functional Overview                                 | 141 |
|      | 9.1.2.1 PCI Configuration Space Registers                 | 141 |
|      | 9.1.2.2 PCI Required Header Region                        | 141 |
|      | 9.1.2.3 Indirect Mode                                     | 142 |
|      | 9.1.2.4 Indirect Register Access                          | 142 |

|     | 9.1.2.5 Indirect Memory Access                                        | 144 |
|-----|-----------------------------------------------------------------------|-----|
|     | 9.1.2.6 UNDI Mailbox Access                                           | 146 |
|     | 9.1.2.7 Standard Mode                                                 | 148 |
|     | 9.1.3 Memory Mapped I/O Registers                                     | 153 |
|     | 9.1.3.1 PCI Command Register                                          | 153 |
|     | 9.1.3.2 PCI State Register                                            | 153 |
|     | 9.1.3.3 PCI Base Address Register                                     | 153 |
| 9.2 | Bus Interface                                                         | 155 |
|     | 9.2.1 Description                                                     | 155 |
|     | 9.2.2 Operational Characteristics                                     | 156 |
|     | 9.2.2.1 Read/Write DMA Engines                                        | 156 |
| 9.3 | Expansion ROM                                                         | 156 |
|     | 9.3.1 Description                                                     | 156 |
|     | 9.3.2 Operational Characteristics                                     | 156 |
|     | 9.3.3 BIOS                                                            | 156 |
|     | 9.3.3.1 Preboot Execution Environment                                 | 157 |
| 9.4 | Power Management                                                      | 157 |
|     | 9.4.1 Description                                                     | 157 |
|     | 9.4.2 Operational Characteristics                                     | 157 |
|     | 9.4.2.1 Device State D0 (Uninitialized)                               | 158 |
|     | 9.4.2.2 Device State D0 (Active)                                      | 158 |
|     | 9.4.2.3 Device State D3 (Hot)                                         | 158 |
|     | 9.4.2.4 Device State D3 (Cold)                                        | 159 |
|     | 9.4.3 Wake on LAN                                                     | 159 |
|     | 9.4.4 GPIO                                                            | 160 |
|     | 9.4.5 Power Supply in D3 State                                        | 160 |
|     | 9.4.6 Clock Control                                                   | 160 |
|     | 9.4.7 Device ACPI Transitions                                         | 161 |
|     | 9.4.8 Disable Device Through BIOS                                     | 161 |
| 9.5 | Endian Control (Byte and Word Swapping)                               |     |
|     | 9.5.1 Background                                                      | 162 |
|     | 9.5.2 Architecture                                                    | 163 |
|     | 9.5.3 Enable Endian Word Swap and Enable Endian Byte Swap Bits        | 163 |
|     | 9.5.4 Word Swap Data and Byte Swap Data Bits                          | 166 |
|     | 9.5.4.1 Word Swap Data = 0, and Byte Swap Data = 0                    | 166 |
|     | 9.5.4.2 Word Swap Data = 0, and Byte Swap Data = 1                    |     |
|     | 9.5.4.3 Word Swap Data = 1, and Byte Swap Data = 0                    |     |
|     | 9.5.4.4 Word Swap Data = 1, and Byte Swap Data = 1                    |     |
|     | 9.5.5 Word Swap Non-Frame Data and Byte Swap Non-Frame Data Bits      |     |
|     | 9.5.5.1 Word Swap Non-Frame Data = 0 and Byte Swap Non-Frame Data = 0 | 170 |

| 9.5.5.2 Word Swap Non-Frame Data = 1 and Byte Swap Non-Frame Data = 0                             | 170 |
|---------------------------------------------------------------------------------------------------|-----|
| 9.5.5.3 Word Swap Non-Frame Data = 0 and Byte Swap Non-Frame Data = 1                             | 170 |
| 9.5.5.4 Word Swap Non-Frame Data = 1 and Byte Swap Non-Frame Data = 1                             |     |
| Chapter 10: Ethernet Link Configuration                                                           | 172 |
| 10.1 Overview                                                                                     |     |
| 10.2 GMII/MII                                                                                     | 172 |
| 10.2.1 Configuring the Ethernet Controller for GMII and MII Modes                                 | 172 |
| 10.2.2 Link Status Change Indications                                                             |     |
| 10.2.3 Configuring the GMII/MII PHY                                                               | 173 |
| 10.2.3.1 Reading a PHY Register                                                                   | 173 |
| 10.2.3.2 Writing a PHY Register                                                                   | 173 |
| 10.2.3.3 PHY Loopback Configuration                                                               | 174 |
| 10.2.3.3.1 External PHY Loopback                                                                  |     |
| 10.2.3.3.2 Internal PHY Loopback                                                                  |     |
| 10.2.3.4 PHY Configuration Auto-Negotiation (10/100/1000 Speed with Half and Full Duplex Support) |     |
| 10.3 MDI Register Access                                                                          |     |
| 10.3.1 Operational Characteristics                                                                |     |
| 10.3.2 Access Method                                                                              |     |
| 10.3.2.1 Auto-Access Method                                                                       |     |
| 10.4 Wake on LAN Mode/Low-Power                                                                   |     |
| 10.4.1 Description                                                                                |     |
| 10.4.2 Functional Overview                                                                        |     |
| 10.4.3 Operational Characteristics                                                                |     |
| 10.4.3.1 Internal Memory                                                                          |     |
| 10.4.3.2 WOL Pattern Configuration Register                                                       |     |
| 10.4.3.4 Pattern Data Structure                                                                   |     |
| 10.4.3.5 Firmware Mailbox                                                                         |     |
| 10.4.3.6 PHY Auto-Negotiation                                                                     |     |
| 10.4.3.7 Power Management                                                                         |     |
| 10.4.3.8 Integrated MACs                                                                          |     |
| 10.4.4 WOL Data Flow Diagram                                                                      |     |
| 10.5 Flow Control                                                                                 |     |
| 10.5.1 Description                                                                                |     |
| 10.5.2 Operational Characteristics                                                                |     |
| 10.5.2.1 Transmit MAC                                                                             |     |
| 10.5.2.2 Receive MAC                                                                              |     |
| 10.5.2.3 Statistics Block                                                                         |     |
| 10.5.2.4 PHY Auto-Negotiation                                                                     |     |
| 10.5.2.5 Integrated MACs                                                                          |     |

| 10.5.3 Flow Control Initialization Pseudocode                                       | 194 |
|-------------------------------------------------------------------------------------|-----|
| Chapter 11: Interrupt Processing                                                    | 196 |
| 11.1 NetXtreme Legacy Interrupt Model                                               | 196 |
| 11.1.1 ISR Flow                                                                     | 197 |
| 11.1.1.1 Legacy Status TAGGING Mode                                                 | 198 |
| 11.2 Basic Driver Interrupt Processing Flow                                         | 199 |
| 11.2.1 Flowchart for Servicing an Interrupt                                         | 199 |
| 11.2.2 Interrupt Procedure                                                          | 200 |
| 11.3 Host Coalescing                                                                | 201 |
| 11.3.1 Description                                                                  | 201 |
| 11.3.2 Operational Characteristics                                                  | 201 |
| 11.3.3 Registers                                                                    | 202 |
| 11.4 MSI                                                                            | 203 |
| 11.4.1 Traditional Interrupt Scheme                                                 | 203 |
| 11.4.2 Message Signaled Interrupt                                                   | 204 |
| 11.4.3 PCI Configuration Registers                                                  | 205 |
| 11.4.3.1 MSI Address                                                                | 205 |
| 11.4.3.2 MSI Data                                                                   | 205 |
| 11.4.4 Host Coalescing Engine                                                       | 206 |
| 11.4.5 Firmware                                                                     | 206 |
| 11.5 MSI-X                                                                          | 207 |
| 11.6 MSI-X Plumbing                                                                 | 211 |
| 11.6.1 Replication of Status Blocks and INT Mailboxes                               | 211 |
| 11.6.1.1 Single-Vector RSS Mode Status Block Format                                 | 212 |
| 11.6.1.2 Single-Vector IOV Mode Status Block Format                                 | 213 |
| 11.6.1.3 Multivector RSS Mode Status Block Format                                   | 214 |
| 11.6.1.4 Multivector IOV Mode Status Block Format                                   | 215 |
| 11.6.2 MSI-X Capability Structure                                                   | 215 |
| 11.6.3 MSI-X Data Structures                                                        | 216 |
| 11.6.4 MSI-X Cognizant Host Coalescing                                              | 218 |
| 11.6.4.1 Legacy Host Coalescing Parameters                                          | 218 |
| 11.6.4.1.1 Receive Coalescing Ticks Register (Offset: 0x3c08)                       |     |
| 11.6.4.1.2 Send Coalescing Ticks Register (Offset: 0x3c0c)                          |     |
| 11.6.4.1.3 Receive Max Coalesced Bd Count Register (Offset: 0x3c10)                 |     |
| 11.6.4.1.5 Receive Max Coalesced BD Count During Interrupt Register (Offset 0x3c18) |     |
| 11.6.4.1.6 Send Max Coalesced BD Count During Interrupt Register (Offset 0x3c1c)    |     |
| 11.6.4.2 BCM571X/BCM5720 Family Host Coalescing Parameter Sets                      | 220 |
| 11.6.4.3 MSI-X One Shot Mode                                                        | 222 |
| 11.6.4.4 Coalesce Now or Forced Update                                              | 222 |
| 11.6.4.5 Misc Coalescing Controls                                                   | 223 |

| 11.6.4.5.1 Broadcom Tagged Status Mode (0x68[9])                                  | 223 |
|-----------------------------------------------------------------------------------|-----|
| 11.6.4.5.2 Clear Interrupt, Mask Interrupt, Mask Mode (0x68[0], 0x68[1], 0x68[8]) |     |
| 11.6.4.5.3 Clear Ticks On Rx Bd Events Mode (0x3c00[9])                           |     |
| 11.6.4.5.4 No Interrupt On Force Update (0x3c00[11])                              |     |
| 11.6.4.5.5 No Interrupt On DMAD Force (0x3c00[12])                                |     |
| 11.6.4.6 End of Receive Stream Interrupt                                          |     |
| 11.6.4.6.1 Host Coalescing Mode Register (Offset 0x3c00)                          |     |
| 11.6.4.6.2 End Stream Debounce Register (Offset 0x3cd4)                           | 224 |
| 11.7 Other Configuration Controls                                                 | 226 |
| 11.7.1 Broadcom Mask Mode                                                         | 226 |
| 11.7.2 Broadcom Tagged Status Mode                                                | 226 |
| 11.7.3 Clear Ticks on BD Events Mode                                              | 226 |
| 11.7.4 No Interrupt on Force Update                                               | 226 |
| 11.7.5 No Interrupt on DMAD Force                                                 | 226 |
| Chapter 12: IO Virtualization (IOV)                                               | 227 |
| 12.1 Data Structure and Register Changes for IOV                                  | 228 |
| 12.1.1 Mail Box Register Changes                                                  | 228 |
| 12.1.2 Receive Mail Box Register Changes                                          | 228 |
| 12.1.3 Send Mail Box Register Changes                                             | 228 |
| 12.1.4 Ring Control Block Changes                                                 | 228 |
| 12.1.5 VRQ Statistics                                                             | 228 |
| 12.1.6 MSI-X Vectors Changes                                                      | 228 |
| 12.1.7 Register Changes                                                           | 229 |
| 12.2 IOV – Receive Side                                                           | 229 |
| 12.3 IOV – Transmit Side                                                          | 230 |
| Chapter 13: Ethernet Controller Register Definitions                              | 232 |
| 13.1 BCM571X/BCM5720 Family Register MAP                                          |     |
| 13.2 PCI Configuration Registers                                                  | 234 |
| 13.2.1 Device ID and Vendor ID Register (offset: 0x00)                            |     |
| 13.2.2 Status and Command Register (offset: 0x04)                                 |     |
| 13.2.3 PCI Classcode and Revision ID Register (offset: 0x08)                      |     |
| 13.2.4 BIST, Header Type, Latency Timer, Cache Line Size Register (offset: 0x0C)  |     |
| 13.2.5 Base Address Register 1 (offset: 0x10)                                     |     |
| 13.2.6 Base Address Register 2 (offset: 0x14)                                     |     |
| 13.2.7 Base Address Register 3 (offset: 0x18)                                     |     |
| 13.2.8 Base Address Register 4 (offset: 0x1c)                                     |     |
| 13.2.9 Base Address Register 5 (offset: 0x20)                                     |     |
| 13.2.10 Base Address Register 6 (offset: 0x24)                                    |     |
| 13.2.11 Cardbus CIS Pointer Register (offset: 0x28)                               |     |
| 13.2.12 Subsystem ID/Vendor ID Register (offset: 0x2C)                            |     |

| 13.2.13 Expansion ROM Base Address Register (offset: 0x30)                                         | 239 |
|----------------------------------------------------------------------------------------------------|-----|
| 13.2.14 Capabilities Pointer Register (offset: 0x34)                                               | 239 |
| 13.2.15 Interrupt Register (offset: 0x3C)                                                          | 239 |
| 13.2.16 INT Mailbox Register (offset: 0x40-0x44)                                                   | 240 |
| 13.2.17 Power Management Capability Register (offset: 0x48)                                        | 241 |
| 13.2.18 Power Management Control/Status Register (offset: 0x4C)                                    | 241 |
| 13.2.19 MSI Capability Header (offset: 0x58)                                                       | 243 |
| 13.2.20 MSI Lower Address Register (offset: 0x5C)                                                  | 243 |
| 13.2.21 MSI Upper Address Register (offset: 0x60)                                                  | 244 |
| 13.2.22 MSI Data Register (offset: 0x64)                                                           | 244 |
| 13.2.23 Miscellaneous Host Control Register (offset: 0x68)                                         | 244 |
| 13.2.24 DMA Read/Write Control Register (Offset: 0x6C)                                             | 245 |
| 13.2.25 PCI State Register (offset: 0x70)                                                          | 247 |
| 13.2.26 Reset Counters Initial Values Register (offset: 0x74)                                      | 248 |
| 13.2.27 Register Base Register (offset: 0x78)                                                      | 248 |
| 13.2.28 Memory Base Register (offset: 0x7C)                                                        | 248 |
| 13.2.29 Register Data Register (offset: 0x80)                                                      | 248 |
| 13.2.30 Memory Data Register (offset: 0x84)                                                        | 248 |
| 13.2.31 UNDI Receive Return Ring Consumer Index Register (offset: 0x88–0x8C)                       | 249 |
| 13.2.32 UNDI Send BD Producer Index Mailbox Register (offset: 0x90–0x94)                           | 249 |
| 13.2.33 UNDI Receive BD Standard Producer Ring Producer Index Mailbox Register (offset: 0x98–0x9C) | 249 |
| 13.2.34 MSI-X Capabilities Registers                                                               | 250 |
| 13.2.34.1 MSI-X Capability Header Register (offset: 0xA0)                                          | 250 |
| 13.2.34.2 MSIX_TBL_OFF_BIR - 0xa4                                                                  | 250 |
| 13.2.34.3 MSIX_PBA_BIR_OFF - 0xa8                                                                  | 250 |
| 13.2.35 PCle Capabilities Registers                                                                | 251 |
| 13.2.35.1 PCIE_CAPABILITY – 0xac                                                                   | 251 |
| 13.2.35.2 DEVICE_CAPABILITY - 0xb0                                                                 | 252 |
| 13.2.35.3 DEVICE_STATUS_CONTROL - 0xb4                                                             | 253 |
| 13.2.35.4 LINK_CAPABILITY – 0xb8                                                                   | 254 |
| 13.2.35.5 LINK_STATUS_CONTROL – 0xbc                                                               | 256 |
| 13.2.35.6 SLOT_CAPABILITY - 0xc0                                                                   | 257 |
| 13.2.35.7 SLOT_CONTROL_STATUS - 0xc4                                                               | 258 |
| 13.2.35.8 ROOT_CAP_CONTROL - 0xc8                                                                  | 258 |
| 13.2.35.9 ROOT_STATUS - 0xcc                                                                       | 258 |
| 13.2.35.10 DEVICE_CAPABILITY_2 - 0xd0                                                              | 259 |
| 13.2.35.11 DEVICE_STATUS_CONTROL2 - 0xd4                                                           |     |
| 13.2.35.12 LINK_CAPABILITY_2 - 0xd8                                                                | 260 |
| 13.2.35.13 LINK_STATUS_CONTROL_2 - 0xdc                                                            | 260 |
| · · · · · · · · · · · · · · · · · · ·                                                              | 200 |

| 13.2.35.15 SLOT_STATUS_CONTROL_2 - 0xe4                                         | 262           |
|---------------------------------------------------------------------------------|---------------|
| 13.2.36 Product ASIC ID (offset: 0xF4)                                          | 262           |
| 13.2.37 Advanced Error Reporting Enhanced Capability Header (offset             | et: 0x100)263 |
| 13.2.38 Uncorrectable Error Status Register (offset: 0x104)                     | 263           |
| 13.2.39 Uncorrectable Error Mask Register (offset: 0x108)                       | 264           |
| 13.2.40 Uncorrectable Error Severity Register (offset: 0x10C)                   | 265           |
| 13.2.41 Correctable Error Status Register (offset: 0x110)                       | 266           |
| 13.2.42 Correctable Error Mask Register (offset: 0x114)                         | 266           |
| 13.2.43 Advanced Error Capabilities and Control Register (offset: 0x1           | 18)267        |
| 13.2.44 Header Log Register (offset: 0x11C)                                     | 267           |
| 13.2.45 Header Log Register (offset: 0x120)                                     | 267           |
| 13.2.46 Header Log Register (offset: 0x124)                                     | 267           |
| 13.2.47 Header Log Register (offset: 0x128)                                     | 268           |
| 13.2.48 Interrupt mail box (High Priority Mailbox) Register                     | 000           |
| (offset: 0x200 – 0x21c)                                                         | 268           |
| 13.2.49 General mail box (High Priority Mailbox) Register (offset: 0x220–0x25c) | 268           |
| 13.2.50 Reload Statistics mail box (High Priority Mailbox)                      | 200           |
| Register (offset: 0x260–0x264)                                                  | 268           |
| 13.3 High Priority Mailbox Registers                                            | 269           |
| 13.3.1 Receive BD Standard Producer Ring Index                                  |               |
| Register (offset: 0x268-0x26F)                                                  |               |
| 13.3.1.1 Receive BD Jumbo Producer Ring Index Register (offse                   | t: 0x270)269  |
| 13.3.2 Receive BD Return Ring 0 Consumer Index Register (offset: 0x280–0x287)   | 260           |
| 13.3.3 Receive BD Return Ring 1 Consumer Index                                  | 209           |
| Register (offset: 0x288–0x28F)                                                  | 269           |
| 13.3.4 Receive BD Return Ring 2 Consumer Index                                  |               |
| Register (offset: 0x290–0x297)                                                  | 269           |
| 13.3.5 Receive BD Return Ring 3 Consumer Index                                  | 070           |
| Register (offset: 0x298–0x29F)                                                  |               |
| 13.3.6 Send BD Ring Host Producer Index Register (offset: 0x300–0x              | •             |
| 13.4 RX Mail Box Registers for VRQ                                              |               |
| 13.5 Ethernet MAC (EMAC) Registers                                              |               |
| 13.5.1 EMAC Mode Register (offset: 0x400)                                       |               |
| 13.5.2 EMAC Status Register (offset: 0x404)                                     |               |
| 13.5.3 EMAC Event Enable Register (offset: 0x408)                               |               |
| 13.5.4 LED Control Register (offset: 0x40C)                                     |               |
| 13.5.5 EMAC MAC Addresses 0 High Register (offset: 0x410)                       |               |
| 13.5.6 EMAC MAC Addresses 0 Low Register (offset: 0x414)                        |               |
| 13.5.7 EMAC MAC Addresses 1 High Register (offset: 0x418)                       |               |
| 13.5.8 EMAC MAC Addresses 1 Low Register (offset: 0x41C)                        | 2/5           |

Broadcom

| 13.5.9 EMAC MAC Addresses 2 High Register (offset: 0x420)                        | 275 |
|----------------------------------------------------------------------------------|-----|
| 13.5.10 EMAC MAC Addresses 2 Low Register (offset: 0x424)                        | 275 |
| 13.5.11 EMAC MAC Addresses 3 High Register (offset: 0x428)                       | 275 |
| 13.5.12 EMAC MAC Addresses 3 Low Register (offset: 0x42C)                        | 275 |
| 13.5.13 WOL Pattern Pointer Register (offset: 0x430)                             | 276 |
| 13.5.14 WOL Pattern Configuration Register (offset: 0x434)                       | 276 |
| 13.5.15 Ethernet Transmit Random Backoff Register (offset: 0x438)                | 276 |
| 13.5.16 Receive MTU Size Register (offset: 0x43C)                                | 276 |
| 13.5.17 Gigabit PCS Test Register (offset: 0x440)                                | 276 |
| 13.5.18 Transmit 1000BASE-X Auto-Negotiation Register (offset: 0x444)            | 277 |
| 13.5.19 Receive 1000BASE-X Auto-Negotiation Register (offset: 0x448)             | 277 |
| 13.5.20 MII Communication Register (offset: 0x44C)                               | 277 |
| 13.5.21 MII Status Register (offset: 0x450)                                      | 277 |
| 13.5.22 MII Mode Register (offset: 0x454)                                        | 278 |
| 13.5.23 Autopolling Status Register (offset: 0x458)                              | 278 |
| 13.5.24 Transmit MAC Mode Register (offset: 0x45C)                               | 278 |
| 13.5.25 Transmit MAC Status Register (offset: 0x460)                             | 280 |
| 13.5.26 Transmit MAC Lengths Register (offset: 0x464)                            | 280 |
| 13.5.27 Receive MAC Mode Register (offset: 0x468)                                | 281 |
| 13.5.28 Receive MAC Status Register (offset: 0x46C)                              | 283 |
| 13.5.29 MAC Hash Register 0 (offset: 0x470)                                      |     |
| 13.5.30 MAC Hash Register 1 (offset: 0x474)                                      |     |
| 13.5.31 MAC Hash Register 2 (offset: 0x478)                                      | 283 |
| 13.5.32 MAC Hash Register 3 (offset: 0x47C)                                      |     |
| 13.5.33 Receive Rules Control Registers (offset: 0x480 + 8*N)                    |     |
| 13.5.34 Receive Rules Value/Mask Registers (offset: 0x484 + 8*N)                 | 284 |
| 13.5.35 Receive Rules Configuration Register (offset: 0x500)                     |     |
| 13.5.36 Low Watermark Maximum Receive Frame Register (offset: 0x504)             |     |
| 13.5.37 APE_PERFECT_MATCH[1-4]_HIGH_REG (Offsets 0x540, 0x548, 0x550, 0x558)     | 286 |
| 13.5.38 APE_PERFECT_MATCH[1-4]_LOW_REG (Offsets 0x544, 0x54C, 0x554, 0x55C)      | 286 |
| 13.5.39 SGMII Control Register (offset: 0x5B0)                                   | 286 |
| 13.5.40 SGMII Status Register (offset: 0x5B4)                                    | 286 |
| 13.5.41 HTX2B Perfect Match[1-4] HI Reg (offset: 0x4880, 0x4888, 0x4890, 0x4898) | 287 |
| 13.5.42 HTX2B Perfect Match[1-4] LO Reg (offset: 0x4884, 0x488C, 0x4894, 0x489C) | 287 |
| 13.5.43 HTX2B Protocol Filter Reg (offset: 0x6D0)                                |     |
| 13.5.44 HTX2B Global Filter Reg (address: 0x6D4)                                 | 289 |
| 13.6 RSS Registers                                                               |     |
| 13.6.1 Indirection Table Register 0 (offset: 0x630)                              |     |
| 13.6.2 Indirection Table Register 2 (offset: 0x634)                              |     |
| 13.6.3 Indirection Table Register 3 (offset: 0x638)                              | 290 |

| 13.6.4 Indirection Table Register 4 (offset: 0x63C)                             | 290 |
|---------------------------------------------------------------------------------|-----|
| 13.6.5 Indirection Table Register 5 (offset: 0x640)                             | 291 |
| 13.6.6 Indirection Table Register 6 (offset: 0x644)                             | 291 |
| 13.6.7 Indirection Table Register 8 (offset: 0x648)                             | 291 |
| 13.6.8 Indirection Table Register 8 (offset: 0x64C)                             | 292 |
| 13.6.9 Indirection Table Register 9 (offset: 0x650)                             | 292 |
| 13.6.10 Indirection Table Register 10 (offset: 0x654)                           | 292 |
| 13.6.11 Indirection Table Register 11 (offset: 0x658)                           | 292 |
| 13.6.12 Indirection Table Register 12 (offset: 0x65C)                           | 293 |
| 13.6.13 Indirection Table Register 12 (offset: 0x660)                           | 293 |
| 13.6.14 Indirection Table Register 13 (offset: 0x664)                           | 293 |
| 13.6.15 Indirection Table Register 14 (offset: 0x668)                           | 294 |
| 13.6.16 Indirection Table Register 15 (offset: 0x66C)                           | 294 |
| 13.6.17 Hash Key Register 0 (offset: 0x670)                                     | 294 |
| 13.6.18 Hash Key Registers 1–8 (offset: 0x674–0x693)                            | 294 |
| 13.6.19 Hash Key Register 9 (offset: 0x694)                                     | 295 |
| 13.6.20 Receive MAC Programmable IPv6 Extension Header Register (offset: 0x6A0) | 296 |
| 13.7 Statistics Registers                                                       | 297 |
| 13.7.1 Transmit MAC Static Counters                                             | 297 |
| 13.7.1.1 ifHCOutOctets (offset: 0x800)                                          | 297 |
| 13.7.1.2 etherStatsCollisions (offset: 0x808)                                   | 297 |
| 13.7.1.3 outXonSent (offset: 0x80C)                                             | 297 |
| 13.7.1.4 outXoffSent (offset: 0x810)                                            |     |
| 13.7.1.5 dot3StatsInternalMacTransmitErrors (offset: 0x818)                     |     |
| 13.7.1.6 dot3StatsSingleCollisionFrames (offset: 0x81C)                         |     |
| 13.7.1.7 dot3StatsMultipleCollisionFrames (offset: 0x820)                       |     |
| 13.7.1.8 dot3StatsDeferredTransmissions (offset: 0x824)                         | 297 |
| 13.7.1.9 dot3StatsExcessiveTransmissions (offset: 0x82C)                        |     |
| 13.7.1.10 dot3StatsLateCollisions (offset: 0x830)                               | 297 |
| 13.7.1.11 iHCOutUcastPkts (offset: 0x86C)                                       | 298 |
| 13.7.1.12 iHCOutMulticastPkts (offset: 0x870)                                   | 298 |
| 13.7.1.13 iHCOutBroadcastPkts (offset: 0x874)                                   | 298 |
| 13.7.1.14 ifCRSERRORS (offset: 0x878)                                           | 298 |
| 13.7.1.15 iOUTDISCARDS (offset: 0x87C)                                          | 298 |
| 13.7.2 H2B Statistics Registers                                                 | 298 |
| 13.7.2.1 HTX2B Statistics                                                       | 299 |
| 13.7.2.2 B2HRX Statistics                                                       | 299 |
| 13.7.3 Receive MAC Static Counters                                              | 299 |
| 13.7.3.1 ifHCInOctets (offset: 0x880)                                           | 299 |
| 13.7.3.2 ifHCINOctets bad (offset: 0x884)                                       | 299 |

| 13.7.3.3 etherStatsFragments (offset: 0x888)                                                    | 299 |
|-------------------------------------------------------------------------------------------------|-----|
| 13.7.3.4 ifHCInUcastPkts (offset: 0x88C)                                                        | 299 |
| 13.7.3.5 ifHCInMulticastPkts (offset: 0x890)                                                    | 299 |
| 13.7.3.6 ifHCInBroadcastPkts (offset: 0x894)                                                    | 300 |
| 13.7.3.7 dot3StatsFCSErrors (offset: 0x898)                                                     | 300 |
| 13.7.3.8 dot3StatsAlignmentErrors (offset: 0x89C)                                               | 300 |
| 13.7.3.9 xonPauseFrameReceived (offset: 0x8A0)                                                  | 300 |
| 13.7.3.10 xoffPauseFrameReceived (offset: 0x8A4)                                                | 300 |
| 13.7.3.11 macControlFramesRecevied (offset: 0x8A8)                                              | 300 |
| 13.7.3.12 xoffStateEntered (offset: 0x8AC)                                                      | 300 |
| 13.7.3.13 dot3StatsFramesTooLongs (offset: 0x8B0)                                               | 300 |
| 13.7.3.14 etherStatsJabbers (offset: 0x8B4)                                                     | 300 |
| 13.7.3.15 etherStatsUndersizePkts (offset: 0x8B8)                                               | 300 |
| 13.7.3.16 Ifnomorerxbd:0x224C                                                                   | 300 |
| 13.7.3.17 Ifindiscard:0x2250                                                                    |     |
| 13.7.3.18 Ifinerror:0x2254                                                                      | 301 |
| 13.7.4 APE_NETWORK_STATS_REGS (Offsets 0x900-0x9BC)                                             | 302 |
| 13.8 Send Data Initiator Registers                                                              | 303 |
| 13.8.1 Send Data Initiator Mode Register (offset: 0xC00)                                        | 303 |
| 13.8.2 Send Data Initiator Status Register (offset: 0xC04)                                      | 303 |
| 13.8.3 Send Data Initiator Statistics Control Register (offset: 0xC08)                          | 303 |
| 13.8.4 Send Data Initiator Statistics Mask Register (offset: 0xC0C)                             |     |
| 13.8.5 Send Data Initiator Statistics Increment Mask Register (offset: 0xC10)                   |     |
| 13.8.6 Local Statistics Register (offset: 0xC80-0xCDF)                                          | 304 |
| 13.9 TCP Segmentation Control Registers                                                         |     |
| 13.9.1 Lower Host Address Register for TCP Segmentation (offset: 0xCE0)                         | 304 |
| 13.9.2 Upper Host Address Register for TCP Segmentation (offset: 0xCE4)                         | 305 |
| 13.9.3 Length/Offset Register for TCP Segmentation (offset: 0xCE8)                              | 305 |
| 13.9.4 DMA Flag Register for TCP Segmentation (offset: 0xCEC)                                   | 305 |
| 13.9.5 VLAN Tag Register for TCP Segmentation (offset: 0xCF0)                                   | 306 |
| 13.9.6 Pre-DMA Command Exchange Register for TCP Segmentation (offset: 0xCF4)                   | 306 |
| 13.10 Send Data Completion Control Registers                                                    | 307 |
| 13.10.1 Send Data Completion Mode Register (offset: 0x1000)                                     |     |
| 13.10.2 Pre-DMA Command Exchange Register for TCP Segmentation (offset: 0x1008)                 |     |
| 13.11 Send BD Selector Control Registers                                                        | 308 |
| 13.11.1 Send BD Ring Selector Mode Register (offset: 0x1400)                                    |     |
| 13.11.2 Send BD Ring Selector Status Register (offset: 0x1404)                                  |     |
| 13.11.3 Send BD Ring Selector Hardware Diagnostics Register (offset: 0x1408)                    |     |
| 13.11.4 Send BD Ring Selector Local NIC Send BD Consumer Index Register (offset: 0x1440–0x147C) |     |
| 13.12 Send BD Initiator Control Registers                                                       | 310 |

| 13.12.1 Send BD Initiator Mode Register (offset: 0x1800)                                                           |     |
|--------------------------------------------------------------------------------------------------------------------|-----|
| 13.12.2 Send BD Initiator Status Register (offset: 0x1804)                                                         |     |
| 13.12.3 Send BD Diagnostic Initiator Local NIC BD N Producer Index Registers (offset: 0x1808–0x1844)               |     |
| 13.12.4 Send BD Fetch Threshold Register (offset: 0x1850)                                                          |     |
| 13.12.5 Send Mail Box Registers                                                                                    |     |
| 13.13 Send BD Completion Control Registers                                                                         |     |
| 13.13.1 Send BD Completion Mode Register (offset: 0x1C00)                                                          |     |
| 13.14 Receive List Placement Registers                                                                             |     |
| 13.14.1 Receive List Placement Mode Register (offset: 0x2000)                                                      |     |
| 13.14.2 Receive List Placement Status Register (offset: 0x2004)                                                    |     |
| 13.14.3 Receive Selector Non-Empty Bits Register (offset: 0x200C)                                                  |     |
| 13.14.4 Receive List Placement Configuration Register (offset: 0x2010)                                             | 315 |
| 13.14.5 Receive List Placement Statistics Control Register (offset: 0x2014)                                        |     |
| 13.14.6 Receive List Placement Statistics Enable Mask Register (offset: 0x2018)                                    | 316 |
| 13.14.7 Receive List Placement Statistics Increment Mask Register (offset: 0x201C)                                 |     |
| 13.14.8 Receive Selector List Head & Tail Pointers (offset: 0x2100)                                                | 317 |
| 13.14.9 Receive Selector List 1 Count Registers (Offset: 0x2108)                                                   |     |
| 13.15 Receive Data and Receive BD Initiator Control Registers                                                      | 319 |
| 13.15.1 Receive Data and Receive BD Initiator Mode Register (offset: 0x2400)                                       | 319 |
| 13.15.2 Receive Data and Receive BD Initiator Status Register (offset: 0x2404)                                     | 320 |
| 13.15.3 VRQ Status Register (offset: 0x240C)                                                                       |     |
| 13.15.4 VRQ Flush Control Register (Offset: 0x2410)                                                                | 321 |
| 13.15.5 VRQ Flush Timer Register (offset: 0x2414)                                                                  | 322 |
| 13.15.6 RDI B2HRX Hardware Debugging Register (offset: 0x2418)                                                     | 322 |
| 13.15.7 Jumbo Producer Ring Host Address High Register (offset: 0x2440)                                            | 322 |
| 13.15.8 Jumbo Producer Ring Host Address Low Register (offset: 0x2444)                                             | 322 |
| 13.15.9 Jumbo Producer Length/Flags Register (offset: 0x2448)                                                      | 322 |
| 13.15.10 Jumbo Producer Ring NIC Address Register (offset: 0x244C)                                                 | 323 |
| 13.15.11 Standard Receive BD Ring RCB Registers                                                                    | 323 |
| 13.15.11.1 Receive Producer Ring Host Address High Register (offset: 0x2450)                                       | 323 |
| 13.15.11.2 Receive Producer Ring Host Address Low Register (offset: 0x2454)                                        | 323 |
| 13.15.11.3 Receive Producer Length/Flags Register (offset: 0x2458)                                                 | 323 |
| 13.15.11.4 Receive Producer Ring NIC Address Register (offset: 0x245C)                                             | 324 |
| 13.15.12 Receive Diagnostic Data and Receive BD Ring Initiator Local NIC Jumbo Receive BD Consume (offset: 0x2470) |     |
| 13.15.13 Receive BD Ring Initiator Local NIC Standard Receive BD Consumer Index (offset: 0x2474)                   | 324 |
| 13.15.14 Receive Data and Receive BD Initiator Hardware Diagnostic Register (offset: 0x24C0)                       | 324 |
| 13.15.15 B2HRX Byte-count Statistics Count (offset: 0x24D0)                                                        |     |
| 13.15.16 B2HRX Unicast Statistics Count (offset: 0x24D4)                                                           | 324 |
| 13.15.17 B2HRX Multicast Statistics Count (offset: 0x24D8)                                                         | 325 |

|     | 13.15.18 B2HRX Broadcast Statistics Count (offset: 0x24DC)                                        | 325 |
|-----|---------------------------------------------------------------------------------------------------|-----|
|     | 13.15.19 B2HRX Drop Packet Count (offset: 0x24E0)                                                 | 325 |
|     | 13.15.20 B2HRX Drop Packet Byte Count (offset: 0x24E4)                                            | 325 |
|     | 13.15.21 B2HRX APE Byte-count Statistics Count (offset: 0x24E8)                                   | 325 |
|     | 13.15.22 B2HRX APE Unicast Statistics Count (offset: 0x24EC)                                      | 325 |
|     | 13.15.23 B2HRX APE Multicast Statistics Count (offset: 0x24F0)                                    | 325 |
|     | 13.15.24 B2HRX APE Broadcast Statistics Count (offset: 0x24F4)                                    | 326 |
|     | 13.15.25 B2HRX APE Drop Packet Count (offset: 0x24F8)                                             | 326 |
|     | 13.15.26 B2HRX APE Drop Packet Byte Count (offset: 0x24FC)                                        | 326 |
| 13. | 16 Receive Data Completion Control Registers                                                      | 327 |
|     | 13.16.1 Receive Data Completion Mode Register (offset: 0x2800)                                    | 327 |
| 13. | 17 Receive BD Initiator Control Registers                                                         | 328 |
|     | 13.17.1 Receive BD Initiator Mode Register (offset: 0x2C00)                                       | 328 |
|     | 13.17.2 Receive BD Initiator Status Register (offset: 0x2C04)                                     | 328 |
|     | 13.17.3 Receive BD Initiator Local NIC Jumbo Receive BD Producer Index (offset: 0x2C08)           | 328 |
|     | 13.17.4 Receive BD Initiator Local NIC Receive BD Producer Index Register (offset: 0x2C0C-0x2C13) | 328 |
|     | 13.17.5 Standard Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C18)           | 329 |
|     | 13.17.6 Jumbo Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C1C)              | 329 |
|     | 13.17.7 Standard Replenish LWM Register (offset 0x2D00)                                           | 329 |
|     | 13.17.8 Jumbo Replenish LWM Register (offset 0x2D04)                                              | 329 |
|     | 13.17.8.1 BD Fetch Limit Register (Offset 0x2D08)                                                 | 331 |
| 13. | 18 Receive BD Completion Control Registers                                                        | 331 |
|     | 13.18.1 Receive BD Completion Mode Register (offset: 0x3000)                                      | 331 |
|     | 13.18.2 Receive BD Completion Status Register (offset: 0x3004)                                    | 331 |
|     | 13.18.3 NIC Jumbo Receive BD Producer Index Register (offset: 0x3008)                             | 331 |
|     | 13.18.4 NIC Standard Receive BD Producer Index Register (offset: 0x300C)                          | 332 |
| 13. | 19 Central Power Management Unit (CPMU) Registers                                                 | 332 |
|     | 13.19.1 CPMU Control Register (offset: 0x3600)                                                    | 332 |
|     | 13.19.2 Link Speed 10 MB/No Link Power Mode Clock Policy Register (offset: 0x3604)                | 334 |
|     | 13.19.3 Link Speed 100 MB Power Mode Clock Policy Register (offset: 0x3608)                       | 335 |
|     | 13.19.4 Link Speed 1000 MB Power Mode Clock Policy Register (offset: 0x360C)                      | 336 |
|     | 13.19.5 Link Aware Power Mode Clock Policy Register (offset: 0x3610)                              | 337 |
|     | 13.19.6 D0u Clock Policy Register (offset: 0x3614)                                                | 338 |
|     | 13.19.7 Link Idle Power Mode Clock Policy Register (offset: 0x3618)                               | 338 |
|     | 13.19.8 APE CLK Policy Register (offset: 0x361C)                                                  | 338 |
|     | 13.19.9 APE Sleep State Clock Policy Register (offset: 0x3620)                                    | 341 |
|     | 13.19.10 Clock Speed Override Policy Register (offset: 0x3624)                                    | 342 |
|     | 13.19.11 Clock Override Enable Register (offset: 0x3628)                                          | 342 |
|     | 13.19.12 Status Register (offset: 0x362C)                                                         | 343 |
|     | 13.19.13 Clock Status Register (offset: 0x3630)                                                   | 345 |

| 13.19.14 C | Clock Status Register (offset: 0x3630)                                   | 345 |
|------------|--------------------------------------------------------------------------|-----|
| 13.19.15   | SPHY Control/Status Register (offset: 0x3638)                            | 346 |
| 13.19.16 F | RAM Control Register (offset: 0x363C)                                    | 347 |
| 13.19.17 C | Core Idle Detection De-Bounce Control Register (offset: 0x3648)          | 348 |
| 13.19.18 F | PCIE Idle Detection De-Bounce Control Register (offset: 0x364C)          | 349 |
| 13.19.19 E | nergy Detection De-Bounce Timer (offset: 0x3650)                         | 349 |
| 13.19.20 E | DLL Lock Timer Register (offset: 0x3654)                                 | 351 |
| 13.19.21 C | CHIP ID Register (offset: 0x3658)                                        | 351 |
| 13.19.22 N | Mutex Request Register (offset: 0x365C)                                  | 352 |
| 13.19.23 N | Mutex Grant Register (offset: 0x3660)                                    | 352 |
| 13.19.24   | SPHY Strap Register (offset: 0x3664)                                     | 352 |
| 13.19.25 F | Padring Control Register (offset: 0x3668)                                | 353 |
| 13.19.26 F | lash Clock Policy Register (offset: 0x366C)                              | 354 |
| 13.19.27 L | ink Idle Control Register (offset: 0x3670)                               | 355 |
| 13.19.28 L | ink Idle Status Register (offset: 0x3674)                                | 358 |
| 13.19.29 T | op Level Miscellaneous Control 1 Register (offset: 0x367C)               | 359 |
| 13.19.30 N | /liscellaneous Control Register (offset: 0x36AC)                         | 359 |
| 13.19.31 E | EE Mode Register (offset: 0x36B0)                                        | 361 |
| 13.19.32 E | EE Debounce Timer 1 Control Register (offset: 0x36B4)                    | 361 |
| 13.19.33 E | EE Debounce Timer 2 Control Register (offset: 0x36B8)                    | 361 |
| 13.19.34 E | EE Link Idle Control Register (offset: 0x36BC)                           | 362 |
| 13.19.35 E | EE Link Idle Status Register (offset: 0x36C0)                            | 362 |
| 13.19.36 E | EE Statistic Counter 1 Register (offset: 0x36C4)                         | 362 |
| 13.19.37 E | EE Statistic Counter 2 Register (offset: 0x36C8)                         | 363 |
|            | EE Statistics Counter 3 Register (offset: 0x36CC)                        |     |
| 13.19.39 E | EE Control Register (offset: 0x36D0)                                     | 363 |
|            | Current Measurement Control Register (offset: 0x36D4)                    |     |
| 13.19.41 C | Current Measurement Upper 32-bit Read Register (offset: 0x36D8)          | 364 |
| 13.19.42 C | Current Measurement Lower 32-bit Read Register (offset: 0x36DC)          | 364 |
| 13.19.43   | Global Mutex Request Register (offset: 0x36F0)                           | 364 |
| 13.19.44   | Global Mutex Grant Register (offset: 0x36F4)                             | 365 |
| 13.19.45 T | emperature Monitor Control Register (offset: 0x36FC)                     | 365 |
|            | alescing Control Registers                                               |     |
|            | ost Coalescing Mode Register (offset: 0x3C00)                            |     |
| 13.20.2 Ho | ost Coalescing Status Register (offset: 0x3C04)                          | 366 |
|            | eceive Coalescing Ticks Register (offset: 0x3C08)                        |     |
|            | end Coalescing Ticks Register (offset: 0x3C0C)                           |     |
|            | eceive Max Coalesced BD Count Register (offset: 0x3C10)                  |     |
|            | end Max Coalesced BD Count Register (offset: 0x3C14)                     |     |
| 13 20 7 Re | eceive May Coalesced BD Count During Interrupt Register (offset: 0x3C18) | 372 |

| 13.20.8 Send Max Coalesced BD Count During Interrupt Register (offset: 0x3C1C)    | 372 |
|-----------------------------------------------------------------------------------|-----|
| 13.20.8.1 HC Parameter Set Reset Register (Offset: 0x3C28)                        | 374 |
| 13.20.8.2 Status Block Host Address Register (offset: 0x3C38)                     | 374 |
| 13.20.9 Status Block Base Address Register (offset: 0x3C44)                       | 374 |
| 13.20.10 Flow Attention Register (offset: 0x3C48)                                 | 375 |
| 13.20.10.1 NIC Jumbo Receive BD Consumer Index Register (offset: 0x3C50-0x3C58)   | 375 |
| 13.20.10.2 NIC Diag Receive Return Ring BD 0 Index Register (offset: 0x3C80)      | 376 |
| 13.20.11 NIC Jumbo Receive BD Consumer Index Register (offset: 0x3C50)            | 376 |
| 13.20.12 NIC Standard Receive BD Consumer Index Register (offset: 0x3C54)         | 376 |
| 13.20.13 NIC Mini Receive BD Consumer Index (offset: 0x3c58)                      | 376 |
| 13.20.14 NIC Diagnostic Return Ring 0 Producer Index Register (offset: 0x3C80)    | 376 |
| 13.20.15 NIC Diagnostic Return Ring 1 Producer Index Register (offset: 0x3C84)    | 376 |
| 13.20.16 NIC Diagnostic Return Ring 2 Producer Index Register (offset: 0x3C88)    | 377 |
| 13.20.17 NIC Diagnostic Return Ring 3 Producer Index Register (offset: 0x3C8C)    | 377 |
| 13.20.18 NIC Diagnostic Send BD Consumer Index Register (offset: 0x3CC0)          | 377 |
| 13.21 Memory Arbiter Control Registers                                            | 378 |
| 13.21.1 Memory Arbiter Mode Register (offset: 0x4000)                             | 378 |
| 13.21.2 Memory Arbiter Status Register (offset: 0x4004)                           | 378 |
| 13.21.3 Memory Arbiter Trap Address Low Register (offset: 0x4008)                 | 380 |
| 13.21.4 Memory Arbiter Trap Address High Register (offset: 0x400C)                | 380 |
| 13.22 Buffer Manager Registers                                                    | 380 |
| 13.22.1 Buffer Manager Mode Register (offset: 0x4400)                             | 380 |
| 13.22.2 Buffer Manager Status Register (offset: 0x4404)                           | 381 |
| 13.22.3 MBUF Pool Base Address Register (offset: 0x4408)                          | 381 |
| 13.22.4 MBUF Pool Length Register (offset: 0x440C)                                | 382 |
| 13.22.5 Read DMA MBUF Low Watermark Register (offset: 0x4410)                     | 382 |
| 13.22.6 MAC RX MBUF Low Watermark Register (offset: 0x4414)                       | 382 |
| 13.22.7 Read DMA MBUF High Watermark Register (offset: 0x4418)                    | 382 |
| 13.22.8 RX RISC MBUF Cluster Allocation Request Register (offset: 0x441C)         | 382 |
| 13.22.9 RX RISC MBUF Allocation Response Register (offset: 0x4420)                | 382 |
| 13.22.10 BM Hardware Diagnostic 1 Register (offset: 0x444C)                       | 383 |
| 13.22.11 BM Hardware Diagnostic 2 Register (offset: 0x4450)                       | 383 |
| 13.22.12 BM Hardware Diagnostic 3 Register (offset: 0x4454)                       | 383 |
| 13.22.13 Receive Flow Threshold Register (offset: 0x4458)                         | 383 |
| 13.23 RDMA Registers                                                              | 385 |
| 13.23.1 LSO Read DMA Mode Register (offset: 0x4800)                               | 385 |
| 13.23.2 LSO Read DMA Status Register (offset: 0x4804)                             | 386 |
| 13.23.3 LSO Read DMA Programmable IPv6 Extension Header Register (offset: 0x4808) | 387 |
| 13.23.4 LSO Read DMA Reserved Control Register (offset: 0x4900)                   | 387 |
| 13.23.5 LSO Read DMA Flow Reserved Control Register (offset: 0x4904)              | 388 |

| 13.23.6 LSO/Non-LSO/BD Read DMA Corruption Enable Control Register (offset: 0x4910)    | 388 |
|----------------------------------------------------------------------------------------|-----|
| 13.23.7 BD Read DMA Mode Register (offset: 0x4A00)                                     | 391 |
| 13.23.8 BD READ DMA Status Register (offset: 0x4A04)                                   | 392 |
| 13.23.9 BD READ DMA Reserved Control Register (offset: 0x4A70)                         | 392 |
| 13.23.10 BD READ DMA Flow Reserved Control Register (offset: 0x4A74)                   | 393 |
| 13.23.11 BD READ DMA Corruption Enable Control Register (offset: 0x4A78)               | 393 |
| 13.23.12 Non_LSO Read DMA Mode Register (offset: 0x4B00)                               | 394 |
| 13.23.13 Non-LSO Read DMA Status Register (offset: 0x4B04)                             | 395 |
| 13.23.14 Non-LSO Read DMA Programmable IPv6 Extension Header Register (offset: 0x4B08) | 396 |
| 13.23.15 Host Address for the DMA Read Channel 0 (Offset: 0x4B28)                      | 396 |
| 13.23.16 Host Address for the DMA Read Channel 1 (offset: 0x4B30)                      | 396 |
| 13.23.17 Host Address for the DMA Read Channel 2 (offset: 0x4B38)                      | 396 |
| 13.23.18 Host Address for the DMA Read Channel 3 (offset: 0x4B40)                      | 396 |
| 13.23.19 Non-LSO Read DMA Reserved Control Register (offset: 0x4B74)                   | 397 |
| 13.23.20 Non-LSO Read DMA Flow Reserved Control Register (offset: 0x4B78)              | 397 |
| 13.23.21 Non-LSO Read DMA Corruption Enable Control Register (offset: 0x4B7C)          | 307 |
| 13.24 Write DMA Registers                                                              |     |
| 13.24.1 Write DMA Mode Register (offset: 0x4C00)                                       |     |
| 13.24.2 Write DMA Status Register (offset: 0x4C04)                                     |     |
| 13.25 RX-CPU Registers                                                                 |     |
| 13.25.1 RX RISC Mode Register (offset: 0x5000)                                         |     |
| 13.25.2 RX RISC Status Register (offset: 0x5004)                                       |     |
| 13.25.3 RX RISC Program Counter (offset: 0x501C)                                       |     |
| 13.25.4 RX RISC Hardware Breakpoint Register (offset: 0x5034)                          |     |
| 13.26 VRQ Statistics                                                                   |     |
| 13.27 VRQ Filter Set Registers                                                         |     |
| 13.28 VRQ Mapper Registers                                                             |     |
| 13.28.0.1 VRQ Enable Register (Offset 0x560)                                           |     |
| 13.28.0.2 RX Mail Box Registers for VRQ                                                |     |
| 13.29 Perfect Match Destination Address Registers                                      |     |
| 13.29.1 VRQ_PERFECT_MATCH[4–23]_HIGH_REG (Offsets: 0x5690, 0x5698, 0x56A0 0x5728)      |     |
| 13.29.2 VRQ_PERFECT_MATCH[4 – 23]_LOW_REG (Offsets: 0x5694, 0x569C, 0x56A4 0x572C)     |     |
| 13.30 Low Priority Mailboxes                                                           |     |
| 13.30.1 Interrupt Mailbox 0 Register (offset: 0x5800)                                  |     |
| 13.30.2 Other Interrupt Mailbox Register (offset: 0x5808–0x5818)                       |     |
| 13.30.3 General Mailbox Registers 1-8 (offset: 0x5820–0x5824)                          |     |
| 13.30.4 Receive BD Standard Producer Ring Index Register (offset: 0x5868)              |     |
| 13.30.5 Receive BD Jumbo Producer Ring Index Register (offset: 0x5870-5877)            |     |
| ,                                                                                      |     |

| 13.30.6 Receive BD Return Ring 0 Consumer Index Register (offset: 0x5880-0x5887) | 409 |
|----------------------------------------------------------------------------------|-----|
| 13.30.7 Receive BD Return Ring 1 Consumer Index Register (offset: 0x5888-0x588F) | 409 |
| 13.30.8 Receive BD Return Ring 2 Consumer Index Register (offset: 0x5890-0x5897) | 409 |
| 13.30.9 Receive BD Return Ring 3 Consumer Index Register (offset: 0x5898-0x589F) | 409 |
| 13.30.10 Send BD Ring Host Producer Index Register (offset: 0x5900)              | 409 |
| 13.30.11 Send BD Ring NIC Producer Index Register (offset: 0x5980)               | 410 |
| 13.31 Flow Through Queues                                                        | 411 |
| 13.31.1 FTQ Reset Register (offset: 0x5C00)                                      | 411 |
| 13.31.2 MAC TX FIFO Enqueue Register (offset: 0x5CB8)                            | 412 |
| 13.31.3 RXMBUF Cluster Free Enqueue Register (offset: 0x5CC8)                    | 412 |
| 13.31.4 RDIQ FTQ Write/Peak Register (offset: 0x5CFC)                            | 413 |
| 13.32 Message Signaled Interrupt Registers                                       | 413 |
| 13.32.1 MSI Mode Register (offset: 0x6000)                                       | 413 |
| 13.32.2 MSI Status Register (offset: 0x6004)                                     | 414 |
| 13.33 DMA Completion Registers                                                   | 415 |
| 13.33.1 DMA Completion Mode Register (offset: 0x6400)                            | 415 |
| 13.34 GRC Registers                                                              | 415 |
| 13.34.1 Mode Control Register (offset: 0x6800)                                   | 415 |
| 13.34.2 Miscellaneous Configuration Register (offset: 0x6804)                    | 417 |
| 13.34.3 Miscellaneous Local Control Register (offset: 0x6808)                    | 417 |
| 13.34.4 Timer Register (offset: 0x680C)                                          | 419 |
| 13.34.5 RX-CPU Event Register (offset: 0x6810)                                   | 419 |
| 13.34.6 RX-CPU Timer Reference Register (offset: 0x6814)                         | 420 |
| 13.34.7 RX-CPU Semaphore Register (offset: 0x6818)                               |     |
| 13.35 Serial EEPROM Address Register                                             |     |
| 13.35.1 Serial EEPROM Delay Register (offset: 0x6848)                            |     |
| 13.35.2 RX CPU Event Enable Register (offset: 0x684C)                            | 421 |
| 13.36 Miscellaneous Control Registers                                            |     |
| 13.36.1 Miscellaneous Control Register (offset: 0x6890)                          | 423 |
| 13.36.2 Fast Boot Program Counter Register (offset: 0x6894)                      | 423 |
| 13.36.3 Power Management Debug Register (offset: 0x68A4)                         | 424 |
| 13.36.4 5755ME Miscellaneous Control Register (offset: 0x68B0)                   | 425 |
| 13.36.5 Memory TM control1 (offset: 0x68E0)                                      | 425 |
| 13.36.6 Memory TM control 2 (offset: 0x68E4)                                     | 425 |
| 13.36.7 Mem TM control 3(offset: 0x68E8)                                         | 425 |
| 13.36.8 Expansion ROM Address Register (offset: 0x68EC)                          | 426 |
| 13.36.9 BCM5719/BCM5720 Registers                                                | 426 |

| 13.36.9.1 Mem TM Control 4 (offset: 0x68F8)                   | 426 |
|---------------------------------------------------------------|-----|
| 13.36.9.2 TPH Hint Register (Offset: 0x68FC)                  | 426 |
| 13.36.9.3 EAV Ref Count Capture LSB Reg (offset: 0x6900)      | 427 |
| 13.36.9.4 EAV Ref Count Capture MSB Reg (offset: 0x6904)      | 428 |
| 13.36.9.5 EAV Ref Clock Control Reg (offset: 0x6908)          | 428 |
| 13.36.9.6 EAV Ref Count Snapshot LSB[0] Reg (offset 0x6910)   | 429 |
| 13.36.9.7 EAV Ref Count Snapshot MSB[0] Reg (offset: 0x6914)  | 429 |
| 13.36.9.8 TX Time Watchdog LSB[0] Reg (offset: 0x6918)        | 429 |
| 13.36.9.9 TX Time Watchdog MSB[0] Reg (offset: 0x691C)        | 429 |
| 13.36.9.10 TX Time Watchdog LSB[1] Reg (offset: 0x6920)       | 430 |
| 13.36.9.11 TX Time Watchdog MSB[1] Reg (offset: 0x6924)       | 430 |
| 13.36.9.12 EAV Ref Corrector Reg [Offset 0x6928)              | 430 |
| 13.36.9.13 EAV Ref Count Snapshot LSB[1] Reg (Offset 0x6930)  | 430 |
| 13.36.9.14 EAV Ref Count Snapshot MSB[1] Reg [Offset 0x6934]  | 431 |
| 13.37 Non-Volatile Memory (NVM) Interface Registers           | 432 |
| 13.37.1 NVM Command Register (0x7000)                         | 432 |
| 13.37.2 NVM Write Register (offset: 0x7008)                   | 433 |
| 13.37.3 NVM Address Register (offset: 0x700C)                 |     |
| 13.37.4 NVM Read Register (offset: 0x7010)                    | 433 |
| 13.37.5 NVM Config 1 Register (offset: 0x7014)                |     |
| 13.37.6 NVM Config 2 Register (offset: 0x7018)                |     |
| 13.37.7 NVM Config 3 Register (offset: 0x701C)                |     |
| 13.37.8 Software Arbitration Register (offset: 0x7020)        |     |
| 13.37.9 NVM Access Register (offset: 0x7024)                  |     |
| 13.37.10 NVM Write1 Register (offset: 0x7028)                 |     |
| 13.37.11 Arbitration Watchdog Timer Register (offset: 0x702C) |     |
| 13.37.12 NVM Auto-Sense Status Register (offset: 0x7038)      |     |
| Chapter 14: Transceiver Registers                             | 439 |
| 14.1 Purpose                                                  | 439 |
| 14.2 BCM571X/BCM5720 Family MII Bus PHY Addressing            | 439 |
| 14.3 Register Field Access Type                               | 439 |
| 14.4 Transceiver Register Map                                 | 440 |
| 14.5 00h-0Fh 10/100/1000T Register Map Detailed Description   | 443 |
| 14.5.1 00h: MII_Control_Register                              | 443 |
| 14.5.2 01h: MII_Status_Register                               |     |
| 14.5.3 02h: PHY_Identifier_MSB_Register                       | 444 |
| 14.5.4 03h: PHY_Identifier_LSB_Register                       |     |
| 14.5.5 04h: Auto_Negot_Advertisement_Register                 |     |
| 14.5.6 05h: Auto_Negot_Link_Partner_Ability_Base_Pg_Register  |     |
| 14.5.7 06h: Auto Negot Expansion Register                     | 446 |

| 14.5.8 07h: Auto_Negot_Next_Page_Transmit_Register (Software Controlled Next Pages) | 446 |
|-------------------------------------------------------------------------------------|-----|
| 14.5.9 08h: Auto_Negot_Link_Partner_Ability_Nxt_Pg_Register                         | 447 |
| 14.5.10 09h: 1000Base_T_Control_Register                                            | 447 |
| 14.5.11 0Ah: 1000Base_T_Status_Register                                             | 448 |
| 14.5.12 0Eh: BroadReach LRE Access Register                                         | 448 |
| 14.5.13 0Fh: IEEE_Extended_Status_Register                                          | 448 |
| 14.6 10h-1Fh Register Map Detailed Description                                      | 449 |
| 14.6.1 10h: PHY_Extended_Control_Register                                           | 449 |
| 14.6.2 11h: PHY_Extended_Status_Register (copper side only)                         | 450 |
| 14.6.3 12h: Receive_Error_Counter_Register                                          | 451 |
| 14.6.4 13h: False_Carrier_Sense_Counter_Register                                    | 451 |
| 14.6.5 14h: Local_Remote_Receiver_NOT_OK_Counters_Register                          | 452 |
| 14.6.6 18h: Auxiliary Control Register (Shadow Register Selector = "000")           | 452 |
| 14.6.7 18h: 10BASE-T Register (Shadow Register Selector = "001")                    | 454 |
| 14.6.8 18h: Power/MII Control Register (Shadow Register Selector = "010")           | 455 |
| 14.6.9 18h: IP Phone Register (Shadow Register Selector = "011")                    | 455 |
| 14.6.10 18h: Misc Test Register 1 (Shadow Register Selector = "100")                | 456 |
| 14.6.11 18h: Misc Test Register 2 (Shadow Register Selector = "101")                | 457 |
| 14.6.12 18h: Manual IP Phone Seed Register (Shadow Register Selector = "110")       | 458 |
| 14.6.13 18h: Miscellaneous Control Register (Shadow Register Selector = "111")      | 458 |
| 14.6.14 19h: Auxiliary Status Summary (Copper Side Only)                            | 459 |
| 14.6.15 1Ah: Interrupt Status Register (Copper Side Only)                           | 460 |
| 14.6.16 1Bh: Interrupt Mask Register                                                | 461 |
| 14.6.17 1Ch: Cabletron LED Register (Shadow Register Selector = "00h")              | 462 |
| 14.6.18 1Ch: DLL Selection Register (Shadow Register Selector = "01h")              | 463 |
| 14.6.19 1Ch: Spare Control 1 Register (Shadow Register Selector = "02h")            | 463 |
| 14.6.20 1Ch: Clock Alignment Control Register (Shadow Register Selector = "03h")    | 464 |
| 14.6.21 1Ch: Spare Control 2 Register (Shadow Register Selector = "04h")            | 465 |
| 14.6.22 1Ch: Spare Control 3 Register (Shadow Register Selector = "05h")            | 466 |
| 14.6.23 1Ch: TDR Control 1 Register (Shadow Register Selector = "06h"               | 466 |
| 14.6.24 1Ch: TDR Control 2 Register (Shadow Register Selector = "07h")              | 467 |
| 14.6.25 1Ch: LED Status Register (Shadow Register Selector = "08h")                 | 467 |
| 14.6.26 1Ch: Led Control Register (Shadow Register Selector = "09h")                | 468 |
| 14.6.27 1Ch: SGMII Secondary Register (Shadow Register Selector = "15h")            | 469 |
| 14.6.28 1Ch: Misc 1000-X Control 2 Register (Shadow Register Selector = "16h")      | 470 |
| 14.6.29 1Ch: Misc 1000-X Control Register (Shadow Register Selector = "17h")        | 471 |
| 14.6.30 1Ch: Auto-Detect SGMII/GBIC Register (Shadow Register Selector = "18h")     | 472 |
| 14.6.31 1Ch: Test 1000-X Register (Shadow Register Selector = "19h")                | 473 |
| 14.6.32 1Ch: Autoneg 1000-X Debug Register (Shadow Register Selector = "1ah")       | 474 |
| 14.6.33 1Ch: Auxiliary 1000-X Control Register (Shadow Register Selector = "1bh")   | 474 |

| 14.6.34 1Ch: Auxiliary 1000-X Status Register (Shadow Register Selector = "1ch") | 476 |
|----------------------------------------------------------------------------------|-----|
| 14.6.35 1Ch: Misc 1000-X Status Register (Shadow Register Selector = "1dh")      | 477 |
| 14.6.36 1Ch: Auto-Detect Medium Register (Shadow Register Selector = "1eh")      | 477 |
| 14.6.37 1Ch: Mode Control Register (Shadow Register Selector = "1fh")            | 478 |
| 14.6.38 1Dh: Primary/Secondary Seed Register (Bit 15 = 0)                        | 479 |
| 14.6.39 1Dh: HCD Status Register (Bit 15 = 1)                                    | 480 |
| 14.6.40 1Eh: Test1_Register                                                      | 481 |
| 14.6.41 1Fh: Test2_Register                                                      | 482 |
| 14.7 SerDes PHY Register Definitions                                             | 483 |
| 14.7.1 Register Map                                                              | 483 |
| 14.7.2 MII Control                                                               | 485 |
| 14.7.3 MII Status                                                                | 485 |
| 14.7.4 AUTONEGADV                                                                | 487 |
| 14.7.5 AUTONEG Link Partner Ability                                              | 487 |
| 14.7.6 AUTONEGEXPANSION                                                          | 488 |
| 14.7.7 EXTENDEDSTATUS                                                            | 488 |
| 14.7.8 1000XCONTROL1                                                             | 489 |
| 14.7.9 1000XCONTROL2                                                             | 490 |
| 14.7.10 1000XCONTROL3                                                            | 491 |
| 14.7.11 1000XSTATUS1                                                             | 493 |
| 14.7.12 1000XSTATUS2                                                             | 494 |
| 14.7.13 1000XSTATUS3                                                             | 494 |
| 14.7.14 FXCONTROL1                                                               | 495 |
| 14.7.15 FXCONTROL2                                                               | 496 |
| 14.7.16 FXCONTROL3                                                               | 496 |
| 14.7.17 FXSTATUS1                                                                | 497 |
| 14.7.18 ANALOG_TX1                                                               | 497 |
| 14.7.19 ANALOG_TX2                                                               | 498 |
| 14.7.20 ANALOG_TXAMP                                                             | 498 |
| 14.7.21 ANALOG_RX1                                                               | 500 |
| 14.7.22 ANALOG_RX2                                                               | 501 |
| 14.7.23 ANALOG_PLL                                                               | 501 |
| 14.7.24 GE_PRBS_CONTROL                                                          | 502 |
| 14.7.25 GE_PRBS_STATUS                                                           | 502 |
| 14.8 Clause 45 Registers                                                         | 502 |
| 14.8.1 Clause 45 Register Dev 3 Reg14h (20d): EEE Capability Register            | 503 |
| 14.8.2 Clause 45 Register Dev 7 Reg3ch (60d): EEE Advertisement Register         | 504 |
| 14.8.2.1 1000BASE-T EEE                                                          | 504 |
| 14.8.2.2 100BASE-TX EEE                                                          | 504 |
| 14.8.3 Clause 45 Register Dev 7 Reg803Eh (32830d): EEE Resolution Status         | 504 |

| 14.8.3.1 EEE 1000BASE-T Resolution                                      | 504 |
|-------------------------------------------------------------------------|-----|
| 14.8.3.2 EEE 100BASE-TX Resolution                                      | 504 |
| 14.8.4 Clause 45 Register Dev 7 Reg803dh (32817d): EEE Control Register | 505 |
| 14.8.4.1 LPI Feature Enable                                             | 505 |
| Appendix A: Flow Control                                                | 506 |
| 14.9 Notes                                                              | 506 |
| 14.10 Flow Control Scenario                                             | 506 |
| 14.10.1 File Transfer                                                   | 506 |
| 14.10.2 Speed Mismatch                                                  | 507 |
| 14.10.3 Switch Buffers Run Low                                          | 508 |
| 14.10.4 Switch Backpressure                                             | 509 |
| 14.10.5 Switch Flow Control                                             | 509 |
| 14.10.6 File Transfer Complete                                          | 510 |
| 14.11 Pause Control Frame                                               | 510 |
| Appendix B: Terminology                                                 | 511 |
| Appendix C: Device Register and Memory Map                              | 512 |
| 14.12 BCM5717/BCM5718 Memory Map                                        | 512 |
| 14.13 BCM5717/BCM5718 Register Map                                      | 514 |
| 14.14 BCM5719 Memory Map                                                | 515 |
| 14.15 BCM5719 Register Map                                              | 518 |
| 14.16 BCM5720 Memory Map                                                | 520 |
| 14.17 BCM5720 Register Map                                              | 522 |

# **Chapter 1: Introduction**

The NetXtreme and NetLink family of Media Access Controller (MAC) devices are highly-integrated, single-chip Gigabit Ethernet LAN controller solutions for high-performance network applications. These devices integrate the following major functions to provide a single-chip solution for Gigabit LAN-on-motherboard (LOM) and network interface card (NIC) applications.

- Triple-speed IEEE 802.3-compliant MAC functionality
- Triple-speed IEEE 802.3-compliant Ethernet PHY transceiver
- PCI Express (PCIe) bus interface
- On-chip packet buffer memory
- On-chip RISC processor for custom frame processing

#### 1.1 About this Document

## 1.1.1 Purpose and Audience

This document covers the Broadcom<sup>®</sup> BCM571X/BCM5720 family of NetXtreme<sup>®</sup>/NetLink<sup>®</sup> Ethernet controllers. This family of controllers includes the following devices:

- BCM5717
- BCM5718
- BCM5719
- BCM5720

The document focuses on the registers, control blocks, and software interfaces necessary for host software programming. It is intended to complement the data sheet for the appropriate member of the NetXtreme/NetLink Ethernet controller family. The errata documentation (see "Revision Levels" on page 30) complements this document.

#### 1.1.2 Document Conventions

The following conventions may be used in this document:

| Convention | Description                                                                                                          |  |  |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bold       | User input and actions: for example, type exit, click OK, press Alt+C                                                |  |  |  |  |
| Monospace  | <pre>Code: #include <iostream> HTML:  Command line commands and parameters: wl [-l] <command/></iostream></pre>      |  |  |  |  |
| <>         | Placeholders for required elements: enter your <username> or w1 <command/></username>                                |  |  |  |  |
| []         | Indicates <i>optional</i> command-line parameters: wl [-l] Indicates bit and byte ranges (inclusive): [0:3] or [7:0] |  |  |  |  |

**Table 1: Register Access Methods** 

| Convention | Description                           |
|------------|---------------------------------------|
| A/C        | Clear contents after read             |
| RO         | Read-Only access, Write has no effect |

Table 1: Register Access Methods (Cont.)

| Convention (Cont.) | Description                                                             |
|--------------------|-------------------------------------------------------------------------|
| RW                 | Full Read and Write access                                              |
| WO                 | Write-Only access, Read returns garbage                                 |
| W1C                | Write a value 1 to clear the bit.                                       |
| W1S                | Write a value 1 to set the bit                                          |
| WZO                | Write 0 only to avoid side effects, Read returns garbage                |
| RW1C               | Readable / Write a 1'b1 value to clear the bit.                         |
| RW1S               | Readable / Write a 1'b1 to set the bit                                  |
| RW/S               | Readable / Writeable but is not affected by any CPU reset or AHB reset. |

#### 1.1.3 References

The references in this section may be used in conjunction with this document.

**NOTE:** Broadcom provides customer access to technical documentation and software through its Customer Support Portal (CSP) and Downloads & Support site (see Introduction).

For Broadcom documents, replace the "xx" in the document number with the largest number available in the repository to ensure that you have the most current version of the document.

| Docu | iment (or Item) Name                                                                                                                                                                                              | Number              | Source       |  |  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------|--|--|--|
| Broa | Broadcom Items                                                                                                                                                                                                    |                     |              |  |  |  |
| [1]  | BCM57XX NetXtreme <sup>®</sup> Programmer's Guide:<br>Programming details for the BCM5700, BCM5701,<br>BCM5702, BCM5703, BCM5704, BCM5705,<br>BCM5721, BCM5751, BCM5752, BCM5714,<br>BCM5715, and BCM57XX devices | 57XX-PG1XX-R        | Broadcom CSP |  |  |  |
| [2]  | x2 PCI Express Dual-Port Gigabit Ethernet Controller                                                                                                                                                              | 5717-DS0X-R         | Broadcom CSP |  |  |  |
| [3]  | x2 PCI Express Dual-Port Gigabit Ethernet Controller                                                                                                                                                              | 5718-DS0X-R         | Broadcom CSP |  |  |  |
| [4]  | x4 PCI Express <sup>®</sup> Quad-Port Dual-Media Gigabit<br>Ethernet Controller                                                                                                                                   | 5719-DS0X-R         | Broadcom CSP |  |  |  |
| [5]  | x2 PCI Express <sup>®</sup> Dual-Port Dual-Media Gigabit<br>Ethernet Controller                                                                                                                                   | 5720-DS0X-R         | Broadcom CSP |  |  |  |
| [6]  | x2 PCI Express <sup>®</sup> Dual-Port Gigabit Ethernet<br>Controller Errata (A0 and B0)                                                                                                                           | 5717-ES10X-R        | Broadcom CSP |  |  |  |
| [7]  | BCM5718 Revision A0, B0                                                                                                                                                                                           | 5718-ES10X-R        | Broadcom CSP |  |  |  |
| [8]  | BCM5719 A0 Errata                                                                                                                                                                                                 | 5719-ES10X-R        | Broadcom CSP |  |  |  |
| [9]  | BCM5720 Errata                                                                                                                                                                                                    | 5720-ES10X-R        | Broadcom CSP |  |  |  |
| [10] | Self Boot Option                                                                                                                                                                                                  | 5754X_5787X-AN10X-R | Broadcom CSP |  |  |  |
| [11] | NetXtreme/NetLink Software Self-Boot NVRAM                                                                                                                                                                        | NetXtreme-AN40X-R   | Broadcom CSP |  |  |  |
| [12] | NetXtreme <sup>®</sup> /NetLink <sup>®</sup> NVRAM Access                                                                                                                                                         | NetXtreme-AN50X-R   | Broadcom CSP |  |  |  |
| [13] | NetXtreme/NetLink NVRAM Configuration Options                                                                                                                                                                     | NetXtreme-AN60X-R   | Broadcom CSP |  |  |  |
| [14] | NetXtreme/NetLink Shared Memory Communication                                                                                                                                                                     | NetXtreme-AN80X-R   | Broadcom CSP |  |  |  |
| Othe | r Items                                                                                                                                                                                                           | ,                   | <u>'</u>     |  |  |  |

| Document (or Item) Name (Cont.)                                  | Number | Source                     |
|------------------------------------------------------------------|--------|----------------------------|
| [15] NC-SI (Network Controller–Sideband Interface) Specification | _      | (http://www.dmtf.org/home) |

# 1.2 Product Features

Table 2: BCM571X/BCM5720 Family Product Features

| Feature                                                                                           | BCM5717<br>Dual-Port Copper | BCM5718<br>Dual-Port<br>Copper/SerDes | BCM5719<br>Quad-Port Copper/<br>SerDes | BCM5720<br>Dual-Port Copper/<br>SerDes |
|---------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------------|----------------------------------------|----------------------------------------|
| Data Management                                                                                   |                             |                                       |                                        |                                        |
| VLAN tag support (IEEE 802.1Q)                                                                    | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Layer 2 priority encoding (IEEE 802.1p)                                                           | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Link aggregation (IEEE 802.3ad)                                                                   | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Full-duplex flow control (IEEE 802.3x)                                                            | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Programmable rules checker for advanced packet filtering and classification                       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Frame/packet buffer memory                                                                        | 32 KB RX,<br>29 KB TX       | 32 KB RX,<br>29 KB TX                 | 40 KB RX,<br>29 KB TX                  | 40 KB RX,<br>29 KB TX                  |
| TCP checksum offload (hardware-based) on Tx/Rx over IPv4/IPv6                                     | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| UDP checksum offload (hardware-based) on Tx/Rx over IPv4/IPv6                                     | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| IP checksum offload on Tx/Rx over IPv4/IPv6                                                       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Hardware TCP segmentation offload over IPv4/IPv6                                                  | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Jumbo frame support                                                                               | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Receive-side scaling (RSS)                                                                        | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| UDP Receive-side scaling (UDP RSS)                                                                | No                          | No                                    | Yes                                    | Yes                                    |
| Transmit-side scaling (TSS)                                                                       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Multiple receive descriptor queues                                                                | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| IOV support (I/O Virtualization) for:  ■ VMWare NetQueue  ■ Microsoft Virtual Machine Queue (VMQ) | No                          | Yes                                   | Yes                                    | Yes                                    |
| MSI                                                                                               | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| MSI-X                                                                                             | Yes (5 Vectors)             | Yes (17 Vectors)                      | Yes (17 Vectors)                       | Yes (17 Vectors)                       |
| Function Level Reset                                                                              | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Scatter/gather bus mastering architecture                                                         | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Statistics for SNMP MIB II, Ethernet like MIB, Ethernet MIB (IEEE 802.3z, Clause 30)              | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| ASF v2.0 support                                                                                  | No                          | No                                    | No                                     | No                                     |
| iSCSI Boot                                                                                        | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Teaming                                                                                           | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Host Bus Interfaces                                                                               |                             |                                       |                                        |                                        |
| PCIe 2.0 x2                                                                                       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| PCIe 2.1 x4                                                                                       | No                          | No                                    | Yes                                    | No                                     |

Table 2: BCM571X/BCM5720 Family Product Features (Cont.)

| Feature                                                        | BCM5717<br>Dual-Port Copper | BCM5718<br>Dual-Port<br>Copper/SerDes | BCM5719<br>Quad-Port Copper/<br>SerDes | BCM5720<br>Dual-Port Copper/<br>SerDes |
|----------------------------------------------------------------|-----------------------------|---------------------------------------|----------------------------------------|----------------------------------------|
| LAN Interfaces                                                 |                             |                                       |                                        |                                        |
| Integrated 10/100/1000 transceiver                             | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Internal MII/GMII Interface                                    | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Other Bus Interfaces                                           |                             |                                       |                                        |                                        |
| NC-SI (version 1.0.0a)                                         | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Host 2 BMC                                                     | No                          | No                                    | No                                     | Yes                                    |
| SMBus 2.0 interface                                            | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Interface to Flash memory                                      | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Interface to Serial EEPROM                                     | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Flash Autoconfig Support                                       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Self-Test                                                      |                             |                                       |                                        |                                        |
| Test modes (BIST, SCAN, etc)                                   | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| JTAG support                                                   | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Technology                                                     | •                           | ,                                     |                                        | ,                                      |
| High-performance, low-overhead software/<br>hardware interface | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| High-speed on-chip RISC processors (one per port)              | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| High-speed on-chip Application Processor<br>Engine (APE)       | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Wake-on-LAN (WOL)                                              | Yes                         | Yes                                   | Yes                                    | Yes                                    |
| Energy Efficient Ethernet (EEE)                                | No                          | Yes                                   | Yes                                    | Yes                                    |
| Ethernet Audio Video (EAV)                                     | No                          | No                                    | No                                     | No                                     |
| Secure Digital (SD) Card Reader                                | No                          | No                                    | No                                     | No                                     |
| IEEE 1588 / IEEE 802.1AS Timestamp Support                     | No                          | No                                    | Yes                                    | Yes                                    |
| On-chip temperature monitor                                    | No                          | No                                    | Yes                                    | Yes                                    |
| Integrated Trusted Platform Module (TPM) Security Engine       | No                          | No                                    | No                                     | No                                     |
| Process voltage                                                | 1.2V                        | 1.2V                                  | 1.2V                                   | 1.2V                                   |
| CMOS linewidth                                                 | 65 nm                       | 65 nm                                 | 65 nm                                  | 65 nm                                  |

## 1.3 Revision Levels

See Table 3 for the revision levels of the Ethernet controllers covered by this document. Host software can use the PCI Revision ID and Chip ID information in the PCI configuration registers to determine the revision level of the Ethernet controller on the board, and then load the appropriate workaround described in the errata sheets.

The Broadcom PCI vendor ID is 0x14E4. Table 3 shows the default values of PCI device IDs. These values may be modified by firmware in accordance with the manufacturing information supplied in NVRAM (see "NVRAM Configuration" on page 47 for more details).

**Table 3: Family Revision Levels** 

| Family Member | Device ID <sup>a</sup> | Revision<br>Level | PCI Revision ID <sup>b</sup> | Chip ID <sup>c</sup> | Product ASIC ID <sup>d</sup> | Errata Sheet <sup>e</sup> |
|---------------|------------------------|-------------------|------------------------------|----------------------|------------------------------|---------------------------|
| BCM5717       | 0x1655                 | A0                | 0x00                         | 0xF000xxxx           | 0X5717000                    | 5717-ES1xx-R              |
| BCM5717       | 0x1655                 | В0                | 0x10                         | 0xF100xxxx           | 0X5717100                    | 5717-ES1xx-R              |
| BCM5718       | 0x1656                 | A0                | 0x00                         | 0xF000xxxx           | 0X5717000                    | 5718-ES1xx-R              |
| BCM5718       | 0x1656                 | В0                | 0x10                         | 0xF100xxxx           | 0X5717100                    | 5718-ES1xx-R              |
| BCM5719       | 0x1657                 | A0                | 0x00                         | 0xF000xxxx           | 0X5719000                    | 5719-ES1xx-R              |
| BCM5719       | 0x1657                 | A1                | 0x01                         | 0XF100XXXX           | 0X5719100                    | 5719-ES1XX-R              |
| BCM5720       | 0X165F                 | A0                | 0x00                         | 0xF000xxxx           | 0X5720000                    | 5720-ES1xx-R              |

- a. See Device ID and Vendor ID Register (Offset: 0x00)—Function 0", per PCI specification.
- b. See "PCI Classcode and Revision ID Register (offset: 0x8)—Function 0" as per the PCI specification. The hardware default value of this register is 0x00. The boot code firmware programs this register with the value as given in the table.
- c. See "Miscellaneous Host Control Register (offset: 0x68)" on page 245. The lower 16 bits are don't cares for determining chip id.
- d. See "Product ASIC ID (offset: 0xF4)" on page 263 or determining ASIC ID.
- e. See the appropriate errata documentation for the errata information and resolutions.

**NOTE:** If you are using silicon revision A0 of the BCM571X/BCM5720, you must load a "patch" image (ap5718.012) into the boot code NVRAM in addition to the usual legacy boot code image common to all NetXtreme/NetLink controllers. This extra patch image, which masquerades as "Management Firmware", works around an issue with A0 silicon in which the device may fail to load reliably and execute the primary boot code image. This issue is fixed in BCM5718 B0 and is not an issue in BCM5719 or BCM5720.

## 1.4 Programming the Ethernet Controllers

See Table 3 on page 31 for the revision levels of the Ethernet controllers. Host software can use the PCI Revision ID and Chip ID information in the PCI configuration registers to determine the revision level of the Ethernet controller on the board, and then load the appropriate workarounds described in the errata sheets.

The choice of host access mode determines the mailboxes:

- Host standard mode uses the high-priority mailboxes (see "Mailbox Registers" on page 70).
- Indirect mode uses the low-priority mailboxes (see "Mailbox Registers" on page 70).

The reference documents for Ethernet controller software development include this manual and the errata documentation (see "Revision Levels" on page 30) that provide the necessary information for writing a host-based device driver. The Broadcom Linux<sup>®</sup> driver (a.k.a. "tg3") is also a very good reference source for writing your own driver.

The programming model for the NetXtreme/NetLink Ethernet controllers does not depend on OS or processor instruction sets. Programmers using Motorola<sup>®</sup> 68000, Intel<sup>®</sup> x86, or DEC Alpha host instruction sets can leverage this document to aid in device driver development. Concepts provided in this document are also applicable to device drivers native to any operating system (i.e., DOS, UNIX<sup>®</sup>, Microsoft<sup>®</sup>, or Novell<sup>®</sup>).

# **Chapter 2: Hardware Architecture**

# 2.1 Theory of Operation

Figure 1 shows the major functional blocks and interfaces of the Ethernet controllers covered in this document. Only a single port is illustrated in Figure 1. The dual-port controllers in this family of controllers essentially replicate a second instance of the major areas of functionality shown in the diagram below. The dual-port controllers have only a single PCIe and NVRAM interfaces.

There are two packet flows: MAC-transmit and receive. The device's DMA engine bus-masters packets from host memory to device local storage, and vice-versa. The host bus interface is compliant with PCIe standards. The RX MAC moves packets from the integrated PHY into device internal memory. All incoming packets are checked against a set of QOS rules and then categorized. When a packet is transmitted, the TX MAC moves data from device internal memory to the PHY. Both flows operate independently of each other in full-duplex mode. An on-chip RISC processor is provided for running value-added firmware that can be used for custom frame processing. The on-chip RISC operates independently of all the architectural blocks; essentially, RISC is available for the auxiliary processing of data streams.

Figure 1: Individual Port Functional Block Diagram



#### 2.2 Overview of Features

The BCM571X/BCM5720 family of controllers represents the third generation of Broadcom NetXtreme multi-port Gigabit Ethernet controllers. This family is the successor to the BCM5714/BCM5715 family. The BCM5717, BCM5718, and BCM5720 feature two independent 1 Gb Ethernet ports on the network side. A host computer can communicate with the controller over a single PCIe link. However, the two network controller ports appear as two independent PCIe functions to the host operating system (four functions in the quad-port BCM5719). In essence, the chip consists of a single PCIe interface controller that offers multiple function-level interfaces, and each function-level interface is further attached to an independent DMA engine which in turn feeds an independent Ethernet Media Access Controller (EMAC).

Attached to the other end of each EMAC is the respective 802.3 Ethernet physical media interface. The controller essentially consists of multiple DMA+EMAC logic instances, multiple Ethernet physical interfaces, and a single instance of a PCIe core that is shared by the DMA blocks.

The BCM571X/BCM5720 is available as four SKUs, BCM5717, BCM5718, BCM5719, and BCM5720. These are also referred to as the Dual-Copper SKU and the Dual-Media SKU. For the BCM5718, BCM5719, and BCM5720 parts, any of the network ports may be independently configured as copper-based (1000BASE-T) or as SerDes-based (1000BASE-X/SGMII) media interfaces. The choice of media interface on each port is configurable via a power-on strapping option.

The BCM5717 part is permanently bonded as a copper (1000BASE-T) only device.

For the Dual-Media SKU (BCM5718 and BCM5719), whenever a port is configured as a SerDes medium, there are two protocol choices: 1000BASE-X or SGMII. This choice can be made by an Auto-Detect feature or by explicit software programming.

The software driver for this device is capable of loading or unloading each network port independently. The DMA+EMAC associated with each port is also able to acquire different ACPI power states irrespective of the other; however, the power state of the PCIe link may not necessarily follow that of either one or both ports. This is a significant behavioral difference between a dual-port controller compared to single-port. The BCM571X/BCM5720 family hardware and firmware is cognizant of this effect and adds the necessary intelligence to handle it. This functionality remains transparent to device driver software.

On top of the basic dual-port network controller functionality, the BCM5718, BCM5719, and BCM5720 also support an advanced feature known as IO Virtualization (IOV).

Network Controller Sideband Interface (NC-SI) pass-through functionality is the Server Management solution offered by the BCM571X/BCM5720 family of controllers. NC-SI pass-through is a part of the Server Management infrastructure. Such technology offers server platform management via a BMC (baseboard management controller) chip. A server platform and, in turn, a BMC is typically administered remotely over the network, but BMCs are not equipped with direct network connectivity. Here, a network controller chip comes into the picture—a pass-through-capable NIC chip offers a sideband packet interface to the BMC. Over this interface, the BMC can send and receive Ethernet packets to and from the network. In essence, the network adapter functionality of the network controller chip is shared by the host computer system and the BMC chip. NC-SI pass-through protocol is an industry-standard (DMTF) for a side band interface between the BMC and network controller. The physical and L2 layers of NC-SI are upwardly compliant with the respective sections of the IEEE 802.3 specification, thus allowing the exchange of Ethernet packets between the network port and BMC without any protocol transformation whatsoever.

In an environment of several network servers, typically no server is dedicated to running only the management console. Host to BMC pass-through functionality identifies host to local BMC-bound packets and routes them internally to the chip. Similarly, BMC to local host-bound packets are also identified and routed internally to the NIC chip. Host to BMC pass-through functionality is offered by the BCM5720 controller.

In addition to IEEE 802.3 standard size Ethernet frames, the BCM571X/BCM5720 family also supports jumbo frames of sizes up to 9622 bytes.

The BCM571X/BCM5720 family of controllers replaces the traditional PNP-based linear regulator with a more efficient switching regulator. This regulator steps down system-supplied 3.3V rail to 1.2V, which it supplies to the chip's core.

Figure 2: High-Level System Functional Block Diagram



**Note:** BCM5719 has the same general architecture, but four ports (ports 0, 1, 2, 3) and a quad-function PCIe interface.

## 2.3 Receive Data Path

## 2.3.1 RX Engine

The receive engine (see Figure 3) activates whenever a packet arrives from the PHY.

Figure 3: Receive Data Path



The receive engine performs the following four functions:

- Moves the data from the PHY to an internal FIFO
- Moves the data from the FIFO to NIC internal memory
- Classifies the frame and checks it for rules matches
- Performs the offloaded checksum calculations

#### 2.3.2 RX FIFO

The RX FIFO provides elasticity while data is read from PHY transceiver and written into internal memory. There are no programmable settings for the RX FIFO. This FIFO's operation is completely transparent to host software.

#### 2.3.3 Rules Checker

The rules checker examines frames. After a frame has been examined, the appropriate classification bits are set in the buffer descriptor. The rules checker is part of the RX data path and the frames are classified during data movement to NIC memory. The following frame positions may be established by the rules checker:

- IP Header Start Pointer
- TCP/UDP Header Start Pointer
- Data Start Pointer

#### 2.3.4 RX List Initiator

The RX List Initiator function activates whenever the receive producer index for any of receive buffer descriptor (BD) rings is written. This value is located in one of the receive BD producer mailboxes. The host software writes to the producer mailbox and causes the RX Initiator function to enqueue an internal data structure/request, which initiates the DMA of one or more new BDs to the NIC. The actual DMAs generated depend on the comparison of the value of the received BD host producer index mailbox, the NIC copy of the received BD consumer index, and the local copy of the received BD producer index.

### 2.4 Transmit Data Path

### 2.4.1 TX MAC

The Read DMA engine moves packets from host memory into internal NIC memory (see Figure 4). When the entire packet is available, the transmit MAC is activated.

Figure 4: Transmit Data Path



The transmit MAC is responsible for the following functions:

- Moving data from NIC internal memory into TX FIFO
- Moving data from TX FIFO to PHY
- Checksum substitutions (not calculation)
- Updating statistics

#### 2.4.2 TX FIFO

The TX FIFO provides elasticity while data is moved from device internal memory to PHY. There are no programmable settings for the TX FIFO. This FIFO's operation is completely transparent to host software.

### 2.5 DMA Read

# 2.5.1 Read Engine

The DMA read engine (see Figure 5) activates whenever a host read is initiated by the send or receive data paths.

Figure 5: DMA Read Engine



The DMA read engine dequeues an internal data structure/request and performs the following functions:

- DMAs the data from the host memory to an internal Read DMA FIFO
- Moves the data from the Read DMA FIFO to NIC internal memory
- Classifies the frame
- Performs checksum calculations
- Copies the VLAN tag field from the DMA descriptor to the frame header

#### 2.5.2 Read FIFO

The read FIFO provides elasticity during data movement from host memory to device local memory. The memory arbiter is a gatekeeper for multiple internal blocks; several portions of the architecture may simultaneously request internal memory. The PCI read FIFO provides a small buffer for the data read from host memory while the Read DMA engine requests internal memory via the memory arbiter. The data is moved out of the read DMA FIFO into device local memory once a memory data path is available. The FIFO isolates the PCI clock domain from the device clock domain. This reduces latency internally and externally on the PCI bus. The PCIe Read DMA FIFO holds 1024 bytes. The operation of the read DMA FIFO is transparent to host software. The Read DMA engine makes sure there is enough space in internal Tx Packet Buffer Memory before initiating a DMA request for transfer of Tx packet data from host memory to device internal packet memory.

# 2.5.3 Buffer Manager

The buffer manager maintains pools of internal memory used by transmit and receive engines. The buffer manager has logic blocks for allocation, free, control, and initialization of internal memory pools. The DMA read engine requests internal memory for BDs and frame data. Figure 5 on page 38 shows the transmit data path using the DMA Read Engine. The read DMA engine also fetches Rx BDs for the receive data path.

### 2.6 DMA Write

### 2.6.1 Write Engine

The DMA write engine, as shown in Figure 6, activates when a host write is initiated by the send or receive data paths.

Figure 6: DMA Write Engine



The DMA write engine dequeues an internal request and performs the following functions:

- Gathers the data from device internal memory into the write DMA FIFO
- DMAs the data to the host memory from the write FIFO
- Performs byte and word swapping
- Interrupts the host using a line or message signaled interrupt

#### 2.6.2 Write FIFO

The write FIFO provides elasticity during data movement from device memory to the host memory. The write FIFO absorbs small delays created by PCIe bus arbitration. The NetXtreme family uses the write FIFO to buffer data, so internal memory arbitration is efficient. Additionally, the FIFO isolates the PCI clock domain from the device's clock domain. This reduces latency on the PCI bus during the write operation (wait states are not inserted while data is fetched from internal memory). The operation of the write DMA FIFO is transparent to host software.

# 2.6.3 Buffer Manager

The buffer manager maintains pools of internal memory used in transmit and receive functions. The buffer manager has logic blocks for allocation, free, control, and initialization of internal memory pools. The receive MAC requests NIC Rx Mbuf memory so inbound frames can be buffered. The read DMA engine requests the device Tx Mbuf memory for buffering the packets from host memory before they are sent out on the wire. The DMA write engine requests a small amount of internal memory for DMA and interrupt operations. The usage of this internal memory is transparent to host software, and does not affect device/system performance.

### 2.7 LED Control

Refer to the "LED Control" section in the applicable data sheet.

# 2.8 Memory Arbiter

The Memory Arbiter (MA) is a gatekeeper for internal memory access. The MA is responsible for decoding the internal memory addresses that correspond to Ethernet controller data structures and control maps. If a functional block faults or traps during access to internal memory, the MA handles the failing condition and reports the error in a status register. In addition to architectural blocks, the MA provides a gateway for the RISC processor to access local memory. The RISC has an MA interface that pipelines up to three access requests. The MA negotiates local memory access, so all portions of the architecture are provided with fair access to memory resources. The MA prevents starvation and bounds access latency. Host software may enable/disable/reset the MA, and there are no tunable parameters.

# 2.9 Host Coalescing

### 2.9.1 Host Coalescing Engine

The Host Coalescing Engine is responsible for pacing the rate at which the NIC updates the send and receive ring indices located in host memory space. The completion of a NIC update is reflected through an interrupt on the Ethernet controller INTA pin or a Message Signaled Interrupt (MSI). Although update criteria are calculated separately, all updates occur at once. This is because all of the ring indices are in one status block, and any host update updates all ring indices simultaneously. The Host Coalescing Engine triggers based on a tick and/or a frame counter.

Figure 7: Host Coalescing Engine



A host update occurs whenever one of the following criteria is met:

- The number of BDs consumed for frames received, without updating receive indices on the host, is equal to or has exceeded the threshold set in the Receive\_Max\_Coalesced\_BD register (see "Receive Max Coalesced Bd Count Register (Offset: 0x3c10)" on page 220).
- The number of BDs consumed for transmitting frames, without updating the send indices, on the host is equal to or has exceeded the threshold set in the Send\_Max\_Coalesced\_BD register (see "Send Max Coalesced BD Count Register (Offset: 0x3c14)" on page 220). Updates can occur when the number of BDs (not frames) meets the thresholds set in the various coalescing registers (see Section 11: "Interrupt Processing," on page 197 for more information).
- The receive coalescing timer has expired, new frames have been received on any of the receive rings, and a host update has not occurred. The receive coalescing timer is then reset to the value in the Receive\_Coalescing\_Ticks register (see "Send Coalescing Ticks Register (Offset: 0x3c0c)" on page 219).
- The send coalescing timer has expired, new frames have been consumed from any send ring, and a host update has not occurred. The send coalescing timer is then reset to the value in the Send Coalescing Ticks register.

#### 2.9.2 MSI FIFO

This FIFO is eight entries deep and four bits wide. This FIFO is used to send MSIs via the PCI interface. The host coalescing engine uses this FIFO to enqueue requests for the generation of MSI. There are no configurable options for this FIFO and this FIFO's operation is completely transparent to host software.

#### 2.9.3 Status Block

This data structure contains consumer and producer indices/values. Host software reads this control block, to assess hardware updates in the send and receive rings. Two copies of the status block exist. The local copy is DMAed to host memory by the DMA write engine. Host software does not want to generate PCI transactions to read ring status; rather quicker memory bus transactions are desired. The host coalescing engine enqueues a request to the DMA write engine, so host software gets a refreshed copy of status. The status block is refreshed before a line IRQ or MSI is generated. See "Status Block Format" on page 61 for a complete discussion of the status block.

### 2.10 10BT/100BTx/1000BASE-T Transceiver

# 2.10.1 Auto-Negotiation

The Ethernet controller devices negotiate their mode of operation over the twisted-pair link using the auto-negotiation mechanism defined in the IEEE 802.3u and IEEE 802.3ab specifications. Auto-negotiation can be enabled or disabled by hardware or software control. When the auto-negotiation function is enabled, the Ethernet controllers automatically choose the mode of operation by advertising their abilities and comparing them with those received from its link partner. The Ethernet controllers can be configured to advertise 1000BASE-T full-duplex and/or half-duplex, 100BASE-TX full-duplex and/or half-duplex, and 10BASE-T full-duplex and/or half-duplex. The transceiver negotiates with their link partner and chooses the highest operating speed and duplex that are common between them. Auto-negotiation can be disabled for testing or for forcing 100BASE-TX or 10BASE-T operation, but is always required for normal 1000BASE-T operation.

### 2.10.2 Automatic MDI Crossover

During auto-negotiation, one end of the link must perform an MDI crossover so that each transceiver's transmitter is connected to the other receiver. The Ethernet controllers can perform an automatic MDI crossover when the Disable Automatic MDI Crossover bit in the PHY Extended Control register is disabled, thus eliminating the need for crossover cables or cross-wired (MDIX) ports. During auto-negotiation, the Ethernet controllers normally transmit on TRD±{0} and

receive on TRD±{1}. When connected to another device that does not perform the MDI crossover, the Ethernet controller automatically switches its transmitter to TRD±{1} and its receiver to TRD±{0} to communicate with the remote device. If two devices that both have MDI crossover capability are connected, an algorithm determines which end performs the crossover function. During 1000BASE-T operation, the Ethernet controllers swap the transmit symbols on pairs 0 and 1 and pairs 2 and 3 if auto-negotiation completes in the MDI crossover state. The 1000BASE-T receiver automatically detects pair swaps on the receive inputs and aligns the symbols properly within the decoder.

### 2.11 PHY Control

The NetXtreme/NetLink Ethernet controller supports the following physical layer interfaces:

- The MII is used in conjunction with 10/100 Mbps copper Ethernet transceivers.
- GMII supports 1000 Mbps copper Ethernet transceivers.

#### 2.11.1 MII Block

The MII interconnects the MAC and PHY sublayers (as shown in Figure 8 on page 43).

Figure 8: Media Independent Interface



The specifics of MII may be located in section 22 of the IEEE 802.3 specification. RXD[3:0] are the receive data signals; TXD[3:0] are the transmit data signals. MII operates at both 10-Mbps and 100-Mbps wire-speeds. (Gigabit Ethernet uses the GMII standard.) When MAC and PHY are configured for 10 Mbps operation, the RX\_CLK1 and MII\_TXCLK clocks run at 2.5 MHz. Both RX\_CLK1 and MII\_TXCLK are sourced by the PHY. 100 Mbps wire speed requires RX\_CLK1 and MII\_TXCLK to provide a 25 MHz reference clock. Receive Data Valid (RX\_DV) is asserted when valid frame data is received; at any point during data reception, the PHY may assert Receive Error (RX\_ER) to indicate a receive error. The MAC will record this error in the statistics block. The MAC may discard a bad RX frame—exception being sniffer/promiscuous modes (see Allow\_Bad\_Frames bit in MAC mode register). The Transmit Enable (TX\_EN) signal is asserted when the MAC presents the PHY with a valid frame for transmission. The MAC may assert TX\_ER to indicate the remaining portion of frame is bad. The PHY will insert Bad Code symbols into the remaining portion of the frame. A detected collision in half-duplex mode may be such a scenario where TX\_ER is asserted. The PHY will assert COL when a collision is detected. The COL signal is routed to both the RX and TX MACs. The transmit MAC will back off transmission and the RX MAC will throw away partial frames.

The 10 Mbps physical layer uses Differential Manchester encoding on the wire. Manchester encoding uses two encoding levels: 0 and 1. 100 Mbps Ethernet requires MLT-3 waveshaping on the transmission media. MLT-3 uses three encoding levels: -1, 0, and 1. Both physical signaling protocols are transparent to the MAC sublayer and are digitized by the PHY. The PHY encodes/decodes analog waveforms at its lower edge while the PHY presents digital data at its upper edge (MII).

### 2.11.2 GMII Block

The GMII is full-duplex (see Figure 9 on page 45); the send and receive data paths operate independently.

The transmit signals TXD[7:0] create an eight-bit wide data path. The TXD[7:0] signals are synchronized to the reference clockTX\_CLK0. The TX\_CLK0 clock runs at 125 MHz and is sourced by the MAC sublayer. Transmit Error (TX\_ER) is asserted by the MAC sublayer. The PHY will transmit a bad code until TX\_ER is deasserted by the MAC. TX\_ER is driven synchronously with TX\_CLK0. The Transmit Enable (TX\_EN) indicates that valid data is presented on the TXD lines. The TXD[7:0] data is framed on the rising edge of TX\_EN.

The receive data path is also eight bits wide. RXD[7:0] are sourced by the PHY. When valid data is presented to the MAC sublayer, the PHY will also assert Receive Data Valid (RX\_DV). The rising edge of RX\_DV indicates the beginning of a frame sequence. The PHY drives the reference clock RX\_CLK1, so the MAC sublayer can synchronize data sampling on RXD[7:0]. The PHY may assert RX\_ER to indicate frame data is invalid; the MAC sublayer must consider frames in progress incomplete.

When the MAC operates in half-duplex mode, a switch or node may transmit a jamming pattern. The PHY will drive the Collision (COL) signal so the MAC may back off transmission and throw away partially received packet(s). The COL signal will also cause the TX MAC to stop the transmission of a packet. The COL signal is not driven for full-duplex operation since collisions are undefined. The PHY will drive Carrier Sense (CRS) as a response to traffic being sent/received. The MAC sublayer can monitor traffic and subsequently drive traffic LEDs.

Pulse Amplitude Modulated Symbol (PAM5) encoding is leveraged for Gigabit Ethernet wire transmissions. PAM5 uses five encoding levels: -2, -1, 0, 1, and 2. Four symbols are transmitted in parallel on the four twisted-wire pairs. The four symbols create a code group (an eight-bit octet). The process of creating the code-group is called 4D-PAM5. Essentially, eight data bits are represented by four symbols. Table 40-1 in the IEEE 802.3ab specification shows the data bit to symbol mapping. The code group representation is also referred to as a quartet of quinary symbols {TA, TB, TC, TD}. The modulation rate on the wire is measured at 125 Mbaud. The resultant bandwidth is calculated by multiplying 125 MHz by eight bits, for 1000 Mbps wire speed.

Figure 9: GMII Block



### 2.11.3 MDIO Register Interface

Figure 10 shows the MDI register interface.

Figure 10: MDI Register Interface



#### 2.11.3.1 Management Data Clock

The Management Data Clock (MDC) is driven by the MAC sublayer. The PHY will sink this signal to synchronize data transfer on the MDIO signal—MDC is a reference clock. This clock is not functionally associated with either RX\_CLK or TX\_CLK. The minimum period for this clock is 400 ns with high and low times having 160 ns duration.

### 2.11.3.2 Management Data Input/Output

The Management Data Input/Output (MDIO) signal passes control and status data, between the MAC and PHY sublayers. MDIO is a bidirectional signal, meaning both the PHY and MAC may transfer data. The MAC typically transfers control information and polls status; whereas, the PHY transfers status back to the MAC, using MDIO.

### 2.11.3.3 Management Data Interrupt

The integrated Broadcom PHY may be programmed to generate interrupts. A PHY status change initiates a Management Data Interrupt (MDINT). A MDI mask register allows host software to selectively enable/disable status types, which cause MDINT notification. The PHY will assert INTR until software clears the interrupt. Reading the status register will clear the interrupt.

### 2.11.3.4 Management Register Block

The layout and configuration of MDI register block are device dependent. The MDI register block is the control/status access point, which host software may read/write. The IEEE 802.3 specification defines a basic register block for MII and GMII; the basic register set contains control and status registers. GMII also exposes an extended register set, used in 1000 Mbps configuration/status. The fundamental point is to understand that the MDC and MDIO signals are used to access the MDI register block.

# **Chapter 3: NVRAM Configuration**

### 3.1 Overview

Broadcom NetXtreme and NetLink controllers require the use of an external non-volatile memory (NVRAM) device (Flash or SEEPROM), which contains a boot code program that the controller's on-chip CPU core loads and executes upon release from reset. This external NVRAM device also contains many configuration items that direct the behavior of the controller, enable/disable various management and/or value-add firmware components, etc.

All configuration settings are default-configured in the official release binary image files provided in Broadcom's CD software releases. However, the settings chosen as default by Broadcom may not be what best suits a particular OEM's application, so some settings may need to be changed by the OEM.

The BCM571X/BCM5720 family supports the following boot code styles:

- "Legacy"—Boot code plus configuration options fully contained in an external 8k byte NVRAM device
- "Self-boot"—Uses a fixed internal ROM'd copy of the boot code program (requires only a very small external NVRAM) for housing OEM-programmable configuration items (refer to Application Note NetXtreme-AN60x-R "NetXtreme/NetLink NVRAM Configuration Options").

**NOTE:** If using self-boot, the design must use a very small (approximately 256 byte) external NVRAM to hold configuration items and self-boot code patches.

Refer to Broadcom Application Note NetXtreme-AN40X-R (NetXtreme®/NetLink™ Software Self-Boot NVRAM Application Note) for additional detail regarding self-boot NVRAM structure.

Details relating to the legacy style NVRAM organization can be found in *NetXtreme/NetLink NVRAM Access* Broadcom application note (NetXtreme-AN50X-R). Some of the topics addressed by this application note include the following:

- Programming NVRAM (sample C code, x86 assembly)
- NVRAM map
- Configuration settings
- Boot code
- Multiple boot agent (MBA), PXE, etc.

NOTE: NVRAM CRC-32: There are multiple distinct regions contained within the NVRAM map. Each of these regions has its own CRC-32 checksum value associated with it. If any data element contained within a region is modified, then that region's CRC-32 value must also be updated. Details relating to calculating the CRC-32 can be found in Calculating CRC32 Checksums for Broadcom NetLink, NetXtreme, and NetXtreme II<sup>®</sup> Controllers Broadcom application note (NetXtreme\_NetXtremeII-AN20X-R).

### 3.2 Self-Boot

Some NetLink controllers offer a capability known as self-boot. Self-boot allows the controller to use a very small, low-cost, external NVRAM device that contains only a very condensed amount of configuration information, along with any small boot code patches that may be necessary to optimize the functionality of a particular controller.

Details relating to self-boot can be found in *Self Boot Option* (5754X\_5787X-AN10X-R) and *NetXtreme/NetLink Software Self-Boot NVRAM* (NetXtreme-AN40X-R) Broadcom application notes.

# **Chapter 4: Common Data Structures**

# 4.1 Theory of Operation

Several device data structures are common to the receive, transmit, and interrupt processing routines. These data structures are hardware-related and are used by device drivers to read and update state information.

# 4.2 Descriptor Rings

To send and receive packets, the host and the controller use a series of shared buffer descriptor (BD) rings to communicate information back and forth. Each ring is composed of an array of buffer descriptors that reside in host memory. These buffer descriptors point to either send or receive packet data buffers. The largest amount of data that a single buffer may contain is 65535 (64K-1) bytes (The length field in BD is 16 bits). Multiple descriptors can be used per packet to achieve scattergather DMA capabilities.

**NOTE:** The maximum number of Send BDs for a single packet is (0.75)\*(ring size).

There are three main types of descriptor rings:

- Send Rings
- Receive Producer Rings
- Receive Return Rings

The TX/RX ring base requires an 8-byte alignment. The receive buffer address (recorded in SBD/RBD) cannot cross 4G.

### 4.2.1 Producer and Consumer Indices

The Producer Index and the Consumer Index control which descriptors are valid for a given ring. Each ring will have its own separate Producer and Consumer Indices. When incremented, the Producer Index can be used to add elements to the ring. Conversely, when incremented, the Consumer Index is used to remove elements from the ring. The difference between the Producer and Consumer Indices mark which descriptors are currently valid in the ring (see Figure 11). When the Producer and Consumer Index are equal, the ring is empty. When the producer is one behind the consumer, the ring is considered to be full.

Figure 11: Generic Ring Diagram

The drawing shows a generic host descriptor ring (could be either a send ring or a receive ring), and demonstrates how the consumer and producer indices are used to determine which descriptors in the ring are valid at any given moment in time.



### 4.2.2 Ring Control Blocks

Each ring (send or receive) has a Ring Control Block (RCB) associated with it. Each RCB has the format shown in Table 4.

**Table 4: Ring Control Block Format** 

| Offset (bytes) | 31                | 16 | 15  | 0 |
|----------------|-------------------|----|-----|---|
| 0x00           | Host Ring Address |    |     |   |
| 0x04           |                   |    |     |   |
| 80x0           | Max_len Flags     |    | ags |   |
| 0x0c           | Reserved          |    |     |   |

The fields are defined as follows:

- The Host Ring Address field contains the 64-bit host address of the first element in the ring. Basically, this field tells the controller precisely where in host memory the ring is located. This field only applies to rings that are located in host memory. The Host\_Ring\_Address field contains the 64-bit address, in big-endian ordering, of the first Send BD in host memory.
- The Flags field contains bits flags that contain control information about a given ring. Table 5 shows the two flags that are defined.

Table 5: Flag Fields for a Ring

| Bits | Name                   | Description                                |
|------|------------------------|--------------------------------------------|
| 0    | Reserved               | Should be set to 0.                        |
| 1    | RCB_FLAG_RING_DISABLED | Indicates that the ring is not in use.     |
| 15:2 | STD_MAX_PACKET_SIZE    | Indicates maximum frame size for the ring. |

- The Max len field has a different meaning for different types of rings.
  - This field indicates the number elements in the ring.
  - The valid values for this field are 32, 64, 128, 256, 512, 1024, 2048, and 4096.
- Max ring sizes supported in the BCM571X/BCM5720 Family are shown below.

- Rx Return: 4096- Rx Producer: 2048

Rx Producer Jumbo: 1024

- Tx Producer: 512

■ The NIC Ring Address field contains the address where the BD cache is located in the internal NIC address space. This address is only valid for Receive Producer Rings. The Send Rings and Receive Return Rings do not require this field to be populated. The location within the NIC address map for Receive Producer Ring is provided in "PCI" on page 140.

### 4.2.2.1 Send Ring Control Blocks

The format of the Send RCB remains unchanged, only 15 more are added as shown in the Table below.

Table 6: Send RCBs for Multiple Rings

|                 |                        | Send Ring RCB         |               |
|-----------------|------------------------|-----------------------|---------------|
| Send Ring#      | Register Name          | Register Address (**) | Usable in     |
|                 | Host Address High      | 0x100                 | Legacy Mode,  |
| Legacy /        | Host Address Low       | 0x104                 | RSS Mode &    |
| 1               | Max Length/Flag        | 0x108                 | IOV Mode      |
|                 | NIC Address            | 0x10C                 |               |
|                 | Host Address High      | 0x110                 |               |
| 2               | Host Address Low       | 0x114                 | RSS Mode &    |
|                 | Max Length/Flag        | 0x118                 | IOV Mode      |
|                 | NIC Address            | 0x11C                 |               |
| 3               |                        |                       |               |
| 4               |                        |                       |               |
| 5               |                        |                       |               |
|                 |                        |                       | IOV Mode Only |
| 16              | Host Address High      | 0x1F0                 |               |
|                 | Host Address Low       | 0x1F4                 |               |
|                 | Max Length/Flag        | 0x1F8                 |               |
|                 | NIC Address            | 0x1FC                 |               |
| ** These are Me | emory Mapped registers |                       |               |

**NOTE:** Address range [0x100–0x10F] is the legacy single RCB address and is also used by RCB1.

### 4.2.2.2 Receive Ring Control Blocks

Table 7 lists all of the receive RCB Register Addresses.

Table 7: High Priority Mail Box Registers for VRQ Rings

| VRQ#        | Register Name     | Standard Ring RCB<br>Register Address | Jumbo Ring RCB Register<br>Address | Return Ring RCB Register Address (**) |
|-------------|-------------------|---------------------------------------|------------------------------------|---------------------------------------|
|             | Host Address High | 0x2450                                | 0x2440                             | 0x200                                 |
| 0 (Default) | Host Address Low  | 0x2454                                | 0x2444                             | 0x204                                 |
| 0 (Default) | Max Length/Flag   | 0x2458                                | 0x2448                             | 0x208                                 |
|             | NIC Address       | 0x245C                                | 0x244C                             | 0x20C                                 |
|             | Host Address High | 0x2510                                | 0x2500                             | 0x210                                 |
| 1           | Host Address Low  | 0x2514                                | 0x2504                             | 0x214                                 |
| I           | Max Length/Flag   | 0x2518                                | 0x2508                             | 0x218                                 |
|             | NIC Address       | 0x251C                                | 0x250C                             | 0x21C                                 |
|             | Host Address High | 0x2530                                | 0x2520                             | 0x220                                 |
| 2           | Host Address Low  | 0x2534                                | 0x2524                             | 0x224                                 |
| 2           | Max Length/Flag   | 0x2538                                | 0x2528                             | 0x228                                 |
|             | NIC Address       | 0x253C                                | 0x252C                             | 0x22C                                 |

Table 7: High Priority Mail Box Registers for VRQ Rings (Cont.)

| VRQ# | Register Name     | Standard Ring RCB<br>Register Address | Jumbo Ring RCB Register<br>Address | Return Ring RCB Register Address (**) |
|------|-------------------|---------------------------------------|------------------------------------|---------------------------------------|
|      | Host Address High | 0x2550                                | 0x2540                             | 0x230                                 |
| 2    | Host Address Low  | 0x2554                                | 0x2544                             | 0x234                                 |
| 3    | Max Length/Flag   | 0x2558                                | 0x2548                             | 0x238                                 |
|      | NIC Address       | 0x255C                                | 0x254C                             | 0x23C                                 |
| 4    | Host Address High | 0x2570                                | 0x2560                             | 0x240                                 |
|      |                   |                                       |                                    |                                       |
|      | Host Address High | 0x26F0                                | 0x26E0                             | 0x300                                 |
| 40   | Host Address Low  | 0x26F4                                | 0x26E4                             | 0x304                                 |
| 16   | Max Length/Flag   | 0x26F8                                | 0x26E8                             | 0x308                                 |
|      | NIC Address       | 0x26FC                                | 0x26EC                             | 0x30C                                 |

NOTE: [0x2450 .. 0x245C] and [0x2440 .. 0x244C] are legacy RCB addresses and are being assigned to VRQ Ring# 0.

**NOTE:** The Return Ring RCBs are Memory Mapped. Memory Address [0x200 .. 0x23C] are legacy Return Ring RCB addresses and are being assigned to VRQ Return Ring# 0 through Ring# 3

### 4.2.3 Send Rings

The controller devices covered in this document support only one host-based Send Ring.

The Send Ring Producer Index is incremented by host software to add descriptors to the Send Ring (see Figure 12 on page 53). By adding descriptors to the ring, the device is instructed to transmit packets that are composed of the buffers pointed to by the descriptors. A single transmit packet may be composed of multiple buffers that are pointed to by multiple send descriptors. The maximum number of send descriptors for a single packet is (0.75)\*(ring size).

Figure 12: Transmit Ring Data Structure Architecture Diagram

Transmit Ring Data Structure is located in the host (as shown below), and the device will keep a local (not shown) copy of the rings.



### 4.2.3.1 Send Buffer Descriptors

### 4.2.3.1.1 Standard (Not Large Segment Offload)

The format of an individual send buffer descriptor is shown in Table 8.

**Table 8: Send Buffer Descriptors Format** 

| Offset (Bytes) | 31                  | 16 | 15           |
|----------------|---------------------|----|--------------|
| 0x00           | Host Address [63:0] |    |              |
| 0x04           |                     |    |              |
| 0x08           | Length [15:0]       |    | Flags [15:0] |
| 0x0c           | Reserved            |    | VLAN Tag     |

The fields are defined as follows:

- The Host Address field contains the 64-bit host address of the buffer that the descriptor points to. A length of 0 indicates that the descriptor does not have a buffer associated with it.
- The Flags field contains bit flags that contain control information for the device for transmitting the packets. The defined flags are listed in Table 9.

Table 9: Defined Flags for Send Buffer Descriptors

| Bits | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | TCP_UDP_CKSUM <sup>a</sup> | If set to 1, the controller replaces the TCP/UDP checksum field of TCP/UDP packets with the hardware calculated TCP/UDP checksum for the packet associated with this descriptor.                                                                                                                                                                                                                                                   |
| 1    | IP_CKSUM                   | If set to 1, the controller replaces the IPv4 checksum field of TCP/UDP packets over IPv4 with the hardware calculated IPv4 checksum for the packet associated with this descriptor. This bit should only be set in the descriptor that points to the buffer containing the IPv4 header. It is assumed that the IPv4 header is contained in a single buffer.                                                                       |
| 2    | PACKET_END                 | If set to 1, the packet ends with the data in the buffer pointed to by this descriptor.                                                                                                                                                                                                                                                                                                                                            |
| 3    | Jumbo Frame                | The driver must set this bit to 1 if the MTU length of the Send Frame is > 1500B. The MTU length is the Ethernet payload length and excludes Header length (and Trailer length).  All BDs belonging to a Send Packet must configure this bit identically.                                                                                                                                                                          |
| 4    | HDRLEN[2]                  | The length of the Ether+IP+TCP Headers to be replicated in each segment arising out of a Large TCP Segment (LSO).                                                                                                                                                                                                                                                                                                                  |
| 5    | Capture Time Stamp         | (BCM5719/5720 only) If this bit is 1, this frame's launch time shall be captured in the TX Time-Stamp Register.                                                                                                                                                                                                                                                                                                                    |
| 6    | VLAN_TAG <sup>a</sup>      | If set to 1, the device inserts an IEEE 802.1Q VLAN tag into the packet. The 16-bit TCI (Tag Control Information) field of four byte VLAN tag comes from the VLAN Tag field in the descriptor.                                                                                                                                                                                                                                     |
| 7    | COAL_NOW                   | If set to 1, the device immediately updates the Send Consumer Index after the buffer associated with this descriptor has been transferred via DMA to NIC memory from host memory. An interrupt may or may not be generated according to the state of the interrupt avoidance mechanisms. If this bit is set to 0, then the Consumer Index is only updated as soon as one of the host interrupt coalescing conditions has been met. |
| 8    | CPU_PRE_DMA                | If set to 1, the controller's internal CPU is required to act upon the packet before the packet is given to the internal <i>Send Data Initiator</i> state machine. Normally this bit should be set to 0.                                                                                                                                                                                                                           |
| 9    | CPU_POST_DMA <sup>a</sup>  | If set to 1, the controller's internal CPU is required to act upon the packet before the packet is given to the internal <i>Send Data Completion</i> state machine. Normally this bit should be set to 0.                                                                                                                                                                                                                          |
| 10   | HDRLEN[3]                  | The length of the Ether+IP+TCP Headers (combined) to be replicated in each frame arising out of a Large TCP Segment (LSO). Maximum Header Length is 256B.                                                                                                                                                                                                                                                                          |
| 11   | HDRLEN[4]                  | _                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Table 9: Defined Flags for Send Buffer Descriptors (Cont.)

| Bits | Name           | Description                                                                          |
|------|----------------|--------------------------------------------------------------------------------------|
| 12   | HDRLEN[5]      | -                                                                                    |
| 13   | HDRLEN[6]      | _                                                                                    |
| 14   | HDRLEN[7]      | -                                                                                    |
| 15   | DON'T_GEN_CRCa | If set to 1, the controller will not append an Ethernet CRC to the end of the frame. |

Indicates that this bit should be set in all descriptors for a given packet if the desired capability is to be enabled for that
packet.

**NOTE:** The UDP checksum engine does not span IP fragmented frames.

The Length field specifies the length of the data buffer. The lengths of the buffers associated with a given packet will add up to the length of the packet.

**NOTE:** The Ethernet controller does not validate the value of the Length field and may generate an error on the PCI bus if the Length field has a value of 0. The host driver must ensure that the Length field is nonzero before enqueueing the BD onto the Send Ring.

■ The VLAN Tag field is only valid when the VLAN\_TAG bit of Flags field is set. This VLAN Tag field contains the 16-bit VLAN tag that is to be inserted into an IEEE 802.1Q (and IEEE 802.3ac)-compliant packet by the controller. If VLAN tag insertion is desired, this field (and the flag) should be set in the first descriptor for that packet (i.e., the descriptor that points to the buffer that contains the Ethernet header).

#### 4.2.3.1.2 Large Segment Offload (LSO) Send BD

See "Large Segment Offload" on page 88.

### 4.2.4 Receive Rings

The Ethernet controllers support two types of Receive Descriptor Rings: Producer Rings and Return Rings (see Figure 13). Unlike previous NetXtreme controllers, the BCM571X/BCM5720 family adds a second Receive Producer ring dedicated to jumbo frame reception. Descriptors in the Producer Rings point to free buffers in the host. When the controller receives a packet and consumes a receive buffer, the controller will modify and write back the descriptor for the consumed buffer into the given Receive Return Ring. Basically, the Producer Rings contain descriptors that point to buffers that the controller is free to use, whereas the Return Rings contain descriptors that the device has used and await processing from host software.

Receive Buffer Descriptor index flags type ip chksum tcp\_udp\_chsum vlan tag Host Memory Ring Control Block opaque Receive Ring #1 Host Ring Address Host Buffer NIC Ring Address 1-(64K-1) Bytes RCB #4 Receive Ring #4 Status Block (80 bytes) 1st Status Block Cor Status block resides in the NIC memory Mailbox Registers space and is periodically DMA'd to the host based on the host coalescing Timer TX Cons RX Prod #1 RX Cons #1 RX Cons #4 The NIC is the Producer of the receive return ring increments the internal producer index to add elements to the ring. Note: The receive return rings are stored in host memory

Figure 13: Receive Return Ring Memory Architecture Diagram

### 4.2.4.1 Receive Producer Ring

The receive producer ring resides in the host and points to empty host receive buffers that will later be filled with received packet data. The controller will internally cache a copy of the producer ring. When the host software driver has a free host receive packet buffer available for incoming packets, it will fill out a receive buffer descriptor and have that descriptor point to the available buffer. Host software will then update the producer index for that receive producer ring to indicate to the controller that there is a newly available receive buffer. After the controller fetches and caches (e.g., consumes) this receive producer descriptor, the controller will update the consumer index of the receive producer ring.

#### 4.2.4.2 Receive Return Rings

When the NIC receives a packet, it will DMA that packet to a host receive packet data buffer pointed to by the available receive buffer descriptor (see Section 5: "Receive Data Flow," on page 66). Earlier the NIC will have received ownership of that data buffer via an update of the producer index of receive producer ring. After the controller does the packet data write DMA, it will DMA a corresponding buffer descriptor into the appropriate receive return ring. The buffer descriptor that is returned in the receive return ring will be slightly modified from the original buffer descriptor that the controller fetched out of the receive producer ring. After the controller has completed the DMA of the receive return ring descriptor, the controller will update its internal copy of the producer index for that particular receive return ring. That new value for that receive return ring producer index will be included in the next status block update that is made to the host. The updated value of receive return ring producer index in status block will be used by host software in determining whether new packets have been received.

**Table 10: Receive Return Rings** 

| Description                              | BCM571X/BCM5720 Family                                                     |
|------------------------------------------|----------------------------------------------------------------------------|
| Number of Rings                          | 4                                                                          |
| Buffer Descriptor Size (bytes)           | 32                                                                         |
| Host Ring Size (# of Buffer Descriptors) | Can be configured for 32 or 64 or 128 or 256 or 512 or 1024 or 208 or 4096 |
| NIC Cache Size (# of Buffer Descriptors) | 0                                                                          |

#### 4.2.4.3 Receive Buffer Descriptors

The format of Standard Receive Buffer Descriptors (in both producer ring and return rings) is shown in Table 11.

**Table 11: Receive Descriptors Format** 

| Offset (bytes) | 3116        | 150           |
|----------------|-------------|---------------|
| 0x00           |             | Host Address  |
| 0x04           |             |               |
| 0x08           | Index       | Length        |
| 0x0c           | Туре        | Flags         |
| 0x10           | IP_Cksum    | TCP_UDP_Cksum |
| 0x14           | Error_Flags | VLAN tag      |
| 0x18           |             | RSS Hash      |
| 0x1C           | Opaque      |               |

The fields are defined as follows:

- Host Address—Contains the 64-bit host address of the buffer that the descriptor points to. A length of 0 indicates that the descriptor does not have a buffer associated with it.
- Length—Specifies the length of the data buffer. For Producer Rings this value is set by the host software to correspond to the size of the buffer that is available for a receive packet. Once a packet has been received, the controller will modify this length field to correspond to the length of the packet received. A value of 0 indicates that there is no valid data in the buffer.
- Index—Is set by host software in the descriptors in the producer rings. When the controller uses a given buffer descriptor, it will opaquely pass the Index field for that buffer descriptor through to the corresponding descriptor in the return ring. This index field of the BD in Return Ring is then used by the host software to associate the BD in Return Ring with the BD in Producer Ring that points to the given receive buffer.
- Flags—Contains bits flags that contain control information about a given descriptor. The defined flags are listed in Table 13 on page 59.

Table 12: Defined Flags for Receive Buffers

| Bits | Name             | Description                                                                                                                                                                                                                                                  |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | IP Version       | Indicates whether the received IP packet is an IPv6 or IPv4 packet. This bit will be 1 for IPv6 packet and 0 for IPv4 packet.                                                                                                                                |
| 14   | TCP_UDP_IS_TCP   | In producer rings this bit should be set to 0. In return rings this bit will be set to 1 by the controller if the controller calculated that the incoming packet was a TCP packet. If the packet is UDP or a non IP frame, then this bit should be set to 0. |
| 13   | TCP_UDP_CHECKSUM | In producer rings this bit should be set to 0. In return rings this bit will be set to 1 by the controller if the controller calculated that the TCP or UDP checksum in the corresponding incoming packet was correct.                                       |

Table 12: Defined Flags for Receive Buffers (Cont.)

| Bits | Name            | Description                                                                                                                                                                                                                                                                                                                                                                     |  |
|------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 12   | IP_CHECKSUM     | In producer rings this bit should be set to 0. In return rings this bit will be set to 1 by the controller if the controller calculated that the IP checksum in the corresponding incoming packet was correct.                                                                                                                                                                  |  |
| 11   | Reserved        | -                                                                                                                                                                                                                                                                                                                                                                               |  |
| 10   | FRAME_HAS_ERROR | If set to 1 in a return ring, it indicates that the controller detected an error. The specific type of error is specified in the Error_Flag field of the receive return descriptor.                                                                                                                                                                                             |  |
| 9:7  | RSS Hash Type   | Indicates the hash type used in RSS hash calculation for a received packet. Available hash types are:  ■ 0 2_TUPLE_IPV4 ■ 1 4_TUPLE_IPV4 ■ 2 2_TUPLE_IPV6 ■ 3 4_TUPLE_IPV6 ■ 4 Reserved ■ 5 Reserved ■ 6 Reserved ■ 7 Reserved ■ 7 Reserved See "Receive MAC Mode Register (offset: 0x468)" on page 282 for additional information about enabling the different RSS hash types. |  |
| 6    | VLAN_TAG*       | If set to 1 in a return ring, it indicates that the packet associated with this buffer contained a four-byte IEEE 802.1Q VLAN tag. The 16 VLAN ID is stripped from the packet and located in the VLAN tag field in the descriptor.                                                                                                                                              |  |
| 5    | Reserved        | Should be set to 0.                                                                                                                                                                                                                                                                                                                                                             |  |
| 4    | Reserved        | Should be set to 0.                                                                                                                                                                                                                                                                                                                                                             |  |
| 3    | RSS_Hash Valid  | If set to 1, indicates host that the RSS_Hash in Receive BD of return ring is valid.                                                                                                                                                                                                                                                                                            |  |
| 2    | PACKET_END      | If set to 1, the packet ends with the data in the buffer pointed to by this descriptor.                                                                                                                                                                                                                                                                                         |  |
| 1:0  | Reserved        | Should be set to 0.                                                                                                                                                                                                                                                                                                                                                             |  |

- Type—Used internally by the controller. In producer rings it should be set to 0, and in return rings it should be ignored by host software.
- TCP\_UDP\_Cksum—Holds the TCP/UDP checksum that the controller calculated for all data following the IP header given the length defined in the IP header. If the Receive No Pseudo-header Checksum bit is set (see "Mode Control Register (offset: 0x6800)" on page 416) to 1, then the pseudo-header checksum value is not added to this value. Otherwise, the TCP\_UDP\_Cksum field includes the pseudo-header in the controller's calculation of the TCP or UDP checksum. If the packet is not a TCP or UDP packet, this field has no meaning. Host software should zero this value in the producer ring descriptors. If the host is capable of TCP or UDP checksum offload, then host software may examine this field in the return rings to determine if the TCP or UDP checksum was correct.
- IP\_Cksum— Host software should zero this value in the producer ring descriptors. For Receive Return Ring descriptors, if using IP checksum offload, the host driver software should rely on the Flags bit IP\_CHECKSUM (Flags bit 12) to determine if the IP checksum in the received packet is correct. This field used to contain the actual IP checksum value but that is not true for the BCM571X/BCM5720 family of controllers. Only the Flags bit IP\_CHECKSUM should be relied on by host driver software as is done by Broadcom drivers.
- VLAN—Only valid when the VLAN\_TAG bit is set. This field contains the 16-bit VLAN ID that was extracted from an incoming packet that had an IEEE 802.1Q (and IEEE 802.3ac) -compliant header.
- Error\_Flags—Contains bits flags that contain error information about an incoming packet that the descriptor is associated with. The bits in this field are only valid if the FRAME\_HAS\_ERROR bit is set in the Flags field in the descriptor. The defined error flags are listed in Table 13.

Table 13: Defined Error Flags for Receive Buffers

| Bits | Name              | Description                                                                                                                                                                                                                                                                                  |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved          | Should be set to 0.                                                                                                                                                                                                                                                                          |
| 8    | GIANT_PKT_RCVD    | If set to 1, the received packet was longer than the maximum packet length value set in the Receive MTU Size register (see "Receive MTU Size Register (offset: 0x43C)" on page 277). The data in the received packet was truncated at the length specified in the Receive MTU Size register. |
| 7    | TRUNC_NO_RES      | If set to 1, the received packet was truncated because the controller did not have the resources to receive a packet of this length.                                                                                                                                                         |
| 6    | LEN_LESS_64       | If set to 1, the received packet was less than the required 64 bytes in length.                                                                                                                                                                                                              |
| 5    | MAC_ABORT         | If set to 1, the MAC aborted due to an unspecified internal error while receiving this packet. The packet could be corrupted.                                                                                                                                                                |
| 4    | ODD_NIBBLE_RX_MII | If set to 1, the received packet contained an odd number of nibbles. Thus, packet data could be corrupt.                                                                                                                                                                                     |
| 3    | PHY_DECODE_ERR    | If set to 1, while receiving this packet the device encountered an unspecified frame decoding error. This packet could be corrupted.                                                                                                                                                         |
|      |                   | This bit is set for valid packets that are received with a dribble nibble. True alignment errors will be dropped by that MAC and never show up to the driver.                                                                                                                                |
| 2    | LINK_LOST         | If set to 1, link was lost while receiving this frame. Therefore, this packet is incomplete.                                                                                                                                                                                                 |
| 1    | COLL_DETECT       | If set to 1, a collision was encountered while receiving this packet.                                                                                                                                                                                                                        |
| 0    | BAD_CRC           | If set to 1, the received packet has a bad Ethernet CRC.                                                                                                                                                                                                                                     |

- When the RSS Hash Valid flag bit is 1, the RSS Hash field holds the 32-bit RSS hash value calculated for a packet. This field should be ignored when the RSS Hash Valid flag bit is zero.
- The Opaque field is reserved for the host software driver. Any data placed in this field in a producer ring descriptor will be passed through unchanged to the corresponding return ring descriptor.

#### 4.2.4.4 Additional Ring Information for the BCM571X/BCM5720 Family

Rings in the BCM571X/BCM5720 Family are more complicated than in previous NetXtreme controllers. Before considering ring structure details, first choose the mode of operation:

- Legacy
- **RSS**
- **RSS+TSS**
- IOV

NOTE: RSS (and/or TSS) and IOV are mutually exclusive.

Once the mode of operation is decided, determine if jumbo frames are to be used.

Setting ring sizes involves setting some ring sizes (such as the Rx Producer Rings) in registers and setting other ring sizes (such as the Rx Return Rings) in memory locations (for example, the upper 16 bits of the 32-bit value at memory offset 0x208 for Rx Return Ring number 0, rather than in a register). See Appendix C: "Device Register and Memory Map," on page 513 for more information. A Ring Control Block (RCB) consists of four 32-bit words:

- host address high
- host address low
- len/flags
- NIC ring address

For example, the RX Return Ring size is set in the high 16 bits of 32bit value in device memory offset 0x208.

571X-5720-PG101 Broadcom

If using RSS or IOV, there are either 4 or 17 Rx Return and Producer rings. The 17th Rx ring is a default throw-away ring for any Rx traffic that does not map to rings 0-3 (RSS) or 0-15 (IOV). Driver software only pulls valid Rx BDs from 16 Rx Ret Rings (rings 0-15) in IOV mode.

For Rx Producer Rings, there are only 1 or 2 in non-IOV mode (the second one dedicated to the driver to supply jumbo Rx BDs to the chip, if using jumbo frames). In RSS mode, there are up to 4. In IOV mode, there are up to 16 (17, including the default ring).

The Tx path is simpler. Tx is 1 or 4 or 16 rings (legacy, TSS, or IOV) for giving Send BDs to the chip. Jumbo BDs go onto the same Send ring as non-jumbos. There are no separate jumbo-dedicated Send ring(s) like there are for Rx producer rings.

The max sizes of the various rings are as follows:

Rx Ret: 4096Rx Prod: 2048

Rx Prod Jumbo: 1024

Tx Prod: 512

As a maximum-use example, there can be an IOV implementation with the following total max ring size/count arrangement:

- 16 Send rings (size=512 each ring)
- 16 Rx Prod rings (size=2048 each ring)
- 16 Rx Prod jumbo rings (size=1024 each ring)
- 17 Rx Ret rings (size=4096 each ring)

### 4.3 Status Block

The Status Block is another shared memory data structure that is located in host memory. The Status Block is 32 bytes in length. Host software will need to allocate 32 bytes of non-paged memory space for the Status Block and set the Status Block Host Address register to point to the host memory physical address reserved for this structure.

The controller will update the Status Block to host memory prior to a host coalescing interrupt or MSI. The frequency of these Status Block updates is determined by the host coalescing logic (see "Host Coalescing Engine" on page 41). Using the software configurable coalescing parameters, the device driver can optimize the frequency of status block updates for a particular application or operating system.

The Status Block contains some of the Producer and Consumer indices for the rings described in "Descriptor Rings" on page 48. These Producer and Consumer indices allow host software to know the current status of the controller is regarding its processing of the various send and receive rings. From information in the status block a software driver can determine:

- Whether the Status Block has been recently updated (via a bit in the status word).
- Whether the Link State has changed (via a bit in the status word).
- Whether the controller has recently received a packet and deposited that packet into host memory for a given ring (via the Receive Return Ring Producer Indices).
- Which host receive descriptors that controller has fetched, and it will consume when future packets are received (via the Receive Producer Ring Consumer Indices).
- Whether the controller has recently completed a transmit descriptor buffer DMA for a given ring (via the Send Ring Consumer Indices).

### 4.3.1 Status Block Format

**NOTE:** Reference registers 0x3C50-0x3CC0 for debug access to the various ring indices.

Each MSI-X vector is associated with a status-block structure. A status block is DMAed to the host memory immediately before raising a legacy style interrupt (INTx, MSI) or MSI-X interrupt. Status block formats vary depending on RSS and the MSI-X vector number.

The various status block formats are shown in this section.

### 4.3.1.1 INTx/MSI — Legacy Mode Status Block Format

INTx and MSI use this status-block format in non-RSS mode.

Table 14: Status Block Format (MSI-X Single-Vector or INTx — RSS Mode)

| Offset | 31                                           | 16 | 15                                  | 0               |
|--------|----------------------------------------------|----|-------------------------------------|-----------------|
| 0x00   | Status Word                                  |    |                                     |                 |
| 0x04   | [31:8] Reserved 0x0                          |    |                                     | [7:0]Status Tag |
| 80x0   | Receive Standard Producer Ring Consumer Inde | X  | Reserved 0x0                        |                 |
| 0x0C   | Reserved 0x0                                 |    | Reserved 0x0                        |                 |
| 0x10   | Send BD Consumer Index                       |    | Receive Return Ring Producer Index  |                 |
| 0x14   | Reserved 0x0                                 |    | Receive Jumbo Producer Ring Consume | er Index        |

Status-Block [0] Status Word Format (single-vector RSS):

■ Bit [0]: Update bit

Bit [1]: Link status change

■ Bit [2]: Error/attention

■ Bits [31:3]: Reserved 0x0

### 4.3.1.2 Single-Vector or INTx — RSS Mode Status Block Format

In the single-vector RSS mode, the status-block format used by Vector#0 is shown below.

INTx and MSI also use this status-block format.

Table 15: Status Block Format (MSI-X Single-Vector or INTx — RSS Mode)

| Offset | 31                                          | 16  | 15                                   |                 |
|--------|---------------------------------------------|-----|--------------------------------------|-----------------|
| 0x00   | Status Word                                 |     |                                      |                 |
| 0x04   | [31:8] Reserved 0x0                         |     |                                      | [7:0]Status Tag |
| 80x0   | Receive Standard Producer Ring Consumer Inc | dex | Receive Return Ring 1 Producer Index |                 |
| 0x0C   | Receive Return Ring 2 Producer Index        |     | Receive Return Ring 3 Producer Index |                 |
| 0x10   | Send BD Consumer Index                      |     | Receive Return Ring 0 Producer Index |                 |
| 0x14   | Reserved 0x0                                |     | Receive Jumbo Producer Ring Consume  | er Index        |

Status-Block [0] Status Word Format (single-vector RSS):

■ Bit [0]: Update bit

■ Bit [1]: Link status change

■ Bit [2]: Error/attention

■ Bits [31:3]: Reserved — always 0x0

### 4.3.1.3 Multivector RSS Mode Status Block Format

There are five slightly different status-block formats used by the multivector RSS mode. Each of these formats associates with their respective vector numbers as shown in the tables below.

Table 16: Status Block [0] Format (MSI-X Multivector RSS Mode)

| Offset | 31 16                                         | 15                                  | 0               |
|--------|-----------------------------------------------|-------------------------------------|-----------------|
| 0x00   | Status Word                                   |                                     |                 |
| 0x04   | [31:8] Reserved 0x0                           |                                     | [7:0]Status Tag |
| 80x0   | Receive Standard Producer Ring Consumer Index | Reserved 0x0                        |                 |
| 0x0C   | Reserved 0x0                                  | Reserved 0x0                        |                 |
| 0x10   | Send BD Consumer Index                        | Reserved 0x0                        |                 |
| 0x14   | Reserved 0x0                                  | Receive Jumbo Producer Ring Consume | er Index        |

Status-Block [0] Status Word Format (multivector RSS):

- Bit [0]: Update bit
- Bit [1]: Link status change
- Bit [2]: Error/attention
- Bits [3]: Reserved always 0
- Bits [4]: Reserved always 0
- Bits [5]: Reserved always 0
- Bits [31:6]: Reserved 0x0

Table 17: Status Blocks [1 thru 4] Formats (MSI-X Multivector RSS Mode)

| Offset | 31                                                                              | 16 | 15                                                                             | 0                                                              |
|--------|---------------------------------------------------------------------------------|----|--------------------------------------------------------------------------------|----------------------------------------------------------------|
| 0x00   | Status Word (Valid for all Status Blocks)                                       |    |                                                                                |                                                                |
| 0x04   | [31:8] Reserved 0x0                                                             |    |                                                                                | [7:0] Status Tag[n]<br>{independent for each<br>status blocks} |
| 0x08   | Reserved 0x0                                                                    |    | Receive Return Ring 1 Producer Index<br>Valid only for Status Block2 else RSVD | 0x0                                                            |
| 0x0C   | Receive Return Ring 2 Producer Index Valid only for Status Block3 else RSVD 0x0 |    | Receive Return Ring 3 Producer Index<br>Valid only for Status Block4 else RSVD | 0x0                                                            |
| 0x10   | Reserved 0x0                                                                    |    | Receive Return Ring 0 Producer Index<br>Valid only for Status Block1 else RSVD | 0x0                                                            |
| 0x14   | Reserved 0x0                                                                    |    | Reserved 0x0                                                                   |                                                                |

Status-Block [1-4] Status Word Format (multivector RSS):

- Bit [0]: Update bit
- Bit [31:1]: Reserved 0x0

### 4.3.1.4 Status Block and INT MailBox Addresses

Each status block may be placed in an independent host memory address (64-bit). Each vector may be acknowledged via associated INT MailBoxes.

Table 18: Status Block Host Addresses and INT MailBox Addresses

|                | Status Block Host |                                 | RSS Mode              | Comments                                             |  |
|----------------|-------------------|---------------------------------|-----------------------|------------------------------------------------------|--|
| Status Block # | Address Register  | INT MailBox<br>Register Address | Indication<br>Items   |                                                      |  |
| Legacy         | 0x3C3C, 0x3C38    | 0x200                           | All                   | Legacy status block                                  |  |
|                |                   |                                 |                       | Used by INTx or MSI                                  |  |
| 0              | x3C3C, 0x3C38     | 0x200                           | Link-Status change    | Used in all MSI-X modes for Vector#0                 |  |
|                |                   |                                 | Error/Attention       |                                                      |  |
|                |                   |                                 | SBD Ring 1 Cons Index |                                                      |  |
|                |                   |                                 | Std RBD Cons Index    |                                                      |  |
|                |                   |                                 | Jmb RBD Cons Index    |                                                      |  |
| 1              | 0x3D00, 0x3D04    | 0x208                           | Rx Return Ring 0      | Used only in MSI-X multivector RSS                   |  |
|                |                   |                                 | Prod Index            | mode or multivector EAV mode for                     |  |
| 2              | 0x3D08, 0x3D0C    | 0x210                           | Rx Return Ring 1      | Vector#1-Vector#4                                    |  |
|                |                   |                                 | Prod Index            |                                                      |  |
| 3              | 0x3D10, 0x3D14    | 0x218                           | Rx Return Ring 2      |                                                      |  |
|                |                   |                                 | Prod Index            |                                                      |  |
| 4              | 0x3D18, 0x3D1C    | 0x220                           | Rx Return Ring 3      |                                                      |  |
|                |                   |                                 | Prod Index            |                                                      |  |
| 5              | 0x3D20, 0x3D24    | N/A                             | N/A                   | Used only in MSI-X multivector EAV mode for Vector#5 |  |

The Status word field contains bit flags that contain error information about the status of the controller. The defined flags are listed in Table 19.

Table 19: Status Word Flags

| Bits | Name               | Description                                                                                                                                                                                                                                                                                                                                                          |  |  |
|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0    | Updated            | This bit is always set to 1 each time the status block is updated in the host via DMA. It is expected that host software clear this bit in the status block each time it examines the status block. This provides the host driver with a mechanism to determine whether the status block has been updated since the last time the driver looked at the status block. |  |  |
| 1    | Link State Changed | Indicates that link status has changed. This method of determining link change status provides a small performance increase over doing a PIO read of the Ethernet MAC Status register (see "EMAC Status Register (offset: 0x404)" on page 273. See "Wake on LAN Mode/Low-Power" on page 181 for a description of the PHY setup required when link state changes.     |  |  |
| 2    | Error              | When this bit is asserted by the chip, the following conditions may have occurred. Bit 2 of the status word is the OR of:                                                                                                                                                                                                                                            |  |  |
|      |                    | <ul> <li>All bits in Flow Attention register (0x3c48) (see "Flow Attention Register (offset: 0x3C48)" on<br/>page 376.</li> </ul>                                                                                                                                                                                                                                    |  |  |
|      |                    | <ul> <li>MAC_ATTN—Events from the MAC block (see "EMAC Status Register (offset: 0x404)" on<br/>page 273.</li> </ul>                                                                                                                                                                                                                                                  |  |  |
|      |                    | ■ DMA_EVENT—Events from the following blocks:                                                                                                                                                                                                                                                                                                                        |  |  |
|      |                    | <ul> <li>MSI (see "MSI Status Register (offset: 0x6004)" on page 415.</li> </ul>                                                                                                                                                                                                                                                                                     |  |  |
|      |                    | <ul> <li>DMA_RD (see "LSO Read DMA Status Register (offset: 0x4804)" on page 387.</li> </ul>                                                                                                                                                                                                                                                                         |  |  |
|      |                    | <ul> <li>DMA_WR (see "Write DMA Status Register (offset: 0x4C04)" on page 401.</li> </ul>                                                                                                                                                                                                                                                                            |  |  |
|      |                    | ■ RXCP_ATTN—Events from RX RISC (see "RX RISC Status Register (offset: 0x5004)" on page 403.                                                                                                                                                                                                                                                                         |  |  |

The Status Block format for these devices is as follows:

- Status Tag—Contains a unique eight-bit tag value in bits 7:0 when the Status Tagged Status mode bit of the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245) is set to 1. This Status Tag can be returned to the Mailbox 0 register at location 31:24 (see "Interrupt Mailbox 0 Register (offset: 0x5800)" on page 409) by host driver. When the remaining Mailbox 0 register bits 23:0 are written as 0, the tag field of the Mailbox 0 register is compared with the tag field of the last status block to be DMAed to host. If the tag returned is not equivalent to the tag of the last status block DMAed to the host, the interrupt state is entered.
- Receive Producer Ring Consumer Index—Contains the controller's current Consumer Index value for the Receive Producer Ring. This field indicates how many receive descriptors are in the receive producer ring that the controller has consumed. For more information regarding this ring, see "Receive Producer Ring" on page 56.
- Receive Return Rings 0–3 Producer Indices—Contain controller's current Producer Index value for each of the Receive Return Rings. When the controller receives a packet and writes that packet data into host memory via DMA, it will increment the Producer Index for the corresponding Receive Return ring. When a Producer Index is incremented, it is a signal to software that a newly arrived receive packet is ready to be processed.
- Send Ring Consumer Index—Contains controller's current Consumer Index value for the Send Ring. When the controller completes the read DMA of the host buffer associated with a send BD, the controller will update the Send Ring Consumer Index. This provides the host software with an indication that the controller has buffered this send data and, therefore, the host software may free the buffer that was just consumed by the device.

# **Chapter 5: Receive Data Flow**

### 5.1 Introduction

The RX MAC pulls BDs from RX producer rings. The RX BD specifies the location(s) in host memory where packet data may be written. Figure 14 on page 67 shows the receive buffer descriptor cycle.

All ingress Ethernet frames are classified by the RX rules engine. A class ID is associated with each frame based on QoS rules set up in the RX MAC (see "Receive Rules Setup and Frame Classification" on page 73). The Receive List Placement and Receive List Initiator portions of the MAC architecture move BDs to the RX return rings; the class ID associated with the packet is examined to route the BD to a specific RX return ring.

Once the packet is queued to the RX return ring, the device driver will wait for indication of the same through the status block update and interrupt from the host coalescing engine. The host coalescing engine will update the status block and generate a line interrupt or MSI (see "Host Coalescing" on page 202 for further details regarding interrupts) when a specified host coalescence criteria is met. Once the interrupt is generated, the host device driver will service the interrupt. The ISR will determine if new BDs have been completed on the RX Return Rings. Next, the device driver will indicate to the network protocol that the completed RX packets are available. The network protocol will consume the packets and return physical buffers to the network driver at a later point.

The BDs may then be reused for new RX frames. The device driver must return the BD to an RX producer ring. For this purpose, the driver should fill out either the opaque field or index field of the Rx BD when inserting/initializing the BD in an RX Producer ring. When the BD is returned by the device through Return Ring, the opaque or index data field of the BD will be used by the driver to identify the BD in Producer Ring that corresponds to the Returned BD in Return Ring. The device driver will then reinitialize the identified BD in Producer Ring with a new allocated buffer and replenish the Receive Producer Ring with this BD.

Figure 14: Receive Buffer Descriptor Cycle



# 5.2 Receive Producer Ring

A Receive Producer Ring is an array containing a series of Receive Buffer Descriptors (BD). The Receive Producer Ring is host-based and a portion of the available buffer descriptors are cached in Ethernet controller internal memory.

A receive producer ring contains a series of buffer descriptors which in turn contain information on host memory locations to where packets are placed by the Ethernet controller at reception.

### 5.2.1 Setup of Producer Rings Using RCBs

A Ring Control Block (RCB) is used by the host software to set up the shared rings in host memory. In the context of producer ring, the Receive Producer Ring RCB is a set of registers (or internal device memory offsets) used to define the Receive Producer Ring. The host software must initialize the Receive Producer Ring RCB.

### 5.2.1.1 Receive Producer Ring RCB—Register Offset 0x2450-0x245f

#### 5.2.1.1.1 Other Considerations Relating to Producer Ring Setup

Other registers that affect the producer rings must be initialized by the host software. These registers include the Receive BD Ring Replenish Threshold register, the Receive MTU register, and the Accept Oversized bit (bit 5) in the Receive MAC Mode register.

- Receive BD Producer Ring Replenish Threshold registers:
  - "Standard Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C18)" on page 330
  - "Receive Data Completion Control Registers" on page 328.

These registers are used for setting the number of BDs that the Ethernet controller can use up before requesting that more BDs be DMAed from a producer ring. In other words, the device does not initiate a DMA for fetching the Rx BDs until the number of BDs made available to the device by the host is at least the value programmed in this register.

- Receive MTU register ("Receive MTU Size Register (offset: 0x43C)" on page 277). This 32-bit register is set to a value that is the maximum size of a packet that the Ethernet controller receives. Any packets above this size are labeled as an oversized packet. The value for this register is typically set to 1522, which is the Standard Producer Ring RCB typical setting. If Jumbo frames are supported, the MTU would be set to the maximum Jumbo frame size.
- Receive MAC Mode register ("Receive MAC Mode Register (offset: 0x468)" on page 282). If the Accept Oversized bit (bit 5) of this register is set, the Ethernet controller accepts packets (of size up to 64 KB) larger than the size specified in the MTU.

#### 5.2.1.2 RCB Setup Pseudo Code

An example of setting up receive producer ring RCB:

```
Content of Pointer_to_RX_PRODUCER_RING_RCB + 0x00 = Host address of standard receive producer ring high 32.

Content of Pointer_to_RX_PRODUCER_RING_RCB + 0x04 = Host address of standard receive producer ring low 32.

Content of Pointer_to_RX_PRODUCER_RING_RCB + 0x0a = No flags.

Content of Pointer_to_RX_PRODUCER_RING_RCB + 0x08 = Max packet size of 1522.

Content of Pointer_to_RX_PRODUCER_RING_RCB + 0x0c = Internal Memory address for device copy of ring.
```

Figure 15 shows the standard ring RCB for the setup of a host-based standard producer ring.

Receive Buffer Descriptors (BDs) begin on the Receive Producer Ring. The host device driver will populate the receive producer ring with a specified number of BDs supported by the receive producer ring (see "Receive MTU Size Register (offset: 0x43C)" on page 277). When a packet is received, the RX MAC moves the packet data into internal memory. The Receive MTU Size register (see "Receive MTU Size Register (offset: 0x43C)" on page 277) specifies the largest packet accepted by the RX MAC; packets larger than the Receive MTU are marked oversized and are discarded.

Figure 15: Receive Producer Ring RCB Setup



# 5.2.2 Receive Buffer Descriptors

The Receive Buffer Descriptor is a data structure in host memory. It is the basic element that makes up each receive producer and receive return ring. The format of receive buffer descriptors can be seen in Table 11 on page 57. A receive buffer descriptor has a 64-bit memory address and may be in any memory alignment and may point to any byte boundary. For performance and CPU efficiency reasons, it is recommended that memory be cache-aligned. The cache line size value is important for the controller to determine when to use the PCI memory write and invalidate command. There are no requirements for memory alignment or cache line integrity for the Ethernet controller.

Unlike send buffer descriptors, the receive buffer descriptors cannot be chained to support multiple fragments.

### 5.2.3 Management of Rx Producer Rings with Mailbox Registers and Status Block

#### 5.2.3.1 Status Block

The host software manages the producer rings through the Mailbox registers and by using the status block. It does this by writing to the Mail Box registers when a BD is available to DMA to the Ethernet controller and reading the status block to see how many BDs have been consumed by the Ethernet controller. The status block can be seen in "Status Block" on page 60.

The status block is controlled and updated by the Ethernet controller. The status block in host memory is constantly updated through a DMA copy by the Ethernet controller from an internal status block. The updates occur at specific intervals and host coalescence conditions that are specified by host software during initialization of the Ethernet controller. The registers for setting the intervals and conditions are in the Host Coalescing Control registers (see "Host Coalescing" on page 202) starting at memory offset 0x3c00. The Ethernet controller DMAs an updated status block to the 32-bit address that is set by the host software in the Host Coalescing Control registers, 0x3c38.

Among other status, the status block displays the last 16-bit value, BD index that was DMAed to the Ethernet controller from receive producer ring. The Ethernet controller updates these indices as the recipient or consumer of the BD from the producer rings.

#### **5.2.3.2** Mailbox

The host software is responsible for writing to the Mailbox registers (see Table 20) when a BD is available from the producer rings for use by the Ethernet controller. Host software should use the high-priority mailbox region from 0x200–0x3FF for host standard and the low-priority mailbox region from 0x5800–0x59FF for indirect register access mode.

The Mailbox registers (starting at memory offset 0x200 for host standard and offset 0x5800 for indirect mode) contain the following receive producer index register.

#### 5.2.3.2.1 Receive BD Producer Ring Producer Index

- Host standard: memory offset 0x268–0x26F
- Indirect mode: memory offset 0x5868-0x586F

**Table 20: Mailbox Registers** 

| Offset<br>(High-Priority<br>Mailboxes for Host<br>Standard Mode) | Offset<br>(Low-Priority<br>Mailboxes for<br>Indirect Mode) | Register                                         | Access |
|------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------|--------|
| 0x200-0x207                                                      | 0x5800-0x5807                                              | Interrupt Mailbox 0                              | RW     |
| 0x208-0x20F                                                      | 0x5808-0x580F                                              | Interrupt Mailbox 1                              | RW     |
| 0x268-0x26F                                                      | 0x5868-0x586F                                              | Receive BD Standard Producer Ring Producer Index | RW     |
| 0x280-0x287                                                      | 0x5880-0x5887                                              | Receive BD Return Ring 1 Consumer Index          | RW     |
| 0x288-0x28F                                                      | 0x5888-0x588F                                              | Receive BD Return Ring 2 Consumer Index          | RW     |
| 0x290-0x297                                                      | 0x5890-0x5897                                              | Receive BD Return Ring Consumer Index            | RW     |

The Receive Producer Ring Producer Index register contains the index value of the next buffer descriptor from the producer ring that is available for DMA to the Ethernet controller from the host. When the host software updates the Receive Producer Ring Producer Index, the Ethernet controller is automatically signaled that a new BD is waiting for DMA. At initialization time, these values must be initialized to zero. These indices are 64-bit wide.

# 5.3 Receive Return Rings

Receive Return Rings (RR) are host-based memory blocks that are used by host software to keep track of where the Ethernet controller is putting the received packets related receive buffer descriptors. Unlike the producer rings, the return rings reside only in host memory. The Ethernet controller uses the BDs in the NIC memory that are previously copied from the producer rings to use when packets are received from the LAN. It places the BDs that correspond to received packets in the return rings.

Return rings are the exact opposite of producer rings, except that they are not categorized by the maximum length receive packets supported. They are categorized by priority or class of received packet. The highest priority return ring is ring 1, and the lowest priority is the last ring (Return Ring 2–Return Ring 4 depending on how many rings are set up by the host software).

The Receive Return Ring RCBs are used to set up return rings in much the same way the Receive Producer Ring RCB is used to set up the receive producer ring. These RCBs for the return rings are set in the Miscellaneous memory region (SSRAM) at offset 0x200 (this region should not be confused with the register space in the chip). The RCB max\_len field is used to indicate the number of buffer descriptor entries in a return ring. If an invalid value is set, the Ethernet controller indicates an attention error in the Flow Attention register. Figure 13 on page 56 shows receive return rings.

### 5.3.1 Management of Return Rings with Mailbox Registers and Status Block

The return rings are managed by the host using the Mailbox registers and status block.

When a packet is received from the LAN, the Ethernet controller DMAs the packet to a location in the host, and then DMAs the related BD to a return ring. As the producer of this packet to the host, the Ethernet controller updates the status block producer indices for the related return ring (i.e., return ring 1 to return ring 4 that was DMAed the BD received packet). These return ring indices can then be read by the host software to determine the last BD index value of a particular ring that has information on the last received packet.

As the consumer of the received packet, the host software must update the return ring consumer indices in Mailbox registers Receive BD Return Ring 1 Consumer Index (memory offset 0x280–0x287 for host standard and 0x5880–0x5887 for indirect mode) through Receive BD Return Ring 4 Consumer Index.

### 5.3.2 Host Buffer Allocation

The allocation of memory in the host is dependent on the operating system in which the controller is being used. There are two crucial items:

- The use of non-cached and physically contiguous memory is best for adapter performance.
- Physical memory mapping is required for the controller's internal copies of logical host memory.

## 5.3.3 Receive Rules Setup and Frame Classification

The Ethernet controller has a feature that allows for the classification of receive packets based on a set of rules. The rules are determined by the host software and then input into the Ethernet controller.

A packet can be accepted or rejected based on the rules initialized into two rules register areas. The packets can also be classified into groups of packets of higher to lower priority using the rules registers. This occurs when the packet is directed to a specific return ring. Return rings 1–4 have an inherent priority associated with them. The priority is from lowest ring number to highest ring number; return ring 1 being the highest priority ring and return ring 4 being the lowest. The implementation of priority class is based on how many rings the host software has initialized and made available to the Ethernet controller. As packets arrive, the Ethernet controller may classify each packet based on the rules. When the host services the receive packet, it can service the lower numbered rings first.

A rule can be changed by first disabling it by setting 0 into Enable bit (bit 31) in Receive BD Rules Control register (see Table 22 on page 74). Wait about 20 receive clocks (rx\_clock) and then reenable it when it is programmed with a new rule. Otherwise, changing the rules dynamically during runtime may cause the rule checker to output erroneous results because the rule checker is a pipelined design and uses the various fields of the rules at different clock cycles.

## 5.3.3.1 Receive Rules Configuration Register

The Receive Rules Configuration register (memory offset 0x500–0x503, see Table 21) uses bits 3:7 to specify the ring where a received packet should be placed if no rules are met, or if the rules have not been set up. A value of 0 means the received packet will be discarded. A value of 1–16 specifies a corresponding ring. This ring should be initialized to at least a value of 1 if the rules are not being used to ensure that all received packets will be DMAed to return ring 1.

Table 21: Receive Rules Configuration Register

| Bits | Field                                                      | Access |
|------|------------------------------------------------------------|--------|
| 31:8 | Reserved                                                   | RO     |
| 7:3  | Specifies the default class (ring) if no rules are matched | RW     |
| 2:0  | Reserved                                                   | RO     |

## 5.3.3.2 Receive List Placement Rules Array

The Receive List Placement Rules Array (memory offset 0x480–0x4ff) is made up of 16 combined element registers. The combined element is actually two 32-bit registers called the Receive BD Rules Control register (see Table 22) and the Receive BD Rules Value/Mask register (see Table 24 on page 75). The element can be looked at as a single 64-bit entity with a Control part and Value/Mask part since they use a single element. Bit 26 of the control part determines how the value/mask part is used. The Receive BD Rules Value/Mask register can be used as either a 32-bit left-justified Value or a 16-bit Mask followed by a 16-bit Value.

**NOTE:** Receive rules cannot be used to match VLAN headers because the VLAN tag is stripped from the Ethernet frame before the rule checker runs.

Table 22: Receive BD Rules Control Register

| 31 | 30     | 29 | 28    | 27 | 26 | 25 | 24  | 23  | 22  | 21   | 20    | 19 | 18 | 17 | 16 |
|----|--------|----|-------|----|----|----|-----|-----|-----|------|-------|----|----|----|----|
| E  | &      | P1 | P2    | P3 | М  | D  | Мар |     |     | Rese | erved |    |    | 0  | )p |
|    |        |    |       |    |    |    |     |     |     |      |       |    |    |    |    |
| 15 | 14     | 13 | 12    | 11 | 10 | 9  | 8   | 7   | 6   | 5    | 4     | 3  | 2  | 1  | 0  |
|    | Header |    | Class |    |    |    |     | Off | set |      |       |    |    |    |    |

Table 23: Receive List Placement Rules Array (memory offset 0x480-0x4ff)

| Bit   | Name     | RW | Description                                                                                                                                                                                                                                                                            | Default |  |  |  |  |  |
|-------|----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--|--|--|
| 31    | E        | RW | Enable. Enabled if set to 1                                                                                                                                                                                                                                                            | _       |  |  |  |  |  |
| 30    | &        | RW | And With Next. This rule and next must both be true to match. The class fields must be the same. A disabled next rule is considered true. Processor activation bits are specified in the first rule in a series.                                                                       | _       |  |  |  |  |  |
| 29    | P1       | RW | f the rule matches, the processor is activated in the queue descriptor for the Receive List - Placement state machine.                                                                                                                                                                 |         |  |  |  |  |  |
| 28    | P2       | RW | If the rule matches, the processor is activated in the queue descriptor for the Receive Data and Receive BD Initiator state machine.                                                                                                                                                   | _       |  |  |  |  |  |
| 27    | P3       | RW | If the rule matches, the processor is activated in the queue descriptor for the Receive Data Completion state machine.                                                                                                                                                                 | _       |  |  |  |  |  |
| 26    | М        | RW | Mask If set, specifies that the value/mask field is split into a 16-bit value and 16-bit mask instead of a 32-bit value.                                                                                                                                                               |         |  |  |  |  |  |
| 25    | D        | RW | Discard Frame if it matches the rule.                                                                                                                                                                                                                                                  | _       |  |  |  |  |  |
| 24    | Мар      | RW | Map Use the masked value and map it to the class.                                                                                                                                                                                                                                      | _       |  |  |  |  |  |
| 23:18 | Reserved | RW | Must be set to zero.                                                                                                                                                                                                                                                                   | 0       |  |  |  |  |  |
| 17:16 | Ор       | RW | Comparison Operator specifies how to determine the match:  00 = Equal  01 = Not Equal  10 = Greater than  11 = Less Than                                                                                                                                                               | _       |  |  |  |  |  |
| 15:13 | Header   | RW | Header Type specifies which header the offset is for:  000: Start of Frame (always valid)  001: Start of IP Header (if present)  010: Start of TCP Header (if present)  011: Start of UDP Header (if present)  100: Start of Data (always valid, context sensitive)  101–111: Reserved | -       |  |  |  |  |  |

#### Table 23: Receive List Placement Rules Array (memory offset 0x480-0x4ff) (Cont.)

| Bit  | Name   | RW | Description                                                                                                                                                                                                                                                                 | Default |
|------|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 12:8 | Class  |    | The class this frame is placed into if the rule matches. 0:4, where 0 means discard. The number of valid classes is the Number of Active Queues divided by the Number of Interrupt Distribution Groups. Ring 1 has the highest priority and Ring 4 has the lowest priority. | _       |
| 7:0  | Offset | RW | Number of bytes offset specified by the header type.                                                                                                                                                                                                                        | _       |

#### Table 24: Receive BD Rules Value/Mask Register

| 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------------------------------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
|    |                                       |    |    |    |    |    | Ma | ask |    |    |    |    |    |    |    |
|    |                                       |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
| 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|    | Value                                 |    |    |    |    |    |    |     |    |    |    |    |    |    |    |

| Bit   | Name  | RW | Description | Default |
|-------|-------|----|-------------|---------|
| 31:16 | Mask  | _  | -           | _       |
| 15:0  | Value | _  | _           | _       |

## 5.3.3.3 Class of Service Example

If either Start of IP Header, Start of TCP Header, or Start of UDP Header is specified, and the frame has no IP, TCP, or UDP header, respectively, there is no frame match. The full set of rules provides a fairly rich selection and filtering criteria.

**Example:** If you wanted to set a Class of Service (CoS) of 2 based on the eighth byte in the data portion of an encapsulated IPX frame using Ethernet Type 2 having a value greater than 6, you could set up the rules shown in Figure 16 on page 76.

Figure 16: Class of Service Example



## 5.4 Checksum Calculation

Whether the host software NOS supports checksum offload or not, the Ethernet controller automatically calculates the IP, TCP, and UDP of received packets as described in RFC 791, RFC 793, and RFC 768, respectively.

Which protocol checksum value is produced can be determined by reading the status flag field in the Receive Return Ring. The valid flag values in the status flag field are IP\_CHECKSUM and TCP\_UDP\_CHECKSUM. When a valid checksum is produced, the values of the checksums are found in the corresponding receive buffer descriptor register. These values should be 0xFFFF for a valid checksum or any other value if the checksum was incorrectly calculated. Assert the Receive No Pseudo-header Checksum bit of the Mode Control register (see "Mode Control Register (offset: 0x6800)" on page 416) to not include Pseudo-header in TCP/UDP checksums.

# 5.5 VLAN Tag Strip

Receiving VLAN-tagged (IEEE 802.1q-compliant) packets are automatically supported by the Ethernet controller. There is no register or setting required to receive packets that are VLAN-tagged. The VLAN tag is automatically stripped from the IEEE 802.1q-compliant packet at reception and then placed in a receive buffer descriptor's two byte VLAN tag field. The flag field has the BD\_FLAGS\_VLAN\_TAG bit set when a valid VLAN packet is received. After the packet has been serviced by the host software, these fields should be zeroed out.

In the Receive MAC Mode register (offset 0x468–0x46b), the Keep VLAN Tag Diag Mode bit (bit 10) can be set to force the Ethernet controller to not strip the VLAN tag from the packet. This is only for diagnostic purposes.

Table 25 shows the frame format with IEEE 802.1Q VLAN tag inserted.

## Table 25: Frame Format with 802.1Q VLAN Tag Inserted

| Offset  | Description                      |
|---------|----------------------------------|
| 0:5     | MAC destination address          |
| 6:11    | MAC source address               |
| 12:13   | Tag Protocol ID (TPID)—0x8100    |
| 14:15   | Tag Control Information (TCI):   |
|         | ■ Bit 15:13—IEEE 802.1P priority |
|         | ■ Bit 12—CFI bit                 |
|         | ■ Bit 11:0—VLAN ID               |
| 16:17   | The original EtherType           |
| 18:1517 | Payload                          |

# 5.6 RX Data Flow Diagram

The receive data flow can be summarized in Figure 17. The Receive Producer Ring, Receive Buffer Descriptors, Receive Return Rings, Mailbox registers, and status block registers are the main areas of the receive data flow.

Figure 17: Overview Diagram of RX Flow



The RX flow sequence is as follows:

- 1. The host software updates a Receive Producer Ring Index in the Mailbox registers.
- 2. A receive BD or series of BDs with the corresponding index is DMAed to the Ethernet controller from the host-based Receive Producer Ring.
- 3. The Ethernet controller updates the Receive Consumer Index in the Host Block register and stores copy of the BD.
- 4. A valid Ethernet packet is received from the network into the device.
- 5. The Ethernet packet is DMAed to host memory using a BD previously DMAed from a Receive Producer Ring.
- 6. The BD used for the received packet is DMAed from the Ethernet controller to one of the receive return rings, and the Receive Return Ring Producer Index register in the host status block is updated by the Ethernet controller.

The host software must create an array of BD structures in host memory, referred to as a receive producer ring. Each receive buffer descriptor within a producer ring describes, among other things, the location of a host memory buffer that is used to store the packets received from the network. When the host software (as the producer) updates the mailbox register's producer ring index that corresponds to the receive producer ring, the Ethernet controller automatically DMAs the BD to itself from the host. When the DMA is completed, the Ethernet controller (as the consumer) updates the status block's receive consumer ring index to signal it successfully consumed the BD. The Ethernet controller keeps this BD in internal memory to know where to put a packet that is received from the network.

When a packet is received from the network, a BD gets updated with information regarding the received packet and the packet is DMAed to a location in host memory described by the BD. The Ethernet controller (as the producer) then updates the receive return ring producer index in the Status Block register corresponding to one of host memory's receive return rings, and DMAs the BD to that receive return ring.

It is the responsibility of the host software to setup, initialize, and manage the data structures in host memory, namely, the receive producer rings and the receive return rings. The producer/consumer indices in the mailbox and status block are read and updated by the host and Ethernet controller for this purpose.

# 5.7 Receive Side Scaling

#### 5.7.1 Overview

RSS is a scalable networking technology that enables receive packet processing to be balanced across multiple processors in the system while maintaining in-order delivery of the data. The RSS enables packets from a single network adapter to be processed in parallel on multiple CPUs/cores while preserving in-order delivery to TCP connections.

# 5.7.2 Functional Description

The figure below shows the processing of received packets when RSS is enabled. The RSS algorithm is based on a load-sharing algorithm and performs the following steps.

- Computes a hash on the incoming packet to produce a 32-bit Hash result.
- Performs a lookup in the load balancing table (also called indirection table) using the one to seven least significant bits of the Hash result to determine which of the n CPUs are processing the packet, where n is the number of CPUs assigned to process received packets.
- Adds a Base CPU Number to determine the exact CPU that will process the packet.

Figure 18: RSS Receive Processing Sequence



The devices implement the above RSS algorithm in hardware except for the step of adding the Base CPU Number to the value from Indirection Table. If required, the step of adding the Base CPU Number to the CPU Result can be done in the main Interrupt Service Routine to determine which CPU will process the packet.

#### 5.7.3 RSS Parameters

#### 5.7.3.1 Hash Function

The default hash function is the Toeplitz hash. No other hash functions are currently supported, so there is no configurable parameter.

### 5.7.3.2 Hash Type

The fields that are used to hash across the incoming packet. The 5 devices support all four hash types given below and the configuration bits for enabling/disabling these hash types are provided in Receive MAC Mode register at offset 0x468. Any combination of these hash types can be enabled:

- Four-tuple of source TCP Port, source IP version 4 (IPv4) address, destination TCP port, and destination IPv4 address.
- Four-tuple of source TCP Port, source IP version 6 (IPv6) address, destination TCP port, and destination IPv6 address.
- Two-tuple of source IPv4 address and destination IPv4 address.
- Two-tuple of source IPv6 address and destination IPv6 address.

**NOTE:** The BCM5719 and BCM5720 add support for UDP RSS hash functionality, in addition to the legacy TCP RSS hash functionality.

#### **5.7.3.3 Hash Mask**

The RSS Hash Mask bits (bits 22:20 of the Receive MAC Mode register at offset 0x468) allow the configuration of the number of hash-result bits that are used to index into the indirection table.

#### 5.7.3.4 Indirection Table

The table of CPU numbers used for balancing the receive traffic across multiple processors. The Indirection Table registers 0–15 at offset 0x630–0x66F are implemented for the required 128 entries of the Indirection Table. The devices support only four Receive Return Rings so each entry of Indirection Table is implemented as 2 bits.

#### 5.7.3.5 Secret Hash Key

The hash key that will be used for RSS hash. For the Toeplitz hash, the hash key size is 40 bytes for IPv6 and 16 bytes for IPv4. The host software should program the hash key in hash key registers at offset 0x670 to 0x697.

#### 5.7.4 RSS Initialization

The host protocol stack should configure the above RSS parameters before enabling the RSS engine. The RSS can be enabled by setting the bit-23 of the Receive MAC Mode register at offset 0x468. Normally the RSS parameters except the Indirection Table are static and will be initialized only during device driver initialization. Though extremely rare, the protocol stack may change the RSS parameters at any time. The devices require a reset to change any of the hash type, hash mask, and hash key parameters.

If the hash type flags in Receive MAC Mode register (offset 0x468) enable only one type of hash, then any received packet that does not match the enabled hash type is not hashed. If multiple flags are set, such as If the TCP/IPv4 and IPv4 hash types (bits 17 and 16 of Receive MAC Mode register at offset 0x468) are enabled, then if the packet is not a TCP/IPv4 packet but is an IPv4 packet, the hash is performed on just the IPv4 2-tuple. Further, for this setting of the hash type flags, if the incoming packet is not an IPv4 packet, then no hash is performed. Because a variety of hash types can be applied on a perpacket basis (including no hash), the hash type is indicated to the host protocol stack on a per-packet basis. If no hash was performed, then none of the hash type flags in the receive BD will be set.

Once RSS is initialized and enabled, data transfer can begin. Over a period of time, the host protocol stack may modify the indirection table to re-balance the processing load. When the indirection table is changed, it is possible for a short period of time (while the current receive descriptor queues are being processed) for packets to be processed on the wrong CPU. This is a normal transient condition and should not be a problem.

### 5.7.5 RSS Rx Packet Flow

Each CPU or CPU core in multiprocessor systems is assigned one receive return ring. Only a single interrupt is initiated at a time.

- 1. As packets arrive, the device parses each packet, calculates the RSS Hash, and derives the CPU number (i.e., receive return ring number) from Indirection Table using the Masked Hash Result as the Indirection Table Index.
- 2. The packet data is DMAed to the host memory at the location specified by the receive buffer descriptor (RBD) of the receive producer ring.
- 3. Based on the derived CPU number, the device DMAs the used RBDs into appropriate receive return rings in host memory.
- 4. The device fires the interrupt via MSI, which causes the device driver ISR to run.
- The ISR disables further interrupts from the device, determines which CPUs have receive packets to be handled and
  uses inter-processor communication mechanisms to start packet receive handlers on CPUs whose return rings have new
  RBDs.
- 6. Each CPU processes the new RBDs in it's receive return ring when its packet handler routine is started by main ISR.
- 7. Once the main ISR determines that all new RBDs have been processed by the CPUs, it enables the interrupts from the device and exits.

# **Chapter 6: Transmit Data Flow**

## 6.1 Introduction

Send Buffer Descriptors (BDs) begin on the Send Producer rings. The device driver updates the Mailbox to reflect available Send BDs.

- The MAC moves the available Send BDs to device local memory—a cache.
- Next, the MAC selects a BD from the internal cache using priority scheduling.

The physical address, programmed in the Send BD by the host device driver prior to the Mailbox update, contains the host memory location of the TX packet buffer. The MAC reads the address from Send BD and schedules a bus master DMA for reading the packet data from host buffer. The packet data will be moved into device internal buffers from host buffers by Read DMA engine, and all the read buffers of 1 packet are chained together into a cluster. This cluster is then sent to the transmit MAC which sends the packet data to the integrated PHY for transmission on Ethernet media.

The write DMA engine will subsequently update the status block to indicate that the Send BD was consumed. The host driver normally returns the packet buffers to the NOS/protocol so the next packet can reuse that host physical memory. The send BD is now available for the next TX packet.

# 6.2 Send Rings

The send rings are shared data structures that are used to describe a series of data buffers that will be transferred onto the network. The shared data structure is called the Ring Control Block (RCB), and the entries within a ring for describing the data buffers are called the Send Buffer Descriptors (Send BDs).

**NOTE:** The maximum number of Send BDs (buffer descriptors) for a single packet is (0.75)\*(ring size).

Associated with each ring are two indices that control its operation. These indices are the producer index and the consumer index, which are not shared between the host software and the Ethernet controller. In the case of send rings, the host software controls the producer index by adding elements (initializing a Send BD) to the ring. Similarly, the Ethernet controller controls the consumer index by removing elements (processing a Send BD) from the ring.

The host software is responsible for maintaining its producer index and updating it by writing to the send ring producer index mailbox register. The mailbox registers are described in registers "Send BD Ring Host Producer Index Register (offset: 0x5900)" on page 410 through "Send BD Ring Host Producer Index Register (offset: 0x300–0x307)" on page 271. The update actually triggers the Ethernet controller to process the send descriptors starting at its consumer index. As a descriptor is processed, the consumer index is incremented, and the new index is reflected in a new status block update. Status block is described in "Status Block" on page 60.

When the producer and consumer indices are equal, the ring is empty. When the producer index is one behind the consumer, the ring is full. Because of this configuration, the producer index always points to an empty slot. Thus, there will always be at least one empty slot in a ring.

Figure 19 illustrates the relationships between all the components of a send ring.

Figure 19: Relationships Between All Components of a Send Ring



# **6.2.1 Ring Control Block**

The Send Ring RCB contains a pointer to the first Send BD in the device and host memory, number of send BDs in the ring, and control flags (see "Send Rings" on page 83 for a full discussion of the send RCB). All the fields are in big-endian ordering as required by the Ethernet controller. The RCBs of the send rings are located in the device Miscellaneous Memory Region at offset 0x0100.

The devices support a host-based send ring. The Send BDs of the host-based Send Ring will be bus-mastered from host memory into device local memory. The device driver will program the BDs directly in its memory space and avoid programmed I/O to the MAC. The Max\_Len field in the RCB (see Figure 20) indicates the maximum number of BDs in the Send Ring. This field can be programmed to either 32, 64, 128, 256, 512, 1024, 2048, or 4096, depending on the type of ring for which the corresponding RCB applies.

Figure 20: Max\_Len Field in Ring Control Block



## 6.2.2 Host-Based Send Ring

The send buffer descriptors of host-based send ring reside in host memory.

The host-based send ring will have up to 512 buffer descriptors, which are periodically and transparently DMAed to a staging area inside the NIC internal memory where they are waiting to be consumed. The staging area can hold up to 128 entries per-ring, and Ethernet controller tries to keep the staging area full at all times by constantly monitoring the consumer and producer index (the algorithm for accomplishing this is beyond the scope of this manual). The staging areas are located at a starting offset 0x4000 of NIC memory. Figure 21 illustrates the relationship between the send buffer descriptors in host memory and the staging area in NIC memory.

When the host software initializes new buffer descriptors, its send ring producer index is incremented by the number of descriptors. The new index is then written to the corresponding send ring host producer index mailbox register starting at offset 0x300 for host standard (see "Send BD Ring Host Producer Index Register (offset: 0x300–0x307)" on page 271), which may trigger the Ethernet controller to DMA the descriptors to its staging area. Eventually, the buffer descriptors are processed, and the data associated with these descriptors is transferred onto the network.

Send Buffer Descriptors in **Send Buffer Descriptors in Host Memory NIC Memory** Consumer Send BD 1 Send BD 2 Send BD 1 Send BD 3 Send BD 4 **DMA** Send BD 5 Send BD n Send BD 6 Send BD n+1 Send BD n+2 Send BD 7 Send BD 8 Send BD 128 Send BD 512 Producer

Figure 21: Relationship Between Send Buffer Descriptors

The Ethernet controller maintains the send ring consumer index, which is incremented as it processes the descriptors. The Ethernet controller informs the host software of its progress by updating the send ring consumer index in the status block. The host software uses the send ring consumer index and its producer index to determine the empty slots in the ring. The Ethernet controller implements an algorithm that periodically DMAs the status block to host memory in an efficient manner.

# 6.3 Checksum Offload

As network speed increases, offloading is becoming an important feature, and the ability to offload tasks from the host processor aids in the efficiency of the host and overall system performance. To achieve a significant performance boost, most modern operating systems offer a mechanism for the TCP/IP protocol stack to offload checksum calculations to the device.

The host software can configure the Ethernet controller to calculate IP, TCP, and UDP checksum as described in RFC 791, RFC 793, and RFC 768 respectively. The first step in checksum calculation is determining the start of an IP and UDP datagram and TCP segment within a frame, which could vary depending on whether the frame is tagged (VLAN) or encapsulated with LLC/SNAP header. Then the checksum is computed from the start to the end of the datagram and inserted into the appropriate location in protocol header. Ethernet controller is designed to support checksum calculation on all frame types and also on IP datagram and TCP segments containing options.

For the Ethernet controller to compute the checksum and insert it into the outgoing frame, the host software must set the appropriate control bits in the send buffer descriptors associated with the frame and seed the checksum field with zero or with the pseudo header checksum.

The host software enables IP checksum calculation by setting the IP\_CHKSUM bits in all the send buffer descriptors associated with the frame. The Ethernet controller inserts the checksum into the checksum field of the IP header.

To enable TCP or UDP checksum calculation, the host software must set the TCP\_UDP\_CKSUM bit in all the send buffer descriptors associated with the frame containing the entire UDP datagram or TCP segment. The TCP and UDP checksum engines do not span IP fragmented frames.

The host software can configure the Ethernet controller to disable TCP or UDP pseudo-header checksum calculation by setting the Mode\_Control.Send\_No\_Pseudo\_Header\_Checksum bit. When set, the host software must seed the checksum field in the TCP or UDP header with the pseudo-header checksum. If the

Mode\_Control.Send\_No\_Pseudo\_Header\_Checksum is cleared, the Ethernet controller computes the checksum including the pseudo header and inserts it into the checksum field.

**NOTE:** In LSO enabled case, a driver needs to zero the TCP checksum field coming from upper layer of OS when doing TX CSO. Also, make sure to set bit-27 and bit-28 of 0x4800 when doing TX CSO in both LSO/Non LSO mode.

# 6.4 Large Segment Offload

In computer networking, large segment offload (LSO) is a technique for increasing outbound throughput of high-bandwidth network connections by reducing host CPU overhead. This is done by queuing up large TCP packets and letting the Ethernet controller split them into separate (smaller) TCP packets to be transmitted onto the network. The technique is also called TCP segmentation offload (TSO) or, more generically, LSO.

When large blocks of data are to be sent over a computer network they must be first broken down to smaller segments that can pass through all of the network elements such as routers and switches between the source and destination computers. This process is referred to as segmentation.

For example, a large TCP packet of 64 KB (65,536 bytes) of data is usually segmented into 46 segments of 1448 bytes each before being sent over the network through the Ethernet controller chip. With some intelligence in the controller, the host CPU can hand over a 64k byte TCP packet directly to the controller in a single transmit request and the controller can break the large TCP packet down into smaller segments of 1448 bytes, add the TCP, IP, and data link layer protocol headers to each segment, and send the resulting frames over the network. This significantly reduces the work done by the host CPU.

Some Broadcom Ethernet controllers, such as the BCM571X/BCM5720, also support using jumbo sized frames (up to 9,216 bytes) as the individual frame size into which a large offloaded TCP packet is segmented into.

**NOTE:** The UDP checksum engine does not span IP fragmented frames.

**NOTE:** The Ethernet controller does not validate the value of the Length field and may generate an error on the PCI bus if the Length field has a value of 0. The host driver must ensure that the Length field is nonzero before enqueueing the BD onto the Send Ring.

NOTE: The BCM571X/BCM5720 family added the ability to use jumbo-sized frames simultaneously with LSO.

#### 6.4.1 QuickStart

Follow the steps to enable LSO:

- 1. Zero TCP checksum field in offloaded packet (leave IP checksum field alone)
- 2. Set register 0x0C00[3]=1: Enable hardware LSO pre-DMA processing
- 3. Set register 0x4800[27]=1: Enable hardware processing of LSO IPv4 packets
- 4. Set register 0x4800[28]=1: Enable hardware processing of LSO IPv6 packets (if desired)
- 5. Set Send BD Flags[8]=1: CPU pre-DMA
- 6. Set Send BD Flags[9]=1: CPU post-DMA
- 7. See LSO Limitations section below

**NOTE:** In Broadcom controllers that have a physically separate isochronous (ISO) TX queue, there is a parallel set of register fields, which mirror that of the normal TX path, for controlling LSO on the ISO TX path.

### 6.4.2 LSO-Related Hardware Control Bits

Table 26: Send Data Initiator Mode Register (Offset: 0xC00)

| Name                    | Bits |    | Default<br>Value | Description                            |
|-------------------------|------|----|------------------|----------------------------------------|
| Hardware Pre-DMA Enable | 3    | RW | 0                | Enable hardware LSO pre-DMA processing |

The ISO Send Data Initiator Mode register is applicable only to controllers that have a secondary Tx ISO (Isochronous) queue.

Table 27: ISO Send Data Initiator Mode Register (Offset: 0xD00)

| Name                    | Bits |    | Default<br>Value | Description                            |
|-------------------------|------|----|------------------|----------------------------------------|
| Hardware Pre-DMA Enable | 3    | RW | 0                | Enable hardware LSO pre-DMA processing |

Table 28: Read DMA Mode Register (offset: 0x4800)

| Name                                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                |
|---------------------------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware IPv6 Post-DMA<br>Processing Enable | 28   | RW     | 1                | Enable hardware processing of LSO IPv6 packets. This bit has no effect on Post-DMA processing of IPv4 packets. This bit when clear disables IPv6 Processing. This bit was not used for controllers before BCM571X/BCM5720. |
| Hardware IPv4 Post-DMA<br>Processing Enable | 27   | RW     | 0                | Enable hardware processing of LSO IPv4 packets. This bit has no effect on Post-DMA processing of IPv6 packets. This bit is the TCP Segmentation Enable bit.                                                                |

The ISO Read DMA Mode register is applicable only to controllers that have a secondary Tx ISO (Isochronous) queue.

Table 29: ISO Read DMA Mode Register (Offset: 0x4A00)

| Name                                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                |
|---------------------------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware IPv6 Post-DMA<br>Processing Enable | 28   | RW     | 1                | Enable hardware processing of LSO IPv6 packets. This bit has no effect on Post-DMA processing of IPv4 packets. This bit when clear disables IPv6 Processing. This bit was not used for controllers before BCM571X/BCM5720. |
| Hardware IPv4 Post-DMA<br>Processing Enable | 27   | RW     | 0                | Enable hardware processing of LSO IPv4 packets. This bit has no effect on Post-DMA processing of IPv6 packets. This bit is TCP Segmentation Enable bit.                                                                    |

The ISO related registers are to allow for processing of ISO Ethernet Audio Video (EAV)-related TX traffic. A physically separate isochronous TX queue exists in some Broadcom Ethernet controllers to support audio/video traffic applications, which require very precisely timed isochronous launch of TX packets onto the wire.

**NOTE:** LSO using jumbo frames is permissible on some Broadcom controllers (i.e., BCM571X/BCM5720). This is accomplished by appropriately programming the MSS field of the Send BD.

# 6.4.3 Send Buffer Descriptor

The Send Buffer Descriptor (SBD) diagram is shown below.

Figure 22: Send Buffer Descriptor



#### 6.4.3.1 Host Address

This field is a 64-bit address specifying where the Send Buffer is located in Host memory.

## 6.4.3.2 Length[15:0]

This field is the length of the frame or TCP large segment to be transmitted.

## 6.4.3.3 VLAN Tag[15:0]

This field is the VLAN Tag to be inserted into the frame if Flags[6] is set to 1.

### 6.4.3.4 HdrLen[7:0]

This field is the length of the Ether + IP + TCP Headers to be replicated in each segment arising out of a Large TCP Segment transmit operation.

The HDRLEN field is split into two fields within the SBD:

- A sub-field within the Flags field at a word offset of 0x08
- Adjacent to the MSS field at an offset of 0x0c

This field is used only for LSO buffers. Its value specifies the combined L3 and L4 header length in 4-byte DWORDS for TCP/IPv4 or TCP/IPv6 packets. The value includes any option headers for IPv4, any extension headers for IPv6, and any TCP options.

For a TCP/IPv4 packet without IP or TCP options, this field would have a value of 10 (decimal).

For a TCP/IPv6 packet without extension headers or TCP options, this field would have a value of 15 (decimal).

For a TCP/IPv6 packet with a hop-by-hop options extension header of length 8 bytes plus a TCP MSS option (4 bytes), this field would have a value of 18 (decimal).

#### 6.4.3.5 MSS[13:0]

This field is the size of the TCP segments into which a LSO segment is to be segmented into. Note that the MSS field has been increased for some NetXtreme controllers (i.e., BCM571X/BCM5720) to hold a value specifying a jumbo frame size.

## 6.4.3.6 Flags

See the table below.

Table 30: Flag Field Description

| Bit # | Flag Name                                  | Flag Description                                                                                                                                                                                                                                                                                                                   |
|-------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TCP/UDP Checksum Offload<br>Enable         | This bit enables calculation of TCP or UDP checksums for IPv4 and IPv6 transmitted packets. The driver will set this bit only if the packet contained within a buffer is TCP or UDP over IPv4 or IPv6.                                                                                                                             |
| 1     | IP Checksum Offload Enable                 | This bit enables calculation of the IPv4 layer-3 checksum. This bit will be set only for IPv4 packets. The driver will never set it for IPv6 packets.                                                                                                                                                                              |
| 2     | Packet End                                 | This bit will be set for the last send buffer in a packet.                                                                                                                                                                                                                                                                         |
| 3     | Jumbo Frame                                | Driver must set this bit to 1 if the MTU length of the Send Frame is > 1500B. The MTU length is the Ethernet payload length and excludes Header length (and Trailer length). All BDs belonging to a Send Packet must configure this bit identically.                                                                               |
| 4     | HDRLEN[2]                                  | The length of the Ethernet + IP + TCP Headers to be replicated in each segment arising from Large TCP Segment Offload (LSO) activity.                                                                                                                                                                                              |
| 5     | Capture Time Stamp (BCM5719/<br>5720 only) | If this bit is 1, this frame's launch time shall be captured in the TX Time-Stamp Register.                                                                                                                                                                                                                                        |
| 6     | VLAN TAG                                   | When this bit is set, the NIC will insert a VLAN tag in the Ethernet header. The value for the inserted tag is taken from the VLAN Tag field in the send BD.                                                                                                                                                                       |
| 7     | Coalesce Now                               | If this bit is set, then a status block with an updated send consumer index will be DMA'd to the host as soon as this buffer's data has been DMA'd from the host. An interrupt may or may not be generated depending on the present state of interrupt avoidance mechanisms.                                                       |
| 8     | CPU Pre-DMA                                | If this bit is set, then the CPU will be required to act upon the buffer before the send data initiator state machine is kicked off. Alternately, if hardware LSO is enabled and this bit is set in conjunction with CPU Post-DMA, then this buffer will be treated as part of an LSO segment to be further segmented by hardware. |
| 9     | CPU Post-DMA                               | If this bit is set, then the CPU will be required to act upon the buffer before the send data completion state machine is kicked off. Alternately, if hardware LSO is enabled and this bit is set in conjunction with CPU Pre-DMA, then this buffer will be treated as part of an LSO segment to be further segmented by hardware. |
| 10    | HDRLEN[3]                                  | The length of the Ether + IP + TCP Headers (combined) to be replicated in each frame                                                                                                                                                                                                                                               |
| 11    | HDRLEN[4]                                  | arising from Large TCP Segment Offload activity (LSO).                                                                                                                                                                                                                                                                             |
| 12    | HDRLEN[5]                                  | Maximum HDRLEN could be 200B.                                                                                                                                                                                                                                                                                                      |
| 13    | HDRLEN[6]                                  |                                                                                                                                                                                                                                                                                                                                    |
| 14    | HDRLEN[7]                                  |                                                                                                                                                                                                                                                                                                                                    |
| 15    | Do Not Generate CRC                        | If set to 1, the controller will not append an Ethernet CRC to the end of the frame.                                                                                                                                                                                                                                               |

## 6.4.4 LSO Limitations

The limitations of the SBD are listed below.

- MSS must not be less than 8 Bytes.
- LSO packet must be a TCP packet.
- IP length field must not be incorrect.
- TCP length field must not be incorrect.
- Total offloaded TCP payload length must be greater than the MSS selected in the SBD.
- For all LSO segments, SBD flag bit 8 and 9 (CPU pre-DMA and CPU post-DMA) must be set.

- LSO packet may not be in IEEE 802.3 format with LLC and SNAP headers.
- L2 header must be contained within the very first SBD.
- IP header (IPv4 or IPv6), including IP options, must be contained within a single SBD.
- HdrLen[7:0] field must be correct in SBD.
- DONT\_GEN\_CRC must not be set in a SBD for an LSO packet.
- SNAP field must not be set in the SBD for an LSO packet.
- TCP Header, including TCP Options, must be contained within a single SBD.
- The total length for all headers (L2/L3/L4) combined, plus options, may not exceed 200 bytes.

#### 6.4.5 Additional LSO Notes

The TCP/UDP and IP checksum offload enable bits in the SBD may be either set or cleared. The hardware still works as expected when LSO is in use (i.e., checksums are calculated/inserted by the hardware since this is a natural requirement for doing LSO).

The driver should zero the TCP checksum field in the offloaded TCP packet, but leave the IP checksum alone. This requirement may change with newer NetXtreme controllers.

Broadcom drivers enable long burst by default in the Read DMA Mode register (0x4800 bits 17:16 = 11 binary = 4k byte burst size).

Do not set TxFIFO Underrun Prevention Enable (bit 31) in the Buffer Manager Mode register 0x4400.

Do not set bit 5 (Multiple Segment Enable) in 0xC00 (Send Data Initiator Mode register).

## 6.4.5.1 Example TCP-segmentation-related (LSO) register values

#### Source: Broadcom tg3 Linux driver with BCM5764M NIC

| 0x4800 | 08033BFE | Read DMA Mode Register                    |
|--------|----------|-------------------------------------------|
| 0x0C00 | A000000A | Send Data Initiator Mode Register         |
| 0x0CF4 | 50000020 | Pre-DMA Command Exchange for Segmentation |
| 0x0CEC | 00040028 | DMA Flag Register for TCP Segmentation    |
| 0x1008 | A0000000 | Pre-DMA Command Exchange for Segmentation |
| 0x0CE8 | 00000036 | Length/Offset Register for Segmentation   |
| 0x0CF0 | 0000000  | VLAN Tag Register for TCP Segmentation    |
|        |          |                                           |

# 6.5 Jumbo Frames

The BCM571X/BCM5720 family supports jumbo Ethernet frames in both the receive (RX) and transmit (TX) paths and in conjunction with LSO. The jumbo frame architecture and the software interface are nearly identical to that of the legacy NetXtreme family controllers which also supported jumbo frames. The related jumbo architectural changes for the BCM571X/BCM5720 family are described in this section.

Following are the feature highlights.

The maximum jumbo frame length supported by the BCM571X/BCM5720 family is 9622B, which may be broken down as follows:

- 9600B MTU payload<sup>1</sup>
- 14B Ethernet Header
- 4B Ethernet FCS
- Optional 4B of VLAN Tag
- 9622B maximum size limit applies equally to both TX and RX paths

#### Transmit Side:

- CRC checksum offload of jumbo frames is permitted.
- TCP and IP checksum offload of jumbo frames is permitted.
- TCP segmentation offload (TSO), a.k.a. large segment offload (LSO), of jumbo frames is permitted.
- Jumbo frames are to be constructed out of standard send buffers.
- There is a single send buffer ring that jumbo and standard frames share. The driver may inter-mix jumbo and standard frames in the send ring without restriction.
- The TX MBUF on-chip memory has to be upsized to 22K bytes.
- The behavior of TX jumbo frame processing remains identical to that of standard TX frame processing:
  - A TX frame is first completely DMAed into the TX MBUF memory and only then will it be transmitted onto the wire.
  - The TX EMAC treats jumbo frames exactly the same as it treats a standard frame, except for being cognizant of the length.
  - Full-Duplex and Half-Duplex behavior remains the same.
  - Host coalescing timing remains identical to that of standard frames.
  - A new jumbo frame flag is introduced in the send buffer descriptor (SBD). The driver must set this flag bit to indicate
    a jumbo frame (i.e., frame length > 1514 bytes without CRC and VLAN tag fields)
  - In Multiple Send Queue mode, all 16 send queues are permitted to post jumbo frames. Thus there are 16 send ring control blocks (RCBs) available in this mode.

#### Receive Side:

- An additional BD producer ring (the jumbo producer ring) has been introduced.
- The receive side retrieves buffers only from the jumbo producer ring in turn to post a received jumbo frame. Similarly, the receive side only retrieves buffers from the standard producer ring in turn to post standard sized frames.
- The jumbo producer ring is populated with BDs of a format known as the Extended Buffer descriptors. This is different from the standard buffer descriptor format.
- It is important to note that the driver may post extended BDs only in the jumbo producer ring and may post standard BDs only in the standard producer ring. BD formats may not be interchanged.
- The return rings are heterogeneous. That is, the controller returns both standard BDs and extended BDs in the same return ring. Intermixing of both types of BDs can happen without any restriction.

<sup>1.</sup> This is the capability of the silicon. The implementation of MTU size is OS-dependent. Contact your Broadcom FAE for additional information.

- RX MBUF memory has been upsized to at least 32 KB.
- Both 4-tuple and 2-tuple RSS computation and classification are performed over RX jumbo frames.
- There are 4 return rings as per RSS requirements (this is not affected by jumbo frame support).
- Receive CRC calculation and checking is performed on jumbo frames.
- Hardware calculates TCP, UDP, and IP checksums on jumbo frames.
- In IOV mode (I/O Virtualization), all 17 receive queues (virtual receive queues) must be provided with extended receive BDs. To that end, each VRQ is provided with a dedicated standard receive BD (RBD) ring and a dedicated jumbo RBD Ring.

#### Other:

- Miscellaneous BD memory has been increased over legacy NetXtreme controllers from 6K (4K receive BD + 1K send BD + 1K gencomm) to 51 KB (17 KB standard receive BD + 17K jumbo receive BD + 16 KB send BD + 1K gencomm). Gencomm describes on-chip memory space used for driver to/from boot code/firmware communication.
- The structure of the status block has been updated in order to accommodate jumbo frame related information.
- The controllers, memory map has also been updated.

### 6.5.1 Affected Data Structures

The data structures introduced, updated, or affected due to jumbo frame support are discussed in this section. In IOV mode, some of these structures are instantiated 17 times in case of receive and 16 times in case of transmit.

### 6.5.1.1 Extended RX Buffer Descriptor (BD)

The extended buffer descriptors are only permitted to be posted to the jumbo producer ring. The structure is shown in Figure 23, Extended RX Buffer Descriptor. The main distinction of the extended BD structure is that it can point to a maximum of four pieces of a scattered receive buffer. Hence the structure contains four host addresses and four length fields.

Figure 23: Extended RX Buffer Descriptor

| 31               | 15                 | 0 |              |
|------------------|--------------------|---|--------------|
| Host Address 1   |                    |   | 0x0<br>0x4   |
| Host Address 2   |                    |   | 0x8<br>0xC   |
| Host Address 3   |                    |   | 0x10<br>0x14 |
| Len 1            | Len 2              |   | 0x18         |
| Len 3            | Resvd              |   | 0x1C         |
| Host Address 0   |                    |   | 0x20<br>0x24 |
| Index            | Len 0              |   | 0x28         |
| Туре             | Flags              |   | 0x2C         |
| IP Checksum      | TCP / UDP Checksum |   | 0x30         |
| Error Flags      | VLAN Tag           |   | 0x34         |
| RSS Hash         |                    |   | 0x38         |
| Opaque Data Area |                    |   | 0x3C         |

- The Host Address 0 field contains the address of the first buffer in host memory. The host address is in host address format (64-bit).
- The Host Address N field in the Extended Receive Buffer Descriptor contains the address of the Nth piece of the buffer in host memory.
- The Index field is used by the host to keep track of the position of the returned buffer descriptor. This field is passed through opaquely by the controller.
- The Len 0 field is initially set by the host and specifies the length of the first buffer available for receiving data; this length field is set to the length of the data pointed to by Host Address 0. When an extended BD is returned to the receive return ring, the Len 0 field is set to the entire length of the data associated with the buffer descriptor, which is so because the receive return ring contains only a single length field. All BDs posted to the return ring by the controller are of size 32 bytes, whereas extended receive BDs posted to the jumbo producer ring by the driver are of size 64 bytes.

**NOTE:** In the case of an extended BD, the host is permitted to make Len 0 > 4 KB and practically even beyond 9.6 KB, such that an entire jumbo frame could be held in a single buffer. In such a scenario, hardware attempts to post an entire jumbo frame in a single buffer designated by Len 0.

**NOTE:** Len 0 is not permitted to be 0. Len1, Len2, or Len 3 may be set to 0, but hardware ignores Len2 and Len3 when Len1 = 0. Similarly, hardware ignores Len4 when Len3 = 0.

**NOTE:** None of the Len N values may be less than 8 bytes.

- The Len1, Len2, and Len3 fields contain the respective lengths of the remaining three pieces of the buffer in host memory.
- The Type field is used by the controller internally and should be ignored and need not be set by the host.
- The Flags bits are used to indicate any special processing that is needed in the buffer. Bits that are not explicitly defined here must be set to zero. See Table 32 on page 96.

- For Receive Return Ring descriptors, if using IP checksum offload, the host driver software should rely on the Flags bit IP\_CHECKSUM (Flags bit 12) to determine if the IP checksum in the received packet is correct. This field used to contain the actual IP checksum value, but that is not true for the BCM571X/BCM5720 Family of controllers. Only the Flags bit IP CHECKSUM should be relied on by host driver software as is done by Broadcom drivers.
- The TCP/UDP Checksum field is the checksum of all data following the IP header, for the length defined in the IP header. If the Receive No Pseudo-header Checksum bit is set, then the pseudo header checksum is not added to this value. If the bit is set this value includes the pseudo header.
- The Error Flags field contains a bitmask of possible errors. It is only valid if the BD\_FLAGS\_FRAME\_HAS\_ERROR bit (see Table 32 on page 96) is set in the Flags field.

Table 31: Receive BD Error Flags

| Bit#  | Error Flag Name             | Description                                                                                                                                                                                                                                                                                     |
|-------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | BD_ERR_BAD_CRC              | This frame has a bad CRC.                                                                                                                                                                                                                                                                       |
| 17    | BD_ERR_COLL_DETECT          | This frame had a collision.                                                                                                                                                                                                                                                                     |
| 18    | BD_ERR_LINK_LOST_DURING_PKT | The link was lost while this, incomplete frame was being received.                                                                                                                                                                                                                              |
| 19    | BD_ERR_PHY_DECODE_ERR       | The frame had an unspecified frame decoding error.                                                                                                                                                                                                                                              |
| 20    | BD_ERR_ODD_NIBBLED_RCVD_MII | The packet arrived with an odd number of nibbles.                                                                                                                                                                                                                                               |
| 21    | BD_ERR_MAC_ABORT            | The MAC aborted the packet due to an unspecified internal error.                                                                                                                                                                                                                                |
| 22    | BD_ERR_LEN_LT_64            | The MAC received a runt packet.                                                                                                                                                                                                                                                                 |
| 23    | BD_ERR_TRUNC_NO_RESOURCES   | The MAC could not receive this entire packet due to a lack of internal resources. Note that this bit is not set for frame longer than MTU that have bad CRC.                                                                                                                                    |
| 24    | BD_ERR_GIANT_FRAME_RCVD     | This frame was longer than the maximum packet length value set in the Receive MTU register. The data is truncated at the length specified in the Receive MTU register. This bit must be set when bit 4 BD_FLAG_IP_FRAG_END is set for the last BD of the last fragment in a train of fragments. |
| 25:31 | Reserved                    | _                                                                                                                                                                                                                                                                                               |

- The VLAN Tag field is filled in if the BD\_FLAGS\_VLAN\_TAG bit is set in the flags field. It is the 2 byte VLAN tag that has been extracted from a 802.1Q compliant frame.
- The Reserved field is used internally by the controller. The host should ignore the value of this field.
- The Opaque Data field is reserved for the driver and any data placed here is passed opaquely by the driver from the receive buffer descriptor in the standard or jumbo receive ring to one of the receive return rings.

Table 32: Receive BD Flags

| Bit # | Flag Name          | Flag Description                                                                                                                                                                                                  |
|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Reserved           | -                                                                                                                                                                                                                 |
| 1     | Reserved           | -                                                                                                                                                                                                                 |
| 2     | BD_FLAG_END        | The frame ends at the end of the data in this buffer descriptor.                                                                                                                                                  |
| 3     | RSS_HASH_VALID     | If this bit is 1, then the RSS_HASH_TYPE field is valid. Else the RSS_HASH_TYPE field is meaningless and must be ignored for this frame.                                                                          |
| 4     | Reserved           | -                                                                                                                                                                                                                 |
| 5     | BD_FLAG_JUMBO_RING | Indicates that this packet came from the Jumbo Receive Ring, not the Standard Receive Ring (For receive BDs only). This must be set by the driver, it is just copied through opaquely by the controller firmware. |
| 6     | BD_FLAG_VLAN_TAG   | The frame associated with this buffer descriptor has an 802.1Q VLAN tag associated with it.                                                                                                                       |

Table 32: Receive BD Flags (Cont.)

| Bit# | Flag Name               | Flag Description                                                                                                                 |
|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 7:8  | RSS_HASH_TYPE           | Hash type of the receive packet. It indicates which hash_type was used on the receive packet if multiple hash types are defined. |
| 9    | Reserved                | -                                                                                                                                |
| 10   | BD_FLAG_FRAME_HAS_ERROR | An error was detected by the controller. The detected error type is set in the Error_Flag word of the receive buffer descriptor. |
| 11   | -                       | -                                                                                                                                |
| 12   | IP_CHECKSUM             | Indicates that the IP Checksum field is valid.                                                                                   |
| 13   | TCP_UDP_CHECKSUM        | Indicates that the TCP_UDP Checksum field is valid.                                                                              |
| 14   | TCP_UDP_IS_TCP          | Indicates that this frame has a TCP packet in it.                                                                                |
| 15   | IPV6_PACKET             | Indicates that this frame has an IPv6 packet in it.                                                                              |

### 6.5.1.2 Receive Jumbo Producer Ring

The jumbo RBD producer ring is reintroduced in the BCM571X/BCM5720 family to support RX jumbo frames. The jumbo RBD producer ring is structured the same as the standard RBD producer ring, but the primary difference is that only extended BDs are permitted to be posted in the jumbo RBD producer ring. The jumbo RBD producer ring has a unique RCB associated with it.

The jumbo ring is managed by a producer index and a consumer index as in the case with the standard producer ring. Whenever host software adds more BDs to the jumbo producer ring, it writes the updated producer index to the controller via a high-priority mailbox located at the PCIE address range 0x208–0x20F. The producer index register is at 0x3008.

The controller keeps a local copy of the jumbo ring consumer index in register 0x2470. The jumbo ring consumer index is also reported to the host via the status block. See "Send Buffer Descriptor" on page 99).

There is also a jumbo ring replenishment threshold register 0x2C1C. The controller DMAs BDs from the jumbo ring in advance and caches them locally in controller memory. The controller initiates DMA of more BDs anytime the local number of cached BDs falls below the threshold programmed in this register.

The maximum number of BDs that can be held in the jumbo ring is programmed in that ring's ring control block RCB.

## 6.5.1.3 Ring Control Blocks

Each host based ring has an RCB associated with it. The same structure applies to all types of host rings, (i.e., receive producer ring, receive return ring, and also send rings). In the case of the BCM571X/BCM5720 family, the RCB structure is enhanced to accommodate jumbo frames. However, the enhancement applies only to the Receive Standard Producer ring.

The RCB essentially points to the physical address of the host memory where a producer ring is placed. The BCM571X/BCM5720 family uses two RCBs, one for the Standard Ring and one for the jumbo ring. The jumbo ring RCB is implemented over a set of four registers at the address range 0x2440–0x244F. The standard ring RCB register addresses remain the same at 0x2450–0x245F. The send ring RCB and return ring RCBs are memory-mapped.

Figure 24: Ring Control Block



The host ring address is the host address of the first ring element. The host ring address is in host address format. In controller-based send rings, the host address is ignored.

The NIC ring address is the address where a portion of a ring is cached in the controller's miscellaneous BD memory. The driver need not program anything to these fields in most NetXtreme controllers. However, the BCM571X/BCM5720 family does require the driver to program non-hardware-default values here.

The Max Len field is interpreted differently for different types of rings. In the case of receive producer rings and receive return rings, this field indicates the maximum number of entries the ring can hold. The BCM571X/BCM5720 family imposes constraints for different rings as shown below:

- Receive standard producer ring and send ring: Max Len should be programmed by the host to indicate the maximum number of entries the ring will hold. The allowable values for the Standard Producer Ring Max Len are 32, 64, 128, 256, 512, 1024, and 2048.
- Receive jumbo producer ring: Max Len should be programmed by the host to indicate the maximum number of entries the ring will hold. The allowable values for the jumbo producer ring Max Len are 32, 64, 128, 256, 512, and 1024.
- Receive return rings: Max Len should be programmed by the host to indicate the maximum number of entries the ring will hold. In case of return rings, the host must program this field to be greater than or equal to the combined value of Max Len fields of the receive standard producer ring and the receive jumbo producer ring. For example, if Standard Ring Max Len == 32 and jumbo ring Max Len == 32, then return ring Max Len must be 64 or higher. This means the allowable values for the return ring Max Len are 32, 64, 128, 256, 512,1024, 2048, and 4096.

The receive standard ring RCB uses the Max Frame Size field to indicate the maximum length of each buffer to be described by the buffer descriptor placed into the standard ring. In this manner any frame received that is larger than this value causes the controller to attempt to use a jumbo ring buffer instead of a standard ring buffer. The Max Frame Size field is unused in the receive jumbo ring RCB, receive return ring RCB, and send ring RCB. The Flags field is described below in Table 33.

Table 33: Receive BD Flags

| Bit # | Flag Name              | Flag Description                      |
|-------|------------------------|---------------------------------------|
| 0     | Reserved               | Reserved                              |
| 1     | RCB_FLAG_RING_DISABLED | Indicates that the Ring is not in use |

### 6.5.1.4 Receive Return Ring(s)

There are no structural changes to the return rings in the BCM571X/BCM5720 family. There are no functional changes from standard size frames or from a Receive Side Scaling (RSS) perspective. The impact of the jumbo frame feature on the return rings is clarified here:

- The same return ring carries jumbo frames as well as standard size frames. Intermixing can happen without any limitation.
- The total number of return rings remains 4. However, when RSS is disabled, return ring 0 is the only active return ring and all RX frames are returned over Ring 0.
- When an extended buffer descriptor is returned to a receive return ring, the extended portion of the descriptor is truncated by the controller. The offset range 0x00–0x01F is the extended portion (see Figure 24 on page 98).
- Furthermore, when an extended BD is returned in a return ring, the length of the entire RX frame is consolidated in the Len 0 field even if any or all of the scatter buffer pieces of the extended BD were used to place the frame in host memory.

### 6.5.1.5 Send Buffer Descriptor

The send buffer descriptor (SBD) has been updated to accommodate LSO over jumbo frames. Figure 25 on page 99 below illustrates the updated SBD format.

Figure 25: Send Buffer Descriptor



- The Host Address is the 64-bit address where the send buffer is located in host memory.
- The Length[15:0] is the length of the frame or TCP large segment to be transmitted.
- The VLAN TAG[15:0] field is the tag to be inserted in the frame if flags[6] is set to 1.
- The aggregate HDRLEN[7:0] field is the length of the Ethernet+IP+TCP headers to be replicated in each segment arising out of a large TCP segment (LSO). (See Flags also.)
- The MSS[13:0] field is the size of the TCP segments into which a LSO segment is to be chopped up into. Note that it has been increased to hold the value of a jumbo frame size. The Flags field of SBD is shown in Table 34 below.

**Table 34: Send Buffer Descriptor Flags** 

| Bit# | Flag Name                                  | Flag Description                                                                                                                                                                                   |
|------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | TCP/UDP Checksum Offload<br>Enable         | This bit enables calculation of TCP or UDP checksums for IPv4 and IPv6 transmitted packets. The driver sets this bit only if the packet contained within a buffer is TCP or UDP over IPv4 or IPv6. |
| 1    | IP Checksum Offload Enable                 | This bit enables calculation of the IPv4 layer-3 checksum. This bit is set only for IPv4 packets. The driver never sets it for IPv6 packets.                                                       |
| 2    | Packet End                                 | This bit is set for the last send buffer in a packet.                                                                                                                                              |
| 3    | Jumbo Frame                                | Driver must set this bit to 1 if the MTU length of the Send Frame is > 1500B. The MTU length is the Ethernet payload length and excludes header length (and trailer length).                       |
|      |                                            | All BDs belonging to a send packet must configure this bit identically.                                                                                                                            |
| 4    | HDRLEN[2]                                  | The length of the Ethernet+IP+TCP headers to be replicated in each segment arising out of a large TCP segment (LSO).                                                                               |
| 5    | Capture Time Stamp (BCM5719/<br>5720 only) | If this bit is 1, this frame's launch time shall be captured in the TX Time-Stamp Register.                                                                                                        |

Table 34: Send Buffer Descriptor Flags (Cont.)

| Bit# | Flag Name           | Flag Description                                                                                                                                                                                                                                                                                                    |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | VLAN TAG            | When this bit is set, the controller inserts a VLAN tag in the Ethernet header. The value for the inserted tag is taken from the VLAN Tag field in the send BD.                                                                                                                                                     |
| 7    | Coalesce Now        | If this bit is set, a status block with an updated send consumer index is DMA'd to the host as soon as this buffer's data has been DMA'd from the host. An interrupt may or may not be generated depending on the present state of interrupt avoidance mechanisms.                                                  |
| 8    | CPU Pre-DMA         | If this bit is set, the CPU is required to act upon the buffer before the send data initiator state machine is kicked off. Alternately, if hardware LSO is enabled and this bit is set in conjunction with CPU post-DMA, then this buffer is treated as part of an LSO segment to be further segmented by hardware. |
| 9    | CPU Post-DMA        | If this bit is set, the CPU is required to act upon the buffer before the send data completion state machine is kicked off. Alternately, if hardware LSO is enabled and this bit is set in conjunction with CPU pre-DMA, then this buffer is treated as part of an LSO segment to be further segmented by hardware. |
| 10   | HDRLEN[3]           | The length of the Ether+IP+TCP headers (combined) to be replicated in each frame                                                                                                                                                                                                                                    |
| 11   | HDRLEN[4]           | arising out of a large TCP segment (LSO).                                                                                                                                                                                                                                                                           |
| 12   | HDRLEN[5]           | Maximum Header Length could be 256B.                                                                                                                                                                                                                                                                                |
| 13   | HDRLEN[6]           |                                                                                                                                                                                                                                                                                                                     |
| 14   | HDRLEN[7]           |                                                                                                                                                                                                                                                                                                                     |
| 15   | Do Not Generate CRC | If set to 1, the controller will not append an Ethernet CRC to the end of the frame.                                                                                                                                                                                                                                |

#### 6.5.1.6 Status Block

The status block has been modified to accommodate the jumbo producer ring's consumer index.

The status block is a data structure in the host memory. The host driver uses this data structure to trace the packet receive and transmission status and resource usage. Its length is 24 bytes. The driver needs to configure the status block host address register to point to the physical address in host memory for this data structure. The BCM571X/BCM5720 family will update the status block in host memory (via DMA) before a host coalescing interrupt or MSI/MSI-X. The frequency of these status block updates is determined by the host coalescing logic. The two status block update interrupt triggers are RX/TX coalescing timer and RX/TX maximum coalesced frame count threshold.

A new field to indicate the Receive Jumbo Producer Ring Consumer Index is added to the BCM571X/BCM5720 family's Legacy RSS mode status block. The updated structure of the status block is shown in Table 35 below.

Note that there are multiple formats of status blocks.

Table 35: Status Block

| Offset | 31 16                                         | 15 0                                       |
|--------|-----------------------------------------------|--------------------------------------------|
| 0x00   | Status Word                                   |                                            |
| 0x04   | Reserved 0x0                                  | Status Tag[7:0]                            |
| 80x0   | Receive Standard Producer Ring Consumer Index | Receive Return Ring 1 Producer Index       |
| 0x0C   | Receive Return Ring 2 Producer Index          | Receive Return Ring 3 Producer Index       |
| 0x10   | Send BD Consumer Index                        | Receive Return Ring 0 Producer Index       |
| 0x14   | Reserved 0x0                                  | Receive Jumbo Producer Ring Consumer Index |

The status tag field contains a unique 8-bit tag value in bits 7:0 when the status tagged status mode bit of the miscellaneous Host Control register 0x68 is set to 1. The status tag can be returned to mailbox 0 register 0x200 in field 31:24 by the host driver. When the remaining mailbox 0 register bits 23:0 are written to 0, the tag field of mailbox 0 is compared with the tag field of the last status block to be DMAed into host memory. If the tag returned is not equivalent to the tag of the last status block DMAed to the host, the interrupt state is entered.

Receive return ring 0 is the default return ring. If RSS is disabled all packets are assigned to this default ring.

There is no status block data structure in the controller memory space, but the host can access the current index through the register space.

### 6.5.1.7 Misc BD Memory

The Misc BD memory has been increased to 10 KB. The miscellaneous BD memory and the TX MBUF memory are physically the same memory, but a partition is hardwired. The miscellaneous BD memory holds four structures:

- On-chip send BD cache
- On-chip standard receive BD cache
- On-chip jumbo receive BD cache
- Software gencomm area (driver/firmware communication shared memory area)

#### 6.5.2 Device Driver Interface

There are minimal driver interface modifications to support jumbo frames.

#### 6.5.2.1 Send Interface

The driver essentially does not see any change in the send interface due to the jumbo frame feature. The only difference is that the stack is now allowed to construct larger frames (i.e., up to 9622 bytes long) out of send buffers.

**NOTE:** The controller can handle a single send buffer of length > 4K bytes and all the way up to 9622 bytes.

As in the case with previous controllers, the driver maintains a buffer descriptor ring (send ring), which allows for the "gather" management of transmit frame data. The production of send side packets by the driver is communicated to the controller via the Send Producer Ring Index Mailbox register. An update of the send BD ring producer index mailbox triggers the controller to begin DMA of the corresponding buffer descriptor. The consumption of send side packets by the controller is communicated back to the driver via the send consumer index, which is returned in the status block and periodically DMAed to the host by the controller.

A conceptual diagram of the Send Interface is shown in Figure 26 on page 102 below.

Figure 26: Send Driver Interface



#### 6.5.2.2 Receive Interface

As mentioned previously, the receive side has added another producer ring called the jumbo producer ring. This means the driver maintains two buffer descriptor rings (receive producer rings) that provide free data buffer space into which the controller can place received frame data. The production of receive-side buffers by the driver is communicated to the device via the rEceive Producer Ring Index(s) Mailbox registers. An update of a receive BD ring producer index mailbox triggers the device to begin DMA of the corresponding buffer descriptor(s). The consumption of receive side buffers by the device is communicated to the driver via the receive consumer index, which is returned via the status block and periodically DMAed to the host by the controller.

The controller fetches RX BDs in anticipation of RX frames and caches the BDs in the controller. The cached BDs are stored in the Misc BD Memory. There is a set of rules that govern placement of packets in buffers:

- All standard sized frames, that is, frames less than or equal to the Max Frame Size field of the standard RCB, typically 1522 bytes or less, are placed in buffers retrieved from the RX standard producer ring.
- Hence the host must ensure that buffers pointed to by the standard BDs are at least of that size.
- In case the host creates a standard ring buffer that is smaller than Max Frame Size and an RX frame larger than the buffer size (but <= Max Frame Size) arrives, the controller attempts to place the frame in such a buffer and ends up truncating the frame.
- RX frames larger than Max Frame Size are placed in buffers retrieved from the RX jumbo producer ring.
- Extended buffers placed in the jumbo producer ring must provide an aggregated space of 9622 bytes or higher. Otherwise, jumbo frames might be truncated by the controller during placement.

A conceptual diagram of the Receive Producer Interface is shown in Figure 27 below.

Figure 27: Receive Producer Interface



The BCM571X/BCM5720 family fills up receive buffers with RX frame data and returns the buffers to the host via receive return rings. The members of a return ring are simply RX buffer descriptors. Both types of descriptors, that is, standard or extended, are returned to the same return ring. As mentioned previously, due to practical reasons, extended buffer descriptors are truncated before posting into a return ring so that the actual size of all BDs posted to the return ring are the same (see "Receive Return Ring(s)" on page 98).

To support RSS, there are four return rings in the BCM571X/BCM5720 family. However, when RSS is disabled all RX frames are posted to Ring 0 while the other three rings remain inactive. In any case, standard and jumbo frames may be intermixed in any return ring as the order of placement strictly follows the order of frame reception.

The controller maintains four producer indexes associated with the four return rings. The availability of receive-side packets by the device is communicated to the driver via the receive return ring producer indices, which is delivered via the status block periodically when it is DMAed to the host by the controller.

The consumption of receive return packets by the driver is communicated to the controller via the receive return consumer ring index mailbox register.

A conceptual diagram of the Receive Return Interface is shown in Figure 28 on page 104 below.

Figure 28: Receive Return Interface



## 6.5.2.3 Large Segment Offload (LSO/TSO)

LSO may create jumbo frames instead of standard sized frames. This is accomplished by programming the MSS field of the send BD (see "Send Buffer Descriptor" on page 99).

The legacy NetXtreme design has limitations in LSO hardware. In the case of the BCM571X/BCM5720 family, these limitations also exist. Below is the list of such limitations:

- MSS may not be less than 8 bytes
- LSO packet must be a TCP packet
- IP length field must not be incorrect
- TCP length field must not be incorrect
- Total offloaded TCP payload length must be greater than the MSS selected by SBD
- For all LSO segments, the SBD flag bit 8 and 9 (CPU pre-DMA and CPU post-DMA fields) must be set.
- LSO packet may not be IEEE 802.3 format with LLC and SNAP headers
- The total length of IP header (including IP option for IPv4, extension headers for IPv6) and TCP header (including TCP option) may not be more than 200 bytes. Note: post\_dma\_proc can support only up to 2 MBUFs worth of packet header data. 1st Mbuf gives: 128, Mbuf-header (8B), Frame Header field (40B) = 80B; 2nd Mbuf gives: 128, Mbuf Header (8B) = 120B. Hence the total space for all headers, which includes all L2/L3/L4 combined, and options cannot exceed 200 bytes.
- L2 header must be contained within one SBD (the first one)
- IP header (IPv4 or IPv6), including IP Options, must be contained within a single SBD
- Hdrlen[7:0] field must be correct in SBD

- DONT\_GEN\_CRC field must not be set in a SBD for LSO packet
- SNAP field must not be set in SBD for LSO packet
- TCP header, including TCP Options, must be contained within a single SBD

The Read DMA (RDMA) engine cannot support LSO packets with the above listed attributes. Any such LSO configurations may cause the RDMA engine to lockup and/or exhibit abnormal behavior.

## 6.5.3 Summary of Register Settings to Support Jumbo Frames

■ Standard receive producer ring RCB (Ring Control Block):

```
0x2450: Host address high [31:0]

0x2454: Host address low [31:0]

0x2458: [31:16]: Standard ring size (power of 2)

[15:2]: std_max_packet_size = 0x600 (1522 decimal)

[1:0] = 0

0x245C: Standard NIC address = 0x400000
```

The NIC address is a controller-internal memory address where the controller caches a portion of a ring to achieve faster, higher performance access to buffer descriptors.

Jumbo receive producer ring RCB:

```
0x2440: Host address high [31:0]
0x2444: Host address low [31:0]
0x2448: [31:16]: Jumbo ring size (power of 2)
[15:2] = 0
[1:0] = 0
```

0x244C: Jumbo NIC address 0x00044400

Only the host address and ring size are applicable to the receive return RCB.

- Receive MBUF low water mark 0x4414 = 0x7E (program to this value only when jumbo enabled)
   Receive MBUF high water mark 0x4418 = 0xEA (program to this value only when jumbo enabled)
   Read DMA watermark register 0x4410 = 0x0
- Standard replenish threshold register 0x2C18 is typically 1/8 of total receive BDs in host memory. Jumbo replenish threshold register 0x2C1C is typically 1/8 of total Receive BDs in host memory.
- EMAC MTU register 0x43C: Program this register based on max packet size.

## 6.6 Scatter/Gather

Most often, the host software requests the NIC to transmit a frame that spans several physical fragments that are arbitrary in size and buffer alignment. This requires the Ethernet controller to gather all these fragments during a DMA process into a continuous data stream for transmission.

The ability to scatter/gather a frame lessens the restriction on the host software and increases overall system performance.

**Example:** A TCP/IP protocol stack could preconstruct the MAC and IP headers in separate buffers that are combined with the payload to form a complete frame. Since the header data are fairly constant during a TCP or UDP session, the stack could use the same header buffers for the next frame.

The Ethernet controller uses a buffer descriptor for describing a physical fragment. There are two types of buffer descriptors; the Receive MAC processes receive buffer descriptors (Receive BD) and the Transmit MAC processes send buffer descriptors (Send BD).

Figure 29 illustrates the relationship between a frame consisting of multiple fragments and their corresponding send buffer descriptors.

Figure 29: Scatter Gather of Frame Fragments



To transmit a frame, the host software sets up consecutive buffer descriptors in a send ring. Each buffer descriptor describes a physical fragment of a frame. As an example, the above figure illustrates a frame consisting of five fragments that are scattered throughout host memory. Frag1, the first fragment, is at the start of the frame, and Frag5, the last fragment, is at the end of a frame. For each fragment, there is a corresponding buffer descriptor, SendBd1 through SendBd5. These buffer descriptors must be initialized in the send ring in a consecutive order, SendBd1 to SendBd5. The last send buffer descriptor of a frame must have the PACKET\_END bit of Send BD Flags field set to indicate the end of a frame.

# 6.7 VLAN Tag Insertion

The Ethernet controller is capable of inserting 802.1Q-compliant VLAN tags into transmitted frames and extracting the VLAN tags from received frames. A frame containing the 802.1Q VLAN tag has the value TPID (Tag Protocol Identifier) value in the Ether-type field followed by a 16-bit TCI (Tag Control Information) field, which is made up of one CFI bit, 3 802.1P priority bits, and a 12-bit VLAN ID. The original 16-bit Ether-type/Length field follows the TCI field.

Table 25 on page 77 shows the frame format with 802.1Q VLAN tag inserted.

The Ethernet controller allows the host software to enable or disable tag insertion on a per-packet basis. To send a frame with a VLAN tag, the host software must initialize the first send buffer descriptor of a packet with the VLAN tag value and set the VLAN\_TAG bit of Send BD Flags field (see "Send Rings" on page 83).

# 6.8 TX Data Flow Diagram

Figure 30 on page 108 illustrates how a frame, consisting of several fragments, is sent from the host to the NIC and onto the network. For simplicity, the diagram depicts the operation of a single ring.

- The host software calls a system API to retrieve the three physical fragments of the frame. It initializes the next three
  send buffer descriptors to point to each fragment. The send buffer descriptors reside in host memory. Internally, the host
  software maintains the ring's producer index. In this case, the producer index is incremented by three because there are
  three fragments.
- 2. The host software updates the send ring producer index by writing the producer index value to Send Ring Producer Index Mailbox at offset 0x300 for host standard and offset 0x5900 for indirect mode. The mailbox update triggers the Ethernet controller to process the send buffer descriptors.
- 3. The send buffer descriptors are DMAed to the ring's staging area in device memory as indicated in the RCB.
- 4. The Ethernet controller DMAs the frame (as described in the descriptors) to its internal memory for transmission.
- 5. Internally, the Ethernet controller maintains the send ring's consumer index, which is incremented as it processes the descriptors.
- 6. The new consumer index is written to the status block in NIC memory (see "Status Block" on page 60).
- 7. The status block is DMAed to host memory. This DMA is subject to host coalescing, and the NIC may generate an interrupt at this point.

Figure 30 and Figure 31 on page 109 show the basic driver flow to send a packet.

Figure 30: Transmit Data Flow



Figure 31: Basic Driver Flow to Send a Packet



#### 6.9 Reset

A hardware reset initiated by the PCI reset signal will initialize all PCI configuration registers and device MAC registers to their default values. The driver reset via the Core Clock Blocks Reset bit (see "Miscellaneous Configuration Register (offset: 0x6804)" on page 418) will also initialize all non-sticky registers to their default values. The content of the device internal memory remains unchanged after warm reset (any reset with the power supplied to the device).

At the end of the reset, the on-chip RX RISC executes a small on chip ROM code. This code loads an executable image contained in an attached NVRAM and referred to as the boot code. This boot code allows at least the following fields to be initialized to different values to support product variations (for additional details, see Section 3: "NVRAM Configuration," on page 47).

- Vendor ID
- Device ID
- Subsystem Vendor ID
- Subsystem Device ID
- Possible PHY initialization

The boot code may have additional functionality such as PXE that must be acquiesced while the host software is running.

**Example:** An NDIS driver issues a device reset via the Core Clock Blocks Reset bit (see Table 358 on page 334). After the reset is completed, the RX RISC begins executing the boot code as if the power was first applied to the device. However, the NDIS driver must have a mechanism to prevent the PXE driver from running and the boot code must be able to distinguish between a power-on reset and a reset initiated by the host software. The host software and the boot code could implement a reset handshake by using shared memory at offset 0x0b50 as a software mailbox (see "Firmware Mailbox" on page 187).

The BCM571X/BCM5720 family of Ethernet controllers supports a boot code mechanism known as "self-boot". For self-boot the boot code image is stored in internal ROM rather than in an external NVRAM. So there is no loading of a boot code image from external NVRAM when resetting in the self-boot scenario.

However, there may still be a very small external NVRAM device which may contain some configuration items and possibly boot code "patches" to be applied to the ROM'd self-boot, boot code. Refer to the following Broadcom Application Notes for additional self-boot and general NVRAM access information:

- 5754X\_5787X-AN10X-R "Self Boot Option"
- NetXtreme-AN40X-R "NetXtreme/NetLink Software Self-Boot NVRAM"
- NetXtreme-AN50X-R "NetXtreme®/NetLink® NVRAM Access"

# 6.10 MAC Address Setup/Configuration

The MAC address registers, starting at offset 0x0410, contain the MAC addresses of the NIC. These registers are usually initialized with a default MAC address extracted from the NIC NVRAM when it is first powered up. The host software may overwrite the default MAC address by writing to the MAC registers with a new MAC address. Table 36 illustrates the MAC register format.

The BCM571X/BCM5720 family Ethernet controller allows a NIC to have up to four MAC addresses (offset 0x410–0x42F) that are used for hardware packet reception filtering. However, most host software will initialize the registers of the four MAC addresses to the same MAC address since a NIC usually has only one MAC address.

When flow control is enabled on the Ethernet controller, the MAC Address 0 is used as the source address for sending PAUSE frames (see "Pause Control Frame" on page 511).

Table 36: Mac Address Registers

| Register Name | Offset | 31     | 24    | 23   | 16      | 15  | 8       | 7   | 0    |
|---------------|--------|--------|-------|------|---------|-----|---------|-----|------|
| Mac_Address_0 | 0x0410 |        | Unu   | ised |         | Oct | et 0    | Oct | et 1 |
|               | 0x0414 | Oc     | tet 2 | Oct  | et 3    | Oct | et 4    | Oct | et 5 |
| Mac_Address_1 | 0x0418 | Unused |       |      | Octet 0 |     | Octet 1 |     |      |
|               | 0x041c | Oc     | tet 2 | Oct  | et 3    | Oct | et 4    | Oct | et 5 |
| Mac_Address_2 | 0x0420 |        | Unu   | ısed |         | Oct | tet 0   | Oct | et 1 |
|               | 0x0424 | Oc     | tet 2 | Oct  | et 3    | Oct | et 4    | Oct | et 5 |
| Mac_Address_3 | 0x0428 |        | Unu   | ised |         | Oct | et 0    | Oct | et 1 |
|               | 0x042c | Oc     | tet 2 | Oct  | et 3    | Oct | et 4    | Oct | et 5 |

## 6.11 Packet Filtering

# 6.11.1 Multicast Hash Table Setup/Configuration

The MAC hash registers are used to help discard unwanted multicast packets as they are received from the external media. The destination address is fed into the normal CRC algorithm in order to generate a hash function. The most significant bits of the CRC are then used without any inversion in reverse order to index into a hash table, which is comprised of these MAC hash registers. If the CRC is calculated by shifting right, then the right-most bits of the CRC can be directly used with no additional inversion or bit swapping required. See "Ethernet CRC Calculation" on page 112 for more details on the CRC algorithm.

All four MAC hash registers are used so that register 1 bit-32 is the most significant hash table entry and register 4 bit-0 is the least significant hash table entry. This follows the normal big-endian ordering used throughout the Ethernet controller. Since there are 128 hash table entries, 7 bits are used from the CRC. When hash table is extended to 256 entries, 8 bits from the CRC will be used as hash index.

The MAC hash registers are ignored if the receive MAC is in promiscuous mode.

#### 6.11.2 Ethernet CRC Calculation

The Ethernet controller uses the standard 32-bit CRC required by the Ethernet specification as its FCS in all packets. The checksum is the 32-bit remainder of the polynomial division of the data taken as a bit stream of polynomial coefficients and a predefined constant, which also represents binary polynomial coefficients. The checksum is optionally appended most-significant bit first to a packet, which is to be sent down the wire. At the receiving side, the division is repeated on the entire packet including the CRC checksum. The remainder is compared to a known constant. For details on the mathematical basis for CRC checksums, see Tanenbaum's Computer Networks, Third Edition, c1996.

The 32-bit CRC polynomial divisor is shown below:

```
x32 + x26 + x23 + x22 + x16 + x12 + x11 + x10 + x8 + x7 + x5 + x4 + x2 + x + 1
```

### 6.11.3 Generating CRC

The following steps describe a method to calculate the CRC with the resulting 32-bit quantity having reversed bit order (i.e., most significant bit x31 of the remainder is right-most bit). The data should be treated as a stream of bytes. Set remainder to 0xFFFFFFF. For each bit of data starting with least-significant bit of each byte:

- If right-most bit (bit-0) of the current remainder XORed with the data bit equal 1, then remainder = (remainder shifted right one bit) XOR 0xEDB88320, else remainder = (remainder shifted right one bit).
- 2. Invert remainder such that remainder = ~remainder.

Remainder is CRC checksum.

Right-most byte is the most significant and is to be sent first.

Swap bytes of CRC if big-endian byte ordering is desired.

### 6.11.4 Checking CRC

The following steps describe a method to check a stream of bytes, which has a CRC appended.

- 1. Set remainder to 0xFFFFFFF.
- For each bit of data starting with least-significant bit of each byte:
   If right-most bit (bit-0) of the current remainder XORed with the data bit equal 1, then remainder = (remainder shifted right one bit) XOR 0xEDB88320, else remainder = (remainder shifted right one bit).
- 3. Remainder should equal magic value 0xDEBB20E3 if CRC is correct.

### 6.11.5 Initializing the MAC Hash Registers

The 128-bit multicast hash table is treated as a single object occupying four Ethernet controller registers starting at offset 0x0470 (see Table 37 on page 113). The 128-bit value follows the big-endian ordering required by Ethernet controller. Thus, the most significant 32-bit of the 128-bit value resides in Mac\_Hash\_Register\_0 at offset 0x0470 and the least significant 32-bit resides in Mac\_Hash\_Register\_3 at offset 0x047c.

Host software can enable the reception of all multicast frames including broadcast frames by setting all four multicast hash registers to 0xFFFFFFFF.

Table 37: Multicast Hash Table Registers

| Register Name       | Offset | Description                                        |
|---------------------|--------|----------------------------------------------------|
| Mac_Hash_Register_0 | 0x0470 | Most significant 32-bit of the 128-bit hash table  |
| Mac_Hash_Register_1 | 0x0474 | Bits 64:93 of the 128-bit hash table               |
| Mac_Hash_Register_2 | 0x0478 | Bits 32:63 of the 128-bit hash table               |
| Mac_Hash_Register_3 | 0x047c | Least significant 32-bit of the 128-bit hash table |

The following C code fragment illustrates how to initialize the multicast hash table registers. The code fragment computes the indices into hash table from a given list of multicast addresses and initializes the multicast hash registers.

```
Unsigned long HashReg[4];
Unsigned long j, McEntryCnt;
Unsigned char McTable[32][6]; // List of multicast addresses to accept.
// Initialize the McTable here.
McEntryCnt = 32;
// Initialize the multicast table registers.
HashReg[0] = 0;
                               // Mac_Hash_Regsiter_0 at offset 0x0470.
                               // Mac_Hash_Register_1 at offset 0x0474.
HashReg[1] = 0;
                               // Mac_Hash_Register_2 at offset 0x0478.
HashReg[2] = 0;
HashReg[3] = 0;
                               // Mac Hash Register 3 at offset 0x047c.
for (j = 0; j < McEntryCnt; j++)
   unsigned long RegIndex;
   unsigned long Bitpos;
   unsigned long Crc32;
   Crc32 = ComputeCrc32(McTable[j], 6);
   // The most significant 7 bits of the CRC32 (no inversion),
   // are used to index into one of the possible 128 bit positions.
   Bitpos = \sim Crc32 \& 0x7f;
   // Hash register index.
   RegIndex = (Bitpos & 0x60) >> 5;
   // Bit to turn on within a hash register.
   Bitpos &= 0x1f;
   // Enable the multicast bit.
   HashReg[RegIndex] |= (1 << Bitpos);</pre>
}
```

The following C routine computes the Ethernet CRC32 value from a given byte stream. The routine is called from the above code fragment.

```
// Routine for generating CRC32.
unsigned long
ComputeCrc32(
   unsigned char *pBuffer, // Buffer containing the byte stream.
   unsigned long BufferSize) // Size of the buffer.
{
   unsigned long Reg;
   unsigned long Tmp;
   unsigned long j, k;
   Reg = 0xffffffff;
   for(j = 0; j < BufferSize; j++)
   {
      Reg ^= pBuffer[j];
      for(k = 0; k < 8; k++)
      {
       Tmp = Reg & 0x01;
   }
}</pre>
```

```
Reg >>= 1;
    if(Tmp)
{
        Reg ^= 0xedb88320;
        }
    }
    return ~Reg;
```

#### 6.11.6 Promiscuous Mode Setup/Configuration

The host software may enable promiscuous mode by setting the Promiscous\_Mode bit (bit 8) of the Receive\_MAC\_Mode register (offset 0x468). The Promiscous\_Mode bit defaults to disabled after reset, and host software must explicitly set this bit for promiscuous mode. In promiscuous mode of operation, the Ethernet controller accepts all incoming frames that are not filtered by the active receive rules regardless of the destination MAC address. In other words, the Ethernet controller operating in promiscuous mode ignores multicast and MAC address filtering ("Multicast Hash Table Setup/Configuration" on page 111 and "MAC Address Setup/Configuration" on page 111), but applies Receive Rules.

### 6.11.7 Broadcast Setup/Configuration

The host software may configure the Ethernet controller to discard the received broadcast frames by using two receive rules as defined below. The Ethernet controller parses all incoming frames according to these receive rules and discards those frames that have a broadcast destination address (see "Receive Rules Setup and Frame Classification" on page 73 for more details on setting up the receive rules).

The following is a sample of the two receive rules for discarding broadcast frames.

Rule1 Control: 0xc2000000 Rule1 Mask/Value: 0xffffffff Rule2 Control: 0x86000004 Rule2 Mask/Value: 0xffffffff

# **Chapter 7: Device Control**

#### 7.1 Initialization Procedure

This section describes the initialization procedure for the MAC portion of the NetXtreme family of devices.

- 1. Call the device reset procedure. (see "Device Reset Procedure" on page 121)
- 2. Enable/Disable any required bug fixes. Refer to the applicable Errata document for information on any errata that must be worked around by enabling/disabling the control bits of chip bug fixes if any are applicable.
- 3. Optionally, enable Tagged Status mode by setting the Enable\_Tagged\_Status\_Mode bit of the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245).

NOTE: For additional information on Tagged Status mode see "Section 11: "Interrupt Processing," on page 197".

- 4. Clear the driver status block memory region by writing zeros to the host memory region where the status block will be direct memory accessed (DMA) (see "Status Block" on page 42).
- 5. Configure the DMA Write Water Mark in the DMA Read/Write Control register (see "DMA Read/Write Control Register (Offset: 0x6C)" on page 246), as follows.
  - If the Max Payload Size of PCIe Device Control register is 128 bytes, set the DMA writewater mark bits (bits19-21) of DMA Read/Write Control register to 011b (for a watermark of 128 bytes).
  - if the Max Payload Size is 256 bytes or more, set the DMA writewater mark bits (bits19-21) of DMA Read/Write Control register to 111b (for a watermark of 256 bytes).
- 6. Set 0x6c[1:0] = 00b to allow 64 byte cache alignment for DMA writes on 5719.
- 7. Optionally, set DMA byte swapping by setting the Byte\_Swap\_Non-Frame\_Data, Byte\_Swap\_Data and Word\_Swap\_Data bits in the General Mode Control register (see "Mode Control Register (offset: 0x6800)" on page 416. If the host processor architecture is big-endian, the MAC may byte swap both control and frame data, when acting as a PCI DMA master.
- 8. Configure the host-based send ring by setting the Host\_Send\_BDs bit in the General Mode Control register (see "Mode Control Register (offset: 0x6800)" on page 416).
- Now that the Indicate Driver is ready to receive traffic, set the Host\_Stack\_Up bit in the General Mode Control register (see "Mode Control Register (offset: 0x6800)" on page 416).
- 10. Configure TCP/UDP pseudo header checksum offloading.
  - This step is relevant when TCP/UDP checksum calculations are offloaded to the device. The device driver may optionally disable receive and transmit pseudo header checksum calculations by the device by setting the Receive\_No\_PseudoHeader\_Checksum and Send\_No\_PseudoHeader\_Checksum bits in the General Mode Control register (see "Mode Control Register (Offset 0x6800)"). If the Send\_No\_PsuedoHeader\_Checksum bit is set, the host software must seed the correct pseudo header checksum value in TCP/UDP checksum field. Similarly, if the Receive\_No\_PsuedoHeader\_Checksum bit is set, the device driver must calculate the pseudo header checksum and add it to the TCP/UDP checksum field of the received packet.
- 11. Configure MAC Mbuf memory pool watermarks ("MAC RX MBUF Low Watermark Register (offset: 0x4414)" on page 383, and "Read DMA MBUF High Watermark Register (offset: 0x4418)" on page 383). Broadcom has run hardware simulations on the Mbuf usage and strongly recommends the settings shown in Table 38. These settings/values establish proper operation for 10/100/1000 speeds.

#### Table 38: Recommended BCM57XX Ethernet Controller Memory Pool Watermark Settings

| Register                           | Standard Ethernet Frames |
|------------------------------------|--------------------------|
| MAC RX Mbuf Low Watermark (0x4414) | 0x2A                     |
| Mbuf High Watermark (0x4418)       | 0xA0                     |

**NOTE:** The Low WaterMark Max Receive Frames register (0x504) specifies the number of good frames to receive after RxMbuf Low Watermark has been reached. The driver software must make sure that the MAC RxMbuf Low WaterMark is greater than the number of Mbufs required for receiving the number of frames as specified in 0x504. The first Mbuf in the Mbuf chain of a frame will have 80 bytes of packet data while each of the subsequent Mbufs [except the last Mbuf] will have 120 bytes for packet data. The last Mbuf in the chain will have the rest of the packet data which can be up to 120 bytes.

12. Configure flow control behavior when the Rx Mbuf low watermark level has been reached (see Table 39).

Table 39: Recommended BCM57XX Ethernet controller Low Watermark Maximum Receive Frames Settings

| Register                                      | Recommended Value |
|-----------------------------------------------|-------------------|
| Low Water Mark Maximum Receive Frames (0x504) | 1                 |

- 13. Enable the buffer manager by setting the Enable and Attn\_Enable bits in the Buffer Manager Mode register (see "Buffer Manager Mode Register (offset: 0x4400)" on page 381). The buffer manager handles the internal allocation of memory resources for send and receive traffic.
- 14. Set the BD Ring Replenish threshold for the RX Producer Ring. The threshold values indicate the number of buffer descriptors that must be indicated by the host software before a DMA is initiated to fetch additional receive descriptors in order to replenish used receive descriptors. The recommended configuration value for the standard receive BD Ring replenish threshold is 0x19 (see "Standard Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C18)" on page 330)
- 15. Initialize the standard receive Buffer Ring. Host software must write the Ring Control Block structure (see "Ring Control Block" on page 85) to the standard receive BD Ring RCB register (see "Standard Receive BD Ring RCB Registers" on page 324"). Host software must initialize the host physical memory address based on allocation routines specific to the OS.
- 16. Initialize the Max len/Flags Receive Ring RCB register (0x2458).
- **NOTE:** Beginning with the BCM57785 and BCM571X/BCM5720 families of controllers, field 15:2 no longer specifies the maximum expected size of a receive frame (it was formerly "Reserved").
- **NOTE:** For the BCM571X/BCM5720 family, do not initialize the Receive Producer Ring NIC Address register (offset: 0x245C).
- 17. Initialize Receive BD Standard Producer Ring Index (0x26C) to zero.
- 18. Initialize the Standard Ring Replenish Watermark register (offset: 0x2d00). The recommended value is 0x20. If supporting Jumbo frames, also initialize 0x2d04 (the recommended value is 0x10). See "Jumbo Frames" on page 93 for more information about supporting Jumbo frames.
- 19. Initialize the Send Ring Producer Index registers by clearing (that is, set to zero) the Send BD Ring Host Producer index (see "Send BD Ring Host Producer Index Register (offset: 0x300–0x307)" on page 271).
- 20. Disable unused Receive Return Rings. Host software must write the RCB\_FLAG\_RING\_DISABLED bit to the flags field of the ring control blocks of all unused Receive Return Rings.

- 21. Initialize Receive Return Rings. The Receive Return Ring RCBs are located in the Miscellaneous Memory region from 0x200 to 0x2FF. Host software must initialize the host physical memory address based on allocation routines specific to the OS. The Max\_Len field indicates the ring size and it can be configured to either 32 or 64 or 128 or 256 or 512 or 1024, 2048, or 4096 depending on which ring's RCB is being initialized.
- 22. Initialize the Receive Producer Ring mailbox registers. The driver must write the value 0x00000000 (clear) to the low 32 bits of the Receive BD Standard Producer Ring Index mailbox (see "Receive BD Standard Producer Ring Index Register (offset: 0x5868)" on page 409).
- **NOTE:** The host software must ensure that on systems that support more than 4 GB of physical memory, Send Rings, Receive Return Rings, Producer Rings, and packet buffers are not allocated across the 4 GB memory boundary. For example, if the starting memory address of the Standard Receive Buffer Ring is below 4 GB and the ending address is above 4 GB, a read DMA PCI host address overflow error may be generated (see "LSO Read DMA Status Register (offset: 0x4804)" on page 387).
  - The Standard RX Producer threshold value should be set very low. Some operating systems may run short of memory resources and the number of BDs that are made available will decrease proportionally. The maximum number of Send BDs for a single packet is (0.75)\*(ring size).
- 23. Configure the MAC unicast address. See "MAC Address Setup/Configuration" on page 111 for a full description of unicast MAC address initialization.
- 24. Configure random backoff seed for transmit. See the Ethernet Transmit Random Backoff register (see "Ethernet Transmit Random Backoff Register (offset: 0x438)" on page 277). Broadcom recommends using the following algorithm:

  Seed = (MAC\_ADDR[0] + MAC\_ADDR[1] + MAC\_ADDR[2] + MAC\_ADDR[3] + MAC\_ADDR[4] + MAC\_ADDR[5]) & 0x3FF
- 25. Configure the Message Transfer Unit MTU size. The MTU sets the upper boundary on RX packet size; packets larger than the MTU are marked oversized and discarded by the RX MAC. The MTU bit field in the Receive MTU Size register (see "Receive MTU Size Register (offset: 0x43C)" on page 277) must be configured before RX traffic is accepted. Host software must account for the following variables when calculating the MTU:
  - VLAN TAG
  - CRC
  - Jumbo Frames Enabled
- 26. Configure the Inter-Packet Gap (IPG) for transmit by setting the Transmit MAC Lengths register (see "Transmit MAC Lengths Register (offset: 0x464)" on page 281). The register contains three bit fields: IPG\_CRS\_Length, IPG\_Length, and Slot\_Time\_Length. The value 0x2620 should be written into this register.

NOTE: An incorrectly configured IPG introduces far end receive errors on the MAC's link partner.

- 27. Configure the default RX return ring for non-matched packets. The MAC has a rules checker, and packets do not always have a positive match. For this situation, host software must specify a default ring, where the RX packet is placed. The bit field is located in the Receive Rules Configuration register (see "Receive Rules Configuration Register (offset: 0x500)" on page 286).
- 28. Configure the number of Receive Lists. The Receive List Placement Configuration register (see "Receive List Placement Configuration Register (offset: 0x2010)" on page 316) allows host software to initialize QOS rules checking. For example, a value of 0x181 (as used by Broadcom drivers) breaks down as follows:
  - · One interrupt distribution list
  - · Sixteen active lists
  - · One bad frames class

- 29. Write the Receive List Placement Statistics mask. Broadcom drivers write a value of 0x7BFFFF (24 bits) to the Receive List Placement Statis Enable Mask register (see "Receive List Placement Statistics Enable Mask Register (offset: 0x2018)" on page 317).
- 30. Enable RX statistics by asserting the Statistics\_Enable bit in the Receive List Placement Control register (see "Receive List Placement Statistics Control Register (offset: 0x2014)" on page 317).
- 31. Enable the Send Data Initiator mask by writing 0xFFFFFF (24 bits) to the Send Data Initiator Enable Mask register (see "Send Data Initiator Statistics Mask Register (offset: 0xC0C)" on page 305").
- 32. Enable TX statistics by asserting the Statistics\_Enable and Faster\_Statistics\_Update bits in the Send Data Initiator Control register (0x0C08)
- 33. Disable the host coalescing engine by writing 0x0000 to the Host Coalescing Mode register (see "Host Coalescing Mode Register (offset: 0x3C00)" on page 367). Software needs to disable the host coalescing engine before configuring its parameters.
- 34. Poll 20 ms for the host coalescing engine to stop. Read the Host Coalescing Mode register (see "Host Coalescing Mode Register (offset: 0x3C00)" on page 367) and poll for 0x0000.
- 35. Configure the host coalescing tick count. The Receive Coalescing Ticks and Send Coalescing Ticks registers specify the number of clock ticks elapsed before an interrupt is driven (see "Receive Coalescing Ticks Register (offset: 0x3C08)" on page 368" and "Send Coalescing Ticks Register (offset: 0x3C0C)" on page 369). The clock begins ticking after RX/TX activity. Broadcom recommends the settings shown in Table 40.

Table 40: Recommended BCM57XX Ethernet Controller Host Coalescing Tick Counter Settings

| Register                         | Recommended Value |
|----------------------------------|-------------------|
| Receive Coalescing Ticks(0x3C08) | 0x48              |
| Send Coalescing Ticks(0x3C0C)    | 0x14              |

36. Configure the host coalescing BD count. The Receive Max Coalesced BD and Send Max Coalesced BD registers specify the number of frames processed before an interrupt is driven (see "Receive Max Coalesced BD Count Register (offset: 0x3C10)" on page 370 and "Send Max Coalesced BD Count Register (offset: 0x3C14)" on page 372). Broadcom recommends the settings shown in Table 41.

Table 41: Recommended BCM57XX Ethernet Controller Host Coalescing Frame Counter Settings

| Register                             | Recommended Value |
|--------------------------------------|-------------------|
| Receive Max Coalesced Frames(0x3C10) | 0x05              |
| Send Max Coalesced Frames(0x3C14)    | 0x35              |

37. Configure the max-coalesced frames during interrupt counter. While host software processes interrupts, this value is used. Broadcom recommends the settings shown in Table 42.

Table 42: Recommended BCM57XX Ethernet Controller Max Coalesced Frames During Interrupt Counter Settings

| Register                                              | Recommended Value |
|-------------------------------------------------------|-------------------|
| Receive Max Coalesced Frames During Interrupt(0x3C20) | 0x05              |
| Send Max Coalesced Frames During Interrupt(0x3C24)    | 0x05              |

- 38. Initialize host status block address. Host software must write a physical address to the Status Block Host Address register, which is the location where the MAC must DMA status data (see "Status Block Host Address Register (offset: 0x3C38)" on page 375). This register accepts a 64-bit value in register 0x3C38 (high order 32 bits) and 0x3C3C (low order 32 bits).
- 39. Enable the host coalescing engine (0x3C00 bit 1).
- 40. Enable the receive BD completion functional block by setting the Enable and Attn\_Enable bits in the Receive BD Completion Mode register (see "Receive BD Completion Mode Register (offset: 0x3000)" on page 332").
- 41. Enable the receive list placement functional block by setting the Enable bit in the Receive List Placement Mode register (see "Receive List Placement Mode Register (offset: 0x2000)" on page 315.
- 42. Enable DMA engines by setting the Enable\_FHDE, Enable\_RDE, and Enable\_TDE bits in the Ethernet Mac Mode register (see "EMAC Mode Register (offset: 0x400)" on page 272).
- 43. Enable and clear statistics by setting the Clear\_TX\_Statistics, Enable\_TX\_Statistics, Clear\_RX\_Statistics, and Enable\_TX\_Statistics bits in the Ethernet Mac Mode register (see "EMAC Mode Register (offset: 0x400)" on page 272).
- 44. Delay 40 microseconds.
- 45. Configure the General Miscellaneous Local Control register (see "Miscellaneous Local Control Register (offset: 0x6808)" on page 418). Set the Interrupt\_On\_Attention bit for MAC to assert an interrupt whenever any of the attention bits in the CPU event register are asserted.
- 46. Delay 100 microseconds.
- 47. Configure the Write DMA Mode register (see "Write DMA Mode Register (offset: 0x4C00)" on page 400). The following bits are asserted:
  - Enable (starts the functional block)
  - Write DMA PCI Target Abort Attention Enable
  - Write\_DMA\_PCI\_Master\_Abort\_Attention\_Enable
  - Write DMA PCI Parity Attention Enable
  - Write\_DMA\_PCI\_Host\_Address\_Overflow\_Attention\_Enable
  - Write\_DMA\_PCI\_FIFO\_Overerrun\_Attention\_Enable
  - Write DMA PCI FIFO Underrun Attention Enable
  - Write\_DMA\_PCI\_FIFO\_Overwrite\_Attention\_Enable
  - Write\_DMA\_Local\_Memory\_Read\_Longer\_Than\_DMA\_Length
- 48. Set bit-29 of the Write DMA Mode register (see "Write DMA Mode Register (offset: 0x4C00)" on page 400) to enable the host coalescence block fix that configures the device to send out status block update before the interrupt message.
- 49. Delay 40 microseconds.
- 50. Set register 0x4900[2] = 1 to prevent DMA overruns for BD read DMA engine. This enables a hardware function that limits all BD fetches to 256 bytes or less.
- 51. Configure the Read DMA Mode register (see "LSO Read DMA Mode Register (offset: 0x4800)" on page 386). The following bits are asserted:
  - Enable—start functional block
  - Read\_DMA\_PCI\_Target\_Abort
  - Read DMA PCI Master Abort
  - Read DMA PCI Parity Error

- Read\_DMA\_PCI\_Host\_Overflow\_Error
- Read\_DMA\_PCI\_FIFO\_Overrun\_Error
- Read DMA PCI FIFO Underrun Error
- · Read DMA PCI FIFO Overread Error
- Read\_DMA\_Local\_Memory\_Write\_Longer\_Than\_DMA\_Length
- 52. Delay 40 microseconds.
- 53. Set 0x4800[24] = 0 to allows multiple outstanding read requests from the non-LSO read DMA engine.
- 54. Set 0x4800[17:16] = 11b to allows 4KB burst length reads for Jumbo/LSO network frames.
- 55. Set 0x4910[19:18] = 11b to allow 4KB burst length reads for non-LSO (i.e. standard) network frames.
- 56. Enable the receive data completion functional block by setting the Enable and Attn\_Enable bits in the Receive Data Completion Mode register (see "Receive Data Completion Mode Register (offset: 0x2800)" on page 328).
- 57. Enable the send data completion functional block by setting the Enable bit in the Send Data Completion Mode register (see "Send Data Completion Mode Register (offset: 0x1000)" on page 308).
- 58. Enable the send BD completion functional block by setting the Enable and Attn\_Enable bits in the Send BD Completion Mode register (see "Send BD Completion Control Registers" on page 313).
- 59. Enable the receive data and BD initiator functional block by setting the Enable and Illegal\_Return\_Ring\_Size bits in the Receive Data and Receive BD Initiator Mode register (see "Receive Data and Receive BD Initiator Mode Register (offset: 0x2400)" on page 320).
- 60. Enable the send data initiator functional block. Set the Enable bit in the Send Data Initiator Mode register (see "Send Data Initiator Mode Register (offset: 0xC00)" on page 304).
- 61. Enable the send BD initiator functional block by setting the Enable and Attn\_Enable bits in the Send BD Initiator Mode register (see "Send BD Initiator Mode Register (offset: 0x1800)" on page 311).
- 62. Enable the send BD selector functional block by setting the Enable and Attn\_Enable bits in the Send BD Selector Mode register (see "Send BD Ring Selector Mode Register (offset: 0x1400)" on page 309).
- 63. Enable the transmit MAC by setting the Enable bit and the Enable\_Bad\_TxMBUF\_Lockup\_fix bit in the Transmit MAC Mode register (see "Transmit MAC Mode Register (offset: 0x45C)" on page 279). Optionally, the software may set the Enable\_Flow\_Control to enable 802.3x flow control.
- 64. Delay 100 microseconds.
- 65. Enable the receive MAC. Set the Enable bit in the Receive MAC Mode register (see "Receive MAC Mode Register (offset: 0x468)" on page 282). Optionally, the software may set the following bits:
  - Enable Flow Control bit—Enable 802.3x flow control
  - Accept\_oversized bit-Ignore RX MTU up to 64K maximum size
  - Promiscuous\_Mode bit-Accept all packets regardless of destination address
  - No CRC Check bit—RX MAC will not check Ethernet CRC
  - Various Hash Enable bits-if using RSS mode (Receive Side Scaling)
- 66. Delay 10 microseconds.
- 67. Setup the LED Control Register (0x40C). The Broadcom driver uses a value of 0x800 when initializing this register.
- 68. Activate link and enable MAC functional blocks by setting the Link\_Status bit in the MI Status register (see "MII Status Register (offset: 0x450)" on page 278) to generate a link attention.

- 69. Optionally, disable auto-polling on the management interface (see "MII Mode Register (offset: 0x454)" on page 279).
- 70. Set Low Watermark Maximum Receive Frame register (offset: 0x504) to a value of 1 for the BCM5717 and BCM 5718 family of controllers.
- 71. Configure D0 power state in PMSCR (see "Power Management" on page 158). Note that the PMCSR register is reset to 0x00 after chip reset. Software may optionally reconfigure this register if the device is being moved from D3 hot/cold.
- 72. Setup the physical layer and restart auto-negotiation. For details on PHY auto-negotiation, refer to the applicable PHY data sheet.
- 73. Setup multicast filters. See "Packet Filtering" on page 111 for details on multicast filter setup.
- 74. Enable the Host Interrupt:
  - a. Set the Clear\_Interrupt bit in the Miscellaneous Host Control register (offset: 0x68) to clear the interrupt and Clear the Mask\_Interrupt bit in the Miscellaneous Host Control register (offset: 0x68) to unmask the interrupt.
  - b. Set the interrupt mail box register (offset: 0x200) to 0.

#### 7.2 Device Reset Procedure

- 1. Write the T3\_MAGIC\_NUMBER (0x4B657654 = KevT) to the device memory at offset 0xB50 to notify the bootcode that the reset is a warm reset (driver initiated core\_clocks reset).
- 2. Save PCI command register 0x4 before chip reset (GRC\_MISC\_CFG core clock reset will clear the memory enable bit in PCI register 0x4, so we save relevant registers here)
- 3. Clear the Fast Boot Program Counter register (Offset 0x6894) and enable the Memory Arbiter (see "Memory Arbiter Mode Register (offset: 0x4000)" on page 379).
- 4. Initialize the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245).
  - a. Set the Enable\_Endian\_Word\_Swap bit in the Miscellaneous Host Control register, when the host processor architecture is little-endian. Set the Enable\_Endian\_Word\_Swap bit and the Enable\_Endian\_Byte\_Swap bit in the Miscellaneous Host Control register, when the host processor architecture is big-endian.
  - b. Enable the indirect register pairs by setting the Enable\_Indirect\_Access bit in the Miscellaneous Host Control register (see "Indirect Mode" on page 143).
  - c. Enable the PCI State register to allow the device driver read/write access by setting the Enable\_PCI\_State\_Register bit in the Miscellaneous Host Control register.
- 5. Reset the core clocks by setting the CORE\_Clock\_Blocks-Reset bit in the General Control Miscellaneous Configuration register and setting the Disable\_GRC\_Reset\_on\_PCI-E\_Block bit (bit-29) to 1 ("Miscellaneous Configuration Register (offset: 0x6804)" on page 418).
- 6. Wait for the core-clock reset to complete. The core clock reset disables indirect mode and flat/standard modes ¡X software cannot poll the core-clock reset bit to deassert, since the local memory interface is disabled by the reset. Delay a minimum of 1 millisecond before continuing the initialization sequence.
- 7. Enable MAC memory space decode and bus mastering by setting the Bus\_Master and Memory\_Space bits in the PCI Configuration Space Command register (see "Status and Command Register (offset: 0x04)" on page 235).
- 8. Enable the MAC memory arbiter by setting the Enable bit in the Memory Arbiter Mode register (see "Memory Arbiter Mode Register (offset: 0x4000)" on page 379).
- 9. Initialize the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245).

- a. Set the Enable\_Endian\_Word\_Swap bit in the Miscellaneous Host Control register, when the host processor architecture is little-endian. Set the Enable\_Endian\_Word\_Swap bit and the Enable\_Endian\_Byte\_Swap bit in the Miscellaneous Host Control register, when the host processor architecture is big-endian.
- b. Enable the indirect register pairs by setting the Enable\_Indirect\_Access bit in the Miscellaneous Host Control register (see "Indirect Mode" on page 143).
- c. Enable the PCI State register to allow the device driver read/write access by setting the Enable\_PCI\_State\_Register bit in the Miscellaneous Host Control register.
- 10. Set Word\_Swap\_Data, Byte\_Swap\_Data, and win the General Mode Control register when the host processor architecture is little endian. Optionally, set Byte\_Swap\_Non\_Frame\_Data in the General Mode Control register when the host processor architecture is big endian, (see "Mode Control Register (offset: 0x6800)" on page 416).
- 11. Poll for bootcode completion. The device driver must poll the general communication memory at 0xB50 for the one is complement of the T3\_MAGIC\_NUMBER (that is, 0xB49A89AB). The bootcode should complete initialization within 1000 ms for Flash devices and 10000 ms for SEEPROM devices.

# 7.3 Device Closing Procedure

This section describes the device close procedure for the MAC portion of the NetXtreme family of devices.

- 1. Disable Host Interrupt.
  - a. Set the Mask\_Interrupt bit in the Miscellaneous Host Control register (offset: 0x68) to disable interrupt
  - b. Set the interrupt mail box register (offset: 0x200)
- 2. Tell Firmware the driver is shutting down and doing prereset.

Note: Do this only if ASF enabled.

- a. Write the 0x2 to the device memory (offset: 0xB78) to PAUSE the firmware
- b. Set the RX-CPU Event register (offset: 0x6810) bit14 (SW Event 7) 7 bit and wait for SW bit14 (SW Event 7) to be clear
- c. Write MAGIC Number 0x4B657654 to the device memory (offset: 0xB50)
- d. Write 0x2 to the device memory (offset 0xc04)
- 3. Disable all the receiver blocks.
  - a. Clear the Enable bit in the Receive MAC Mode register (offset: 0x468)
  - b. Clear the Enable bit in the Receive BD Initiator Mode register (offset: 0x2C00)
  - c. Clear the Enable bit in the Receive List Placement Mode register (offset: 0x2000)
  - d. Clear the Enable bit in the Receive BD Initiator Mode register (offset: 0x2400)
  - e. Clear the Enable bit in the Receive Data Completion Mode Register (offset: 0x2800)
  - f. Clear the Enable bit in the Receive BD Completion Mode Register (offset: 0x3000)
- 4. Disable all the transmit blocks.
  - a. Clear the Enable bit in the Send BD Selector Mode register (offset: 0x1400)
  - b. Clear the Enable bit in the Send BD Initiator Mode Register (offset: 0x1800)
  - c. Clear the Enable bit in the Send Data Initiator Mode Register (offset: 0xC00)
  - d. Clear the Enable bit in the Read DMA Mode Register (offset: 0x4800)
  - e. Clear the Enable bit in the Send Data Completion Mode Register (offset: 0x1000)
  - f. Clear the Enable bit in the Send BD Initiator Mode Register (offset: 0x1C00)

- 5. Shut down all of the memory managers and related state machines.
  - a. Clear the Enable bit in the Host Coalescing Mode Register (offset: 0x3C00)
  - b. Clear the Enable bit in the Write DMA Mode Register (offset: 0x4C00)
  - c. Reset the FTQ by setting 0xfffffff to the FTQ Reset Register (offset: 0x5C00)
  - d. Set FTQ Reset Register 0x5C00 to 0
- 6. Reset the controller. Call Device Reset Procedure (see "Device Reset Procedure" on page 121)
- 7. Instruct the firmware do the following post reset:

Note: Do this only if ASF enabled.

- a. write 0x2 to the device memory (offset 0xc04)
- b. write 0x80000002 to the device memory (offset 0xc04)
- 8. Free the RX/TX Ring list and buffers.
- 9. Set PCI power state to D3hot.

# 7.4 Energy Efficient Ethernet<sup>™</sup>

The BCM571X/BCM5720 family of controllers supports the IEEE specification for Energy Efficient Ethernet (EEE) (IEEE 802.3az-2010). The algorithm below describes how to initialize and enable EEE mode in the BCM571X/BCM5720 family of controllers.

```
* Controller EEE initialization
// Disable LPI requests
val = reg read(0x36B0);
val &= 0xFFFFFF7F;
reg write(0x36B0, val);
// Setup PHY DSP for EEE
mii write(0x18, 0x0C00);
mii write(0x17, 0x4022);
mii_write(0x15, 0x017B);
mii write(0x18, 0x0400);
if (enable EEE advertisement)
    // Enable EEE advertisement for 100Base-TX and 1000Base-T modes
    mii write(0x0D, 0x0007);
    mii_write(0x0E, 0x003C);
    mii write (0x0D, 0x4007);
    mii write(0x0E, 0x0006);
    val = mii read(0x0E);
    //Enable MAC control of LPI
    reg write (0x36BC, 0x01000004);
    reg write (0x36D0, 0x000001F8);
    reg write (0x36B0,0x00100348);
    // Set EEE timer debounce values
```

```
reg write(0x36B4,0x07ff07ff);
    reg write(0x36B8,0x07ff07ff);
}
else
{
    // Disable EEE advertisement for 100Base-TX and 1000Base-T modes
    mii write(0x0D, 0x0007);
    mii write(0x0E, 0x003C);
    mii_write(0x0D, 0x4007);
    mii_write(0x0E, 0x0000);
    val = mii read(0x0E);
    // Disable MAC control of LPI
    reg write(0x36B0, reg read(0x36B0) &= 0x00100000);
}
 * Link status interrupt handler
// Check for PHY link status
if ((mii read(0x11) \& 0x100) == 0x100)
    // Check for 1000mb link
    if ((mii read(0x19) & 0x700) == 0x700)
        // Set EEE LPI exit timing for 1000mb link speed
        reg write(0x36d0, 0x19d);
    // Check for 100mb link
    elseif ((mii read(0x19) & 0x500) == 0x500)
        // Set EEE LPI exit timing for 100mb link speed
        reg write(0x36d0, 0x384);
    }
    //delay 1000 milliseconds
    ms_delay(1000);
    // Read PHY's EEE negotiation status
    mii write(0x0d, 7);
    mii_write(0x0e, 0x803e);
    mii_write(0x0d, 0x4007);
    val = mii_read(0x0e);
    // Enable EEE LPI request if EEE negotiated
    if (4 == val || 2 == val)
       reg write(0x0x36b0, reg read(0x36b0) | 0x80);
    }
    break;
else
```

```
{
    // Disable LPI requests
    val = reg_read(0x36B0);
    val &= 0xFFFFFF7F;
    reg_write(0x36B0, val);
}
```

After the controller is fully initialized, the following algorithm may be used to verify EEE link status:

```
i=0
while (i < 100)
    if ((mii read(0x11) \& 0x100) == 0x100)
        if ((mii read(0x19) \& 0x700) == 0x700)
            if (((mii_read(0xA) & 0x7000) == 0x7000) | |
               ((mii read(0xA) & 0x3000) == 0x3000)))
                  //link negotiated to gigabit master or slave
                  reg write(0x36d0, 0x19d);
        elseif ((mii read(0x19) & 0x500) == 0x500)
            //link negotiated to 100Mbps
            reg write(0x36d0, 0x384);
        ms delay(1000);//delay 1000 milliseconds
        //Assert LPI
        reg_write(0x36b0,(reg_read(0x36b0) | 0x80))
        break;
    }
    else
    {
        ms delay(500);//delay 500 milliseconds
        i++;
    }
}
if (i >= 100)
{
    Link_not_detected();
}
```

# Chapter 8: IEEE1588

# 8.1 IEEE1588 Time Sync Introduction

IEEE1588 and IEEE802.1AS are two protocols designed to perform time synchronization over Ethernet networks. IEEE1588 Precision Time Protocol (PTP) provides a UDP packet based time synchronization mechanism, while IEEE802.1AS extends PTP to operate directly over the L2 or Ethernet layer. Time precision offered by PTP is in the sub-microsecond range and, in fact, can get down to a Nanosecond.

# 8.2 NetXtreme Time Sync Assist

NetXtreme architecture provides a set of hardware (HW) features to assist IEEE1588 and IEEE802.1AS traffic over Ethernet. Both 1588 and 802.1AS are complex protocols from the perspective of statefulness and are best implemented by a software module resident in the host computer. However, since these protocols demand a sub-microsecond, in some cases nanosecond grade precision, long latencies encountered by host software do not permit these protocols to be implemented in software (Host CPU) in their entirety. The goal of NetXtreme architecture is to provide the cheapest and simplest set of HW hooks so that a service grade PTP profile may be enabled in the host server computer.

The assists that NetXtreme provides are:

- A 64-bit Counter clocked by the 125 MHz DLL clock to serve as the Precision Clock Thus 8ns is the maximum precision offered. This clock is known as the EAV Reference Clock.
- A 64-bit Transmit Time Stamp Register Software shall mark certain types of PTP message Packets in turn for TX hardware to capture launch time of that packet.
- A 64-bit Receive Time Stamp Register RX hardware shall crack and identify certain types of PTP packets as configured by host SW. The reception time of such a packet shall be recorded in this register. Host SW shall retain the control to choose which PTP message Types get time stamped.

This feature, Time Sync Assist, may be enabled by setting a Mode bit in the chip.

#### 8.2.1 Coexistence

The Time Sync Assist feature coexists with the following NetXtreme features:

- VLAN Tagging In-band or out-of-band
- SNAP/LLC Framing Transmit and receive.
- Transmit LSO Note that PTP packets cannot be TCP segments.
- Transmit IP, UDP, TCP checksum offload IP/UDP Transmit Checksum offload is applicable to UDP PTP packets, provided the packets are appropriately formatted by the software protocol engine, that is, 2B UDP padding, etc must be handled by software.

### 8.2.2 PTP Link Delay Measurement

At the completion of the Delay Request/Response exchange, the delay requester uses four timestamps (t1, t2, t3, t4) to compute the link delay. The link delay is computed as the average of the two one-way delays using the following formula:

$$T \text{ delay} = [(t2 - t1) + (t4 - t3)] / 4$$

Assume that both nodes contain a NetXtreme Time-Synch Capable NIC. Table 43 describes the roles the PTP software component and the Time-Synch capable NIC hardware play during the above exchange.

Table 43: PTP Link Delay Measure Roles

|    | Delay Requester                                |                                                                                         | Delay Responder                                                                  |                                                                        |  |
|----|------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------|--|
|    | Host Software                                  | NIC Hardware                                                                            | NIC Hardware                                                                     | Host Software                                                          |  |
| 1  | TX PTP Delay Request packet-<br>mark capture → | Capture TX stamp (t1) →                                                                 | _                                                                                | _                                                                      |  |
| 2  | _                                              | _                                                                                       | → Receive and identify PTP delay request packet, then capture RX Time Stamp (t2) | → Receive packet, Read RX<br>Time Stamp Reg.                           |  |
| 3a | _                                              | _                                                                                       | Capture TX Time Stamp (t3) ←                                                     | TX PTP Delay Response packet with embedded (t2) value — mark capture ← |  |
| 4  | ← Receive Packet, Read RX<br>Time Stamp Reg    | Receive and identify PTP Delay<br>Response packet, then capture<br>RX Time Stamp (t4) ← | _                                                                                | _                                                                      |  |
| 3b | Receive packet                                 | -                                                                                       | ← (pass through)                                                                 | TX PTP Delay Response<br>Follow-up packet with<br>embedded (t3) value  |  |
| 5  | Collect t1, t2, t3, and t4 to compute T delay. | _                                                                                       | _                                                                                | _                                                                      |  |

# 8.2.3 PTP Time Synchronization Messaging

The secondary device then uses the link delay (Tdelay) and the Sync Message timestamps (t1, t2) to calculate the time offset it needs to compensate its local clock by using the following equation:

Tslave-offset = t2 - t1 - Tdelay

Assume that both nodes contain a NetXtreme Time-Synch Capable NIC. Table 44 on page 127 describes the roles the PTP software component and Time-Synch capable NIC hardware play during above exchange.

**Table 44: PTP Time Synchronization Messaging Roles** 

|   | PTP Primary Node                                        |                         | PTP Secondary Node                                                      |                                              |  |
|---|---------------------------------------------------------|-------------------------|-------------------------------------------------------------------------|----------------------------------------------|--|
|   | Host Software                                           | NIC Hardware            | NIC Hardware                                                            | Host Software                                |  |
| 1 | TX PTP Sync packet—mark capture →                       | Capture TX stamp (t1) → |                                                                         |                                              |  |
| 2 |                                                         |                         | → Receive and identify PTP sync packet, then capture RX Time Stamp (t2) | → Receive packet, Read RX<br>Time Stamp Reg. |  |
| 3 | TX PTP Sync Follow-up packet with embedded (t1) value → |                         | → (pass through)                                                        | → Receive PTP Follow-up packet               |  |

#### Table 44: PTP Time Synchronization Messaging Roles (Cont.)

|   | PTP Primary Node |              | PTP Secondary Node |                                                                  |  |
|---|------------------|--------------|--------------------|------------------------------------------------------------------|--|
|   | Host Software    | NIC Hardware | NIC Hardware       | Host Software                                                    |  |
| 4 |                  |              |                    | Collect t1, t2, and Tdelay to compute the secondary Offset value |  |

# 8.3 Hardware Description

The following items describe the included hardware:

#### Clock Hardware:

- EAV Reference Clock this clock is neither the Primary-clock nor the Secondary-clock, but a specific clock. All time related hardware services are provided with respect to this clock.
- Reference Time Capture off an external GPIO Trigger
- A Time Watchdog that drives a GPIO output pin upon meeting a programmable time value
- A divided EAV Reference Clock output

#### Transmit Time Sync hardware:

- A 64-bit TX Time Stamp Register.
- A bit defined in Send BD for indication of TX Time capture

#### Receive Time Sync hardware:

- Programmable Receive Frame Cracker.
- A 64-bit RX Time Stamp Register + A 16-bit RX PTP Sequence ID Register
- An RX Time Stamp Lock Timer

Each of the above items is described separately in the following sections.

#### 8.3.1 EAV Reference Clock/Counter

The EAV Reference Clock (Count) is a 64-bit free-running clock-tick counter with a 1ns time base. All Real-Time sensitive services needed by EAV are in reference to this counter. In the 5719/5720 chip, this counter is clocked by a 125 MHz free running DLL. Therefore, the precision of this counter is limited to 8ns for this generation of NIC. This implies that the LSB 3-bits of EAV Reference Count shall always be "000" in this chip. This counter will emerge with a 0 value from Power on Reset and always count upwards. After reaching the full count, the counter will roll-over to 0 and count up again. These two counters are the only static attributes of this clock. The rest are programmable.

Time referencing, Time-stamping, Time-sampling, etc. all real-time interfacing of the chip hardware with the AV Device Driver shall be performed in reference to this counter.

The following are the instrumentations available for the EAV Reference Counter:

- Reset Control: The Driver has the option to configure the EAV Reference Counter to be reset in response to the following events:
  - a. GRC Reset (MAC-core soft reset) and PCIE FLR (if supported)
  - b. PCle Link Reset
  - c. Network Link transition from UP→DOWN
  - d. Network Link transition from DOWN→UP
- 2. Explicit Driver Controls:
  - a. Driver may reset the counter.
  - b. Driver may stop the counter.
  - c. Driver may restart the counter after being stopped.
  - d. Driver may over-write the counter value by PIO write.
- 3. The driver may read the value of the free-running counter anytime. For that purpose, a 32-bit Register pair is provided.
- 4. The driver may take a snap-shot of this counter.

#### **8.4 EAV Reference Corrector**

The 64-bit EAV Ref Count described in the previous section is the integer porting of the counter. This is the part visible to the system for time stamping purposes. There is also a 24-bit correction field associated with the EAV Reference Count. This field is used by the host system to periodically add or subtract a minimum resolution value from the EAV Reference Count, in case of 5719/5720. That value happens to be 8 nanoseconds. This feature is mainly used to compensate for the local crystal/PLL drifts. The add/subtract operation is performed entirely in hardware. Software is responsible only for programming the EAV Reference Corrector field appropriately.

The Corrector features a Correction-Value and a Correction-Sense sub-field. Host software (in this case the software PTP module) must compute the correction amount and then load the Correction-Value/Sense fields accordingly. The programmed value could be anything from 0x000001 through 0xFFFFFF. A value 0x0 is NOT permitted. The Correction-Value is added to a 24-bit accumulator for every EAV Reference Clock tick (accumulator is re-initiated to 0 at POR reset and every time the Corrector register is updated). Therefore, the accumulator's value will increase with every EAV Ref clock cycle until it overflows. In the EAV Reference Clock tick in which the accumulator overflows, the hardware reloads the accumulator with the last programmed Correction-Value. On the same clock cycle, based on the programmed Correction-Sense, the hardware either adds or subtracts 8 ns from EAV Reference Count. Therefore, the host software controls the sense, value, and period of an automatic hardware based correction. Although software may re-program the EAV Reference Corrector frequently, be cautious that a large negative correction-value may result in out of order time-stamps.

### 8.4.1 Time Watchdogs

A Time Watchdog is a 64-bit register that may be programmed by host software to a specific time value in the future. When the value of the EAV Reference Count equates the value of the Time Watchdog, the 1588\_GPIO[n] output pin is toggled. There are two such Time Watchdogs that work independently.

### 8.4.2 Divided EAV Reference Clock Output

An additional PLL channel output has been routed to an external pin. This output clock is edge synchronous to the EAV Reference clock, although there could be a < 5ns routing delay present. A register is available in the CPMU block in which the clock-divisor value may be programmed by host software. The available output frequency range is 125 MHz through 4.8 MHz. See the Flash Clock Policy Register (0x366C).

# 8.5 Transmit Time Stamping Service

The software can mark certain types of PTP packets (Delay Request, Synch etc) and the NIC hardware captures the time when such a packet's first byte, or SOF, is launched for transmission. Ideally, the time capture is the instant of the actual SOF launch on the wire, but due to practical limitations, the capture will take place at the time the SOF appears on GMII interface among EMAC and GPHY. The propagation delay through the GPHY is virtually fixed, and hence, could easily be accounted for by system software. The captured time is in reference to the EAV Reference Count. There is only a single 64-bit register, the TX Time Stamp Register, for this purpose. The precision of this stamp is 1ns. System software may read the value of this register anytime to get the time-stamp of last sent PTP packet. Reference the following table of send ring SBD for IEEE1588.



Table 45: Send Ring SBD Flags

| Bit # | Flag Name                       | Flag Description                                                                                                                                                                                                                                     |
|-------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TCP/UDP Checksum Offload Enable | This bit enables calculation of TCP or UDP checksums for IPv4 and IPv6 transmitted packets. The driver will set this bit only if the packet contained within a buffer is TCP or UDP over IPv4 or IPv6.                                               |
| 1     | IP Checksum Offload enable      | This bit enables calculation of the IPv4 layer-3 checksum. This bit will be set only for IPv4 packets. The driver will never be set for IPv6 packets.                                                                                                |
| 2     | Packet End                      | This bit will be set for the last send buffer in a packet.                                                                                                                                                                                           |
| 3     | Jumbo Frame                     | Driver must set this bit to 1 if the MTU length of the Send Frame is > 1500B. The MTU length is the Ethernet payload length and excludes Header length (and Trailer length). All BDs belonging to a Send Packet must configure this bit identically. |
| 4     | HDRLEN[2]                       | The length of the Ether+IP+TCP Headers to be replicated in each segment arising out of a Large TCP Segment (LSO).                                                                                                                                    |
| 5     | Capture Time Stamp              | If this bit is 1, this frame's launch time shall be captured in the TX Time-Stamp Register.                                                                                                                                                          |
| 6     | VLAN TAG                        | When this bit is set, the NIC will insert a VLAN tag in the Ethernet header. The value for the inserted tag is taken from the VLAN Tag field in the send BD.                                                                                         |

# 8.6 Receive Time Stamp and Sequence ID Registers

The time of reception of chosen PTP frames shall be recorded by hardware in the RX Time Stamp Register. The place of time capture is the GMII interface, the point of capture is arrival of the SOF octet and the reference of time is the EAV Reference Count. Thus, the time of appearance of the SOF octet of every RX frame on the internal GMII interface needs to be recorded by hardware and held it in a temporary register or a temporary FIFO. After reception of a complete frame, upon examining the RX Frame cracker results, hardware shall decide if that particular Frame had the Host SW desirable PTP message type and only then it will transfer its acquired time stamp into the RX Time Stamp Register. Along with the RX Time Stamp, hardware shall also capture the respective PTP packets sequenceID field. Hardware shall also mark a status field in a packet's Receive BD indicating if the packet was a PTP packet and also if RX Time Stamp was captured for the packet.



Table 46: Receive Return Ring RBD Flags

| Bit# | Flag Name       | Flag Description                                                                                                                         |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | PTP Packet Type | 00: PTP Delay Request Packet                                                                                                             |
|      |                 | 01: PTP Delay Response Packet                                                                                                            |
|      |                 | 10: PTP Sync Packet                                                                                                                      |
|      |                 | 11: All other type of PTP Packets                                                                                                        |
| 2    | BD_FLAG_END     | The frame ends at the end of the data in this buffer descriptor.                                                                         |
| 3    | RSS_HASH_VALID  | If this bit is 1, then the RSS_HASH_TYPE field is valid. Else the RSS_HASH_TYPE field is meaningless and must be ignored for this frame. |
| 4    | PTP Status[0]   | Bit{[9][4]} makes up this 2-bit field                                                                                                    |
|      |                 | 00: Not a PTP packet                                                                                                                     |
|      |                 | 01: PTP v1 (UDP) packet Time Stamped                                                                                                     |
|      |                 | 10: PTP v2 (L2) packet Time Stamped                                                                                                      |
|      |                 | 11: PTP packet, but not time stamped                                                                                                     |

#### Table 46: Receive Return Ring RBD Flags (Cont.)

| Bit# | Flag Name               | Flag Description                                                                                                                                                                                            |
|------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | BD_FLAG_JUMBO_RING      | Indicates that this packet came from the Jumbo Receive Ring, not the Standard Receive Ring (for receive BDs only). This must be set by the driver, it is just copied through opaquely by the NMIC firmware. |
| 6    | BD_FLAG_VLAN_TAG        | The frame associated with this buffer descriptor has an 802.1Q VLAN tag associated with it.                                                                                                                 |
| 7    | RSS_HASH_TYPE           | Hash type of the receive packet. It indicates which hash_type was used on the                                                                                                                               |
| 8    |                         | receive packet if multiple hash types are defined.                                                                                                                                                          |
| 9    | PTP Status[1]           | See bit [4]                                                                                                                                                                                                 |
| 10   | BD_FLAG_FRAME_HAS_ERROR | An error was detected by the NIC. The detected error type is set in the Error_Flag word of the receive buffer descriptor.                                                                                   |
| 11   | Reserved                |                                                                                                                                                                                                             |
| 12   | IP_CHECKSUM             | Indicates that the IP Checksum field is valid.                                                                                                                                                              |
| 13   | TCP_UDP_CHECKSUM        | Indicates that the TCP_UDP_Checksum field is valid.                                                                                                                                                         |
| 14   | TCP_UDP_IS_TCP          | Indicates that this frame has a TCP packet in it.                                                                                                                                                           |
| 15   | IPV6_PACKET             | Indicates that this frame has an IPv6 packet in it.                                                                                                                                                         |

# 8.7 Time Sync Registers

# 8.7.1 GRC MODE REG [0x6800]

| Name                  | Bits  | Access | Default Value | Description                                   |
|-----------------------|-------|--------|---------------|-----------------------------------------------|
| Legacy                | 31:20 |        |               |                                               |
| Time Sync Mode Enable | 19    | RW     | 0             | Write 1 to this bit to enable Time Sync Mode. |
| Legacy                | 20:0  |        |               |                                               |

### 8.7.2 EAV REF COUNT CAPTURE LSB REG [Offset 0x6900]

The MSB and LSB registers are interface to the actual EAV Ref Counter hardware. The Counter value may be read via this pair anytime and even be overwritten by this pair anytime. While reading the pair, the hardware Counter does not stop, only its value is latched in this pair.

The only two legal sequences of accessing this pair are Read-LSB followed by Read-MSB and Write-LSB followed by Write-MSB.

| Name                             | Bits | Access | Default Value | Description                                                                                                                                                                       |
|----------------------------------|------|--------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAV Reference Count [lower half] | 31:3 | RW     | UUUU          | LSB of the EAV Reference Count – Reading this LSB latches a Count in this pair until the time the corresponding MSB is read.                                                      |
|                                  |      |        |               | Writing to this LSB latches the value in this pair and the subsequent write to the MSB transfers the 64-bit value to EAV Ref Counter and counting immediately resumes from there. |
| Reserved                         | 2:0  | RO     | 000           | [2:0] shall always be 000.                                                                                                                                                        |

# 8.7.3 EAV REF COUNT CAPTURE MSB REG [Offset 0x6904]

| Name                             | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------|------|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAV Reference Count [Upper half] | 31:0 | RW     | υυυυ          | MSB of the EAV Reference Count – See the pairing LSB register. Reading this register returns the MSB of the 64- bit EAV Ref count previously latched by performing an LSB read. Writing to this MSB transfers the 64-bit value, this plus previously latched LSB, to EAV Ref Counter and counting immediately resumes from there.  Back-to-back writes to this MSB have no effect. |

# 8.7.4 EAV REF CLOCK CONTROL REG [Offset 0x6908]

This register controls the EAV Reference Counter and the TimeSync related GPIO pins. Each MAC's 1588 HW owns a dedicated TimeSync\_GPIO pin which may be connected to any of its four Snap-shot/WatchDog HW logic. If a MAC needs to use more pins beyond its TimeSync\_GPIO pin, it may use any or all of the four APE\_GPIO[3:0] pins – note that these pins are shared among APE HW and four MAC-1588 HW. Thus a platform must design-in these pins and have individual BootCode or FW configure this register and APEGPIO register accordingly.

**NOTE:** HW behavior shall be indeterminate in case of conflicting or duplicate assignment of GPIO pins to the same resource. A platform design MUST allocate its dedicated TimeSync\_GPIO pin first before using any pin from APE\_GPIO shared pool (we are talking PCB/Hardware design here).

| Name                             | Bits  | Access | Default Value | Description                                                        |
|----------------------------------|-------|--------|---------------|--------------------------------------------------------------------|
| Reserved                         | 31:30 | RO     | 00            | -                                                                  |
| APE_GPIO[3] Mapping              | 29:27 | RW     | 000           | Same as below                                                      |
| APE_GPIO[2] Mapping              | 26:24 | RW     | 000           | Same as below                                                      |
| APE_GPIO[1] Mapping              | 23:21 | RW     | 000           | Same as below                                                      |
| APE_GPIO[0] Mapping              | 20:18 | RW     | 000           | An APE_GPIO[n] pin is mapped to 1588 input/output via this field:  |
|                                  |       |        |               | 000 => Do not use APE_GPIO[n] pin                                  |
|                                  |       |        |               | 001 => Reserved                                                    |
|                                  |       |        |               | 010 => Reserved                                                    |
|                                  |       |        |               | 011 => Reserved                                                    |
|                                  |       |        |               | 100 => Use as Snap-Shot[0] Input Trigger                           |
|                                  |       |        |               | 101 => Use as Snap-Shot[1] Input Trigger                           |
|                                  |       |        |               | 110 => Use as Time Watchdog[0] Output                              |
|                                  |       |        |               | 111 => Use as Time Watchdog[1] Output                              |
| TimeSync_GPIO Mapping            | 17:16 | RW     | 00            | The MAC/Port dedicated TimeSync_GPIO pin is mapped via this field: |
|                                  |       |        |               | 00 => Use as Snap-Shot[0] Input Trigger                            |
|                                  |       |        |               | 01 => Use as Snap-Shot[1] Input Trigger                            |
|                                  |       |        |               | 10 => Use as Time Watchdog[0] Output                               |
|                                  |       |        |               | 11 => Use as Time Watchdog[1] Output                               |
| Reserved                         | 15:12 | RO     | 0x0           |                                                                    |
| Reset on Network Link            | 11    | RW     | 0             |                                                                    |
| Down -> Up                       |       |        |               |                                                                    |
| Reset on Network Link Up -> Down | 10    | RW     | 0             |                                                                    |
| Reset on GRC Reset and PCIe FLR  | 9     | RW     | 0             | Reset on GRC Reset pulse                                           |
| Reset on PCIe reset              | 8     | RW     | 0             | Reset on de-asserting edge of PCIe Reset                           |
| Reserved                         | 7:3   | RO     | 0x0           |                                                                    |
| Resume EAV Ref Count             | 2     | W1C    | 0             |                                                                    |
| Stop EAV Ref Count               | 1     | RW     | 0             |                                                                    |
| Reset EAV Ref Count              | 0     | W1C    | 0             |                                                                    |

# 8.7.5 EAV REF-COUNT SNAP-SHOT LSB[0] REG [Offset 0X6910]

This LSB and MSB pair captures the EAV Reference Count when externally triggered by the desired TimeSync/APE\_GPIO pin – a toggle serves as a trigger. The only legal sequence of accessing this pair is Read-LSB followed by Read-MSB.

| Name                                           | Bits | Access | Default Value | Description                                                                                  |
|------------------------------------------------|------|--------|---------------|----------------------------------------------------------------------------------------------|
| EAV Reference Count Snap-<br>shot [lower half] | 31:0 | RO     | U             | LSB of the EAV Reference Count as snapshotted by TimeSync/APE_GPIO [2:0] shall always be 000 |

### 8.7.6 EAV REF-COUNT SNAP-SHOT MSB[0] REG [Offset 0X6914]

| Name                                           | Bits | Access | Default Value | Description                                                        |
|------------------------------------------------|------|--------|---------------|--------------------------------------------------------------------|
| EAV Reference Count Snap-<br>shot [Upper half] | 31:0 | RO     | U             | MSB of the EAV Reference Count as snapshotted by TimeSync/APE_GPIO |

### 8.7.7 EAV REF CORRECTOR REG [Offset 0x6928]

| Name              | Bits  | Access | Default Value | Description                                                                                                                                                              |
|-------------------|-------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Correction Enable | 31    | RW     | 0             | Write a 1 to Enable the Correction feature.                                                                                                                              |
| Correction Sense  | 30    | RW     | 0             | If 0, the correction is an addition                                                                                                                                      |
|                   |       |        |               | If 1, the correction is a subtraction                                                                                                                                    |
| Reserved          | 29:24 | RO     | 0x00          | Reserved                                                                                                                                                                 |
| Correction Value  | 23:0  | RW     | 0x000001      | This value is accumulated in an accumulator every EAV REF CLK tick until it overflows – upon which the EAV REF COUNT is corrected by a 8ns unit and the acc is reloaded. |
|                   |       |        |               | A 0x0 value is not permissible.                                                                                                                                          |

### 8.7.8 TX TIME STAMP LSB REG [Offset 0x05C0]

This LSB and MSB pair captures time-stamp of transmit packets when marked to do so. The only legal sequence of accessing this pair is Read-LSB followed by Read-MSB. Once the LSB is read, the pair attains a frozen state, and is unfrozen immediately after a subsequent MSB read – if another TX packet passes to the wire between these two reads, its timestamp capture request is ignored by hardware.

| Name                       | Bits | Access | Default Value | Description                                                    |
|----------------------------|------|--------|---------------|----------------------------------------------------------------|
| TX Time Stamp [lower half] | 31:0 | RO     | U             | LSB of the TX Time Stamp – Reading this LSB freezes the time   |
|                            |      |        |               | stamp and is only unfrozen when the corresponding MSB is read. |

### 8.7.9 TX TIME STAMP MSB REG [Offset 0X05C4]

| Name                       | Bits | Access | Default Value | Description                                                  |
|----------------------------|------|--------|---------------|--------------------------------------------------------------|
| TX Time Stamp [Upper half] | 31:0 | RO     | U             | MSB of the TX Time Stamp – Reading this MSB unfreezes the    |
|                            |      |        |               | time stamp which was earlier frozen by the corresponding LSB |
|                            |      |        |               | read.                                                        |

### 8.7.10 RX TIME STAMP LSB REG [Offset 0X06B0]

| Name                       | Bits | Access | Default Value | Description               |
|----------------------------|------|--------|---------------|---------------------------|
| RX Time Stamp [lower half] | 31:0 | RO     | U             | LSB of the RX Time Stamp. |

#### 8.7.11 RX TIME STAMP MSB REG [Offset 0x06B4]

This MSB and LSB pair captures the time-stamp (63-bits) of received PTP packets when qualified to do so. HW overwrite of the Time Stamp value is controlled by an interlock policy – See "RX PTP CONTROL REG [Offset 0X06C8]" on page 137. The MSB and LSB registers may be accessed in the order of LSB first and MSB second – else the Valid / Interlock bit would not serve its purpose.

| Name                            | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                              |
|---------------------------------|------|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX Time Stamp Valid / Interlock | 31   | RO     |               | This bit is set by hardware in conjunction with posting a new value in the Time Stamp MSB and LSB fields. When this bit is 1 and SW executes a read to the RX TIME STAMP MSB Register, hardware shall clear this bit – the reset behavior of this bit is influenced by RX PTP CONTROL Register's [RX TIME STAMP INTERLOCK POLICY] field. |
| RX Time Stamp [Upper half]      | 30:0 | RO     | U             | MSB of the RX Time Stamp.                                                                                                                                                                                                                                                                                                                |

# 8.7.12 RX PTP SEQUENCE ID REG [Offset 0X06B8]

| Name            | Bits  | Access | Default Value | Description                                                                                                                                                                      |
|-----------------|-------|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved        | 31:16 | RO     | 0x0000        |                                                                                                                                                                                  |
| PTP Sequence ID | 15:0  | RO     | 0x0000        | This field reflects the Sequence ID extracted from the PTP packet which was last Time Stamped by RX hardware                                                                     |
|                 |       |        |               | <b>NOTE:</b> Hardware shall blindly capture 2 octets from offset 30 of each time-stamped PTP packet – not all message types carry Sequenceld, so use this value with discretion. |

### 8.7.13 RX LOCK TIMER LSB REG [Offset 0x06C0]

| Name                | Bits | Access | Default Value | Description                     |
|---------------------|------|--------|---------------|---------------------------------|
| Lock Time LSB Value | 31:0 | RW     | 0x0000        | See RX Lock Timer MSB Register. |

### 8.7.14 RX LOCK TIMER MSB REG [Offset 0x06C4]

See "RX PTP CONTROL REG [Offset 0X06C8]"

| Name                | Bits  | Access | Default Value | Description                                                                                                                                                                    |
|---------------------|-------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved            | 31:16 | RO     | 0x0           |                                                                                                                                                                                |
| Lock Time MSB Value | 15:0  | RW     |               | This, concatenated with Lock Time LSB value, constitutes a 48-bit Lock Timer value. Precision of the value is 1ns – which equates to the precision of the EAV Reference Count. |

# 8.7.15 RX PTP CONTROL REG [Offset 0X06C8]

| Name     | Bits  | Access | Default Value | Description |
|----------|-------|--------|---------------|-------------|
| Reserved | 31:28 | RO     | 0x00          |             |

| Name                                   | Bits  | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------|-------|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX Time Stamp Interlock<br>Policy      | 27:26 | RW     | 01            | This field determines how the successive RX Time Stamps are retained in the RX TIME STAMP Register, given that there is a chance of over-write.                                                                                                                                                                                    |
|                                        |       |        |               | 00 => HW freely over-writes RX Time Stamp values.                                                                                                                                                                                                                                                                                  |
|                                        |       |        |               | 01 => Interlock Mode – HW does not overwrite unless SW reads a posted RX Time Stamp value.                                                                                                                                                                                                                                         |
|                                        |       |        |               | 10 => Lock Timer Mode – HW does not overwrite unless SW reads a posted RX Time Stamp value OR the Lock Timer has expired.                                                                                                                                                                                                          |
|                                        |       |        |               | 11 => Reserved                                                                                                                                                                                                                                                                                                                     |
|                                        |       |        |               | NOTE: Changing the state of this field while                                                                                                                                                                                                                                                                                       |
|                                        |       |        |               | receiving PTP traffic may result in abrupt HW                                                                                                                                                                                                                                                                                      |
|                                        |       |        |               | behavior. This field is best configured statically.                                                                                                                                                                                                                                                                                |
| PTP RX Time Stamping Enable            | 25:23 | RW     | 00            | Write a 1 to enable – all permutations allowed.                                                                                                                                                                                                                                                                                    |
| bit-map                                |       |        |               | [25] RX Time Stamp PTP V1 – L4 packets                                                                                                                                                                                                                                                                                             |
|                                        |       |        |               | [24] RX Time Stamp PTP V2 – L4 packets                                                                                                                                                                                                                                                                                             |
|                                        |       |        |               | [23] RX Time Stamp PTP V2 – L2 packets                                                                                                                                                                                                                                                                                             |
|                                        |       |        |               | See field [15:0]                                                                                                                                                                                                                                                                                                                   |
| Reserved                               | 22:16 | RO     | 0x00          |                                                                                                                                                                                                                                                                                                                                    |
| Stamp-able PTP Message<br>Type bit-map | 15:0  | RW     | 0x0000        | This field, in conjunction with field [25:23] qualifies a particular PTP message type packet to be time stamped by hardware. Write a 1 in a bit position to enable time stamping of the corresponding message type and write a 0 in a bit position to disable time stamping of the corresponding message type:  [00] => Sync Event |
|                                        |       |        |               | [01] => Delay_Req                                                                                                                                                                                                                                                                                                                  |
|                                        |       |        |               | [02] => Pdelay_Req                                                                                                                                                                                                                                                                                                                 |
|                                        |       |        |               | [03] => Pdelay_Resp                                                                                                                                                                                                                                                                                                                |
|                                        |       |        |               | [04 - 07] => N/A                                                                                                                                                                                                                                                                                                                   |
|                                        |       |        |               | [08] => Follow_Up                                                                                                                                                                                                                                                                                                                  |
|                                        |       |        |               | [09] => Delay_Resp                                                                                                                                                                                                                                                                                                                 |
|                                        |       |        |               | [10] => Pdelay_Resp_Follow_Up                                                                                                                                                                                                                                                                                                      |
|                                        |       |        |               | [11] => Announce                                                                                                                                                                                                                                                                                                                   |
|                                        |       |        |               | [12] => Signaling                                                                                                                                                                                                                                                                                                                  |
|                                        |       |        |               | [13] => Management                                                                                                                                                                                                                                                                                                                 |
|                                        |       |        |               | [14 – 15] => N/A                                                                                                                                                                                                                                                                                                                   |
|                                        |       |        |               | NOTE: Not all message Types are available in PTP V1.                                                                                                                                                                                                                                                                               |

# 8.7.16 TX TIME WATCHDOG LSB[0] REG [Offset 0x6918]

| Name               | Bits | Access | Default Value | Description                           |
|--------------------|------|--------|---------------|---------------------------------------|
| Watchdog LSB Value | 31:0 | RW     | 0x0000        | See TX Time Watchdog MSB[0] Register. |

# 8.7.17 TX TIME WATCHDOG MSB[0] REG [Offset 0x691C]

| Name              | Bits | Access | Default Value | Description                           |
|-------------------|------|--------|---------------|---------------------------------------|
| Enable Lock Timer | 31   | RW     | 0             | Write a 1 to enable Time Watchdog[0]. |

| Name               | Bits | Access | Default Value | Description                                                                                                                                                               |
|--------------------|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Watchdog MSB Value | 30:0 | RW     | 0x00          | This, concatenated with the Watchdog[0] LSB value, constitutes a 63-bit value. Precision of the value is 1ns – which equates to the precision of the EAV Reference Count. |
|                    |      |        |               | If bit[31] ==1, the desired TimeSync/APE_GPIO shall toggle as soon as EAV Reference Count[62:0] increments to match this 63-bit value.                                    |
|                    |      |        |               | <b>NOTE:</b> Setting this time value back in time will produce no toggle.                                                                                                 |

### 8.7.18 TX TIME WATCHDOG LSB[1] REG [Offset 0x6920]

| Name               | Bits | Access | Default Value | Description                          |
|--------------------|------|--------|---------------|--------------------------------------|
| Watchdog LSB Value | 31:0 | RW     | 0x0000        | See TX Time Watchdog MSB[1] Register |

# 8.7.19 TX TIME WATCHDOG MSB[1] REG [Offset 0x6924]

| Name               | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable Lock Timer  | 31   | RW     | 0             | Write a 1 to enable Time Watchdog[0].                                                                                                                                                                                                                                                                                                                                                 |
| Watchdog MSB Value | 30:0 | RW     | 0x00          | This, concatenated with the Watchdog[0] LSB value, constitutes a 63-bit value. Precision of the value is 1ns – which equates to the precision of the EAV Reference Count.  If bit[31] ==1, the desired TimeSync/APE_GPIO shall toggle as soon as EAV Reference Count[62:0] increments to match this 63-bit value.  NOTE: Setting this time value back in time will produce no toggle. |

# 8.7.20 EAV REF-COUNT SNAP-SHOT LSB[1] REG [Offset 0X6930]

This LSB and MSB pair captures the EAV Reference Count when externally triggered by the desired TimeSync/APE\_GPIO pin – a toggle serves a trigger. The only legal sequence of accessing this pair is Read-LSB followed by Read-MSB.

| Name                                           | Bits | Access | Default Value | Description                                                                                   |
|------------------------------------------------|------|--------|---------------|-----------------------------------------------------------------------------------------------|
| EAV Reference Count Snap-<br>shot [lower half] | 31:0 | RO     | U             | LSB of the EAV Reference Count as snapshotted by TimeSync/APE_GPIO [2:0] shall always be 000. |

### 8.7.21 EAV REF-COUNT SNAP-SHOT MSB[1] REG [Offset 0X6934]

| Name                                           | Bits | Access | Default Value | Description                                                         |
|------------------------------------------------|------|--------|---------------|---------------------------------------------------------------------|
| EAV Reference Count Snap-<br>shot [Upper half] | 31:0 | RO     | U             | MSB of the EAV Reference Count as snapshotted by TimeSync/APE_GPIO. |

# **Chapter 9: PCI**

# 9.1 Configuration Space

#### 9.1.1 Description

PCI, PCI-X, and PCIe devices must implement sixteen 32-bit PCI registers. These registers are required for a device to have PCI compliance. The format and layout of these registers are defined in the PCI 2.2 specification. Capability registers provide system BIOS and Operating Systems visibility into a set of optional features, which devices may implement. Although the capability registers are not required, the structure and mechanism for chaining auxiliary capabilities are defined in the PCI specification. Both software and BIOS must implement algorithms to fetch and program capabilities fields accordingly. Refer to section 6.7 of the PCI SIIG 2.2 specification. Additional PCI configuration space may be used for device-specific registers. However, device-specific registers are not exposed to system software, according to a specification/standard. System software cannot probe device specific registers without a predetermined understanding of the device and its functionality. In summary, three types of PCI configuration space registers may be exposed by any particular device:

- Required
- Optional capabilities
- Device specific

**NOTE:** The BCM571X/BCM5720 is PCIe v1.1 compliant.

Network devices implement large quantities of registers, and these registers could consume huge amounts of PCI configuration space. PCI configuration access is not very efficient, on a performance basis.

**Example:** Intel x86 architectures use two I/O mapped I/O addresses 0xCF8 and 0xCFC for host-based access to PCI configuration space. Should a host device driver access these I/O addresses on every device read/write, CPU overhead would grow greatly. Generally, host device drivers should not use PCI configuration space for standard I/O and control programming. There is one special case—Universal Network Device Interface (UNDI) drivers. UNDI drivers may not have access to host memory mapped registers when operating in real-mode; thus, an indirect mode of access is necessary. The Ethernet controller implements a PCI indirect mode for memory, registers, and mailboxes access. A specific example of a device driver, which uses indirect mode, is the Preboot Execution (PXE) driver. PXE drivers may be stored in either option ROMs or directly in the system BIOS.

Most host device drivers use register blocks, which are mapped into host memory. Memory Mapped I/O is an efficient mechanism for PCI devices to use system resources. The type and extent of this memory mapping depends upon the MAC's configuration (see the operational characteristics subsection). A typical PCI device will decode a range of physical (bus) addresses, which do not conflict with physical memory or other PCI devices. Each device on the PCI bus will request a range of physical memory, and the PnP BIOS will assign mutually exclusive resources to that device. The size and range of resource is based on each device's hardwired programming of the BAR. The Ethernet controller implements two modes of memory mapped I/O—Standard and Flat. I/O mapped I/O is not supported by the Ethernet controller, and there are no I/O space registers.

**NOTE:** The PCI BAR 0 register is only reset to 0 after a hard reset, otherwise it maintains its value over GRC and PCI resets.

Two programmable blocks expose Ethernet controller functionality to host software. The first is a register block. The second is a memory block. The register and memory blocks map into address spaces based on processor context. For example, the Ethernet controller has an on-chip RISC processor. This RISC processor will have an internal view of the register and memory blocks. This view is one large contiguous and addressable range, where the register block maps starting at offset 0xC0000000. Conversely, host processors have two entirely different views. When the Ethernet controller is configured in standard mode, the register block is mapped into a 64K host memory range. The host processor must use a memory window or indirect mode to access the memory block. It is fundamental to understand that the register and memory blocks are not necessarily tied together. The PCI mode and processor context all affect how software views both blocks (see Figure 32 on page 141).

Figure 32: Local Contexts



The high-priority mailboxes are at offset 0x200 through 0x3FF for host standard, and the low-priority mailboxes are at offset 0x5800 through 0x59FF for indirect mode.

The following components are involved in Ethernet controller configuration space mapping:

<sup>2.</sup> The local memory addresses in this diagram apply to standard and internal views only. Refer to the section on memory maps and pool configuration.

- Base Address registers
- Standard mode map mode
- Flat memory map mode
- Indirect access mode
- Configuration space header
- Host memory
- MAC registers
- MAC local memory

#### 9.1.2 Functional Overview

#### 9.1.2.1 PCI Configuration Space Registers

The Ethernet controller configuration space can be broken into two regions: Header and Device Specific. Table 47 on page 143 shows the registers implemented to support PCI/PCI-X/PCIe functionality in the Ethernet controller. Reserved fields in PCI configuration registers will always return zero.

#### 9.1.2.2 PCI Required Header Region

The bit-7 of the Header Type register (Offset 0x0E) in the PCI Required Header Region is used to identify whether the device is a single function device or multifunction device.

Figure 33: Header Type Register 0xE



**NOTE:** BIOS programmers should take special care to read bit\_7 in PCI Header Type register (Offset 0x0E) before scanning the Ethernet controller PCI configuration space.

Single function PCI devices may decode access to non-implemented device functions in two ways, per Section 3.2.2.3.4 of the PCI 2.2 specification:

- A single function device may optionally respond to all function numbers as the same.
- May decode the function number field and respond only to function 0.

The Ethernet controller single function chips follow the stated technique #1—BIOS code scanning multifunctions get a target response from function(s) 1–7, but these functions are essentially shadows of function 0. Software that programs to function(s) 1–7 is remapped to function 0.

The header region is required by the PCI 2.2 specification. These registers must be implemented. The capabilities registers are optional; however, they must adhere to section 6.7 of the PCI SIIG 2.2 specification. Each capability has a unique ID, which is well-defined. The capabilities are chained using the Next Caps field, in the capability register. The last capability will have a Next Caps field, which is zeroed.

The Device-Specific registers are shown in Table 47.

**Table 47: Device Specific Registers** 

| Register                                                      | Cross Reference                                                                                           |
|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Miscellaneous Host Control                                    | "Miscellaneous Host Control Register (offset: 0x68)" on page 245.                                         |
| PCI State                                                     | "PCI State Register (offset: 0x70)" on page 248.                                                          |
| Register Base Address                                         | "Register Base Register (offset: 0x78)" on page 249.                                                      |
| Memory Base Address                                           | "Memory Base Register (offset: 0x7C)" on page 249.                                                        |
| Register Data                                                 | "Register Data Register (offset: 0x80)" on page 249.                                                      |
| Memory Window Data                                            | "Memory Data Register (offset: 0x84)" on page 249.                                                        |
| UNDI Receive BD Standard Producer Ring Producer Index Mailbox | "UNDI Receive BD Standard Producer Ring Producer Index Mailbox Register (offset: 0x98–0x9C)" on page 250. |
| UNDI Receive Return Ring Consumer Index<br>Mailbox            | "UNDI Receive Return Ring Consumer Index Register (offset: 0x88–0x8C)" on page 250.                       |
| UNDI Send BD Producer Index Mailbox                           | "UNDI Send BD Producer Index Mailbox Register (offset: 0x90–0x94)" on page 250.                           |

#### 9.1.2.3 Indirect Mode

Host software may use Indirect mode to access the Ethernet controller resources, without using Memory Mapped I/O. Indirect mode shadows MAC resources to PCI configuration space registers. These shadow registers can be read/written by system software through PCI configuration space registers. The Ethernet controller Indirect mode registers expose the following MAC resources:

- Registers
- Local Memory
- Mailboxes

Indirect mode access can be used in conjunction with Standard mode PCI access. Indirect mode has no interdependency on other PCI access modes and is a mode in itself.

**NOTE:** Host software must assert the Indirect\_Mode\_Access bit in the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245) to enable indirect mode.

#### 9.1.2.4 Indirect Register Access

Two PCI configuration space register pairs give host software access to the Ethernet controller register block. The Register\_Base\_Address register creates a position in the MAC register block. Valid positions range from 0x0000–0x8000 and 0x30000–0x38800 ranges. Access to the register block from 0x8000–0x30000, should be avoided and is not necessary. The Flat and Standard modes do map a memory window into the 0x8000–0xFFFF ranges; however, the Memory Indirection register pair provides a more efficient mechanism to access the Ethernet controller memory block. The Register\_Data register allows host software to read/write, from the indirection position. The Register\_Base\_Address register can be perceived as creating a cursor/pointer into the register block. The Register\_Data register allows host software to read/write to the location, specified by the Register\_Base\_Address. This register pair accesses the Ethernet controller register block (see Figure 34 on page 144).

**NOTE:** If indirect register access is performed using memory write cycles (i.e., by accessing the Register\_Base\_Address and Register\_Data registers through memory mapped by the PCI BAR register), as opposed to PCI configuration write cycles, the host software must insert a read command to the Register\_Base\_Address register between two consecutive writes to the Register\_Base\_Address and Register\_Data registers.

Figure 34: Register Indirect Access





### 9.1.2.5 Indirect Memory Access

Memory indirect mode operates in the same fashion to register indirect mode. There is a PCI configuration space register pair, which is used to access the Ethernet controller memory block. The Memory\_Window\_Base\_Address register positions a pointer/cursor in the local memory block. Unlike the Register\_Base\_Address register, the Memory\_Window\_Base\_Address register may position at any valid offset. Access to ranges 0x00000–0x1FFFF is allowable. The Memory\_Window\_Data register is the read/write porthole for host software, using the previously positioned pointer/cursor. This register pair accesses the Ethernet controller local memory block (see Figure 35 on page 146).

NOTE: If Indirect Memory Access is performed using memory write cycles (i.e., by accessing the Memory\_Window\_Base\_Address and Memory\_Window\_Data registers through memory mapped by the PCI BAR register), as opposed to PCI configuration write cycles, the host software must insert a read command to the Memory\_Window\_Base\_Address register between two consecutive writes to the Memory Window Base Address and Memory Window Data registers.

Figure 35: Indirect Memory Access

### **Indirect Memory Access**



### 9.1.2.6 UNDI Mailbox Access

The UNDI mailboxes are shadows of Ethernet controller mailbox registers. All mailboxes reside in the Ethernet controller register block, not memory block. Unlike register and memory indirect access, the UNDI Mailboxes shadows are mapped 1:1 to an Ethernet controller register; these shadow registers do not have an address register.

- The UNDI\_RX\_BD\_Standard\_Ring\_Producer\_Index\_Mailbox register shadows a mailbox located at offset 0x5868 (see "Receive BD Return Ring 3 Consumer Index Register (offset: 0x5898-0x589F)" on page 410), in the Ethernet controller register block. Any index update (write) to the UNDI\_RX\_BD\_Standard\_Ring\_Producer\_Index\_Mailbox will advance the standard producer ring index; software signals hardware that an RX buffer descriptor is available.
- The UNDI\_RX\_BD\_Return\_Ring\_Consumer\_Index\_Mailbox register corresponds to a mailbox located at offset 0x5880 (see "Receive BD Standard Producer Ring Index Register (offset: 0x5868)" on page 409). An update (write) to this register indicates that host software has consumed a RX buffer descriptor(s); return rings contain filled Enet frames, from the receive MAC.
- Finally, the UNDI\_TX\_BD\_Host\_Producer\_Mailbox register maps to register offset 0x5900 () in the Ethernet controller register block. Host software writes to this register when Ethernet frame(s) are ready to be transmitted. Host software writes the index of buffer descriptor, which is ready for transmission.

Notice that all these UNDI shadows are the first or primary ring and not all the rings are shadowed into PCI configuration space. For example, Receive Return rings 2–16 do not have shadow registers. UNDI drivers only require a minimal set of registers to provide basic network connectivity. Functionality is the most important consideration. Fifteen additional receive return rings would extend the size of the Device Specific portion of the PCI Configuration Space registers.

The UNDI shadow registers alias three registers in the Ethernet controller register block (see Figure 36 on page 148).

Figure 36: Low-Priority Mailbox Access for Indirect Mode

### **Indirect Mailbox Access**



### 9.1.2.7 Standard Mode

Standard mode is the most useful memory mapped I/O view provided by the Ethernet controller (see Figure 37). 64K of host memory space must be made available. The PnP BIOS or OS will program BAR0 and BAR1 with a base address where the 64K address region may be decoded. The BAR registers point to the beginning of the host memory mapped regions where Ethernet controller can be accessed.

Figure 37: Standard Memory Mapped I/O Mode



The Ethernet controller resources listed in the following are decoded in the 64K address block.

Table 48: PCI Address Map Standard View

| Offset                | Name                          | Size      |
|-----------------------|-------------------------------|-----------|
| 0x00000000-0x000000ff | PCI Configuration space       | 256 bytes |
| 0x00000200-0x000003ff | High-Priority Mailboxes       | 512 bytes |
| 0x00000400-0x00007fff | Ethernet controller registers | 31 KB     |
| 0x00008000-0x0000ffff | Memory Window                 | 32 KB     |

32K is partitioned for MAC control registers and 32K available for a memory access window. Range 0x0000–0x00FF is a complete shadow of the PCI configuration space registers—host software can also read/write to the Ethernet controller's PCI configuration space registers via the host memory map. Host software may use the shadow registers to change PCI register contents and avoid PCI configuration cycles (transactions). Again, using the host memory map is slightly more efficient. The MAC's control/status registers are mapped from 0x0400–0x8000. See Section 13: "Ethernet Controller Register Definitions," on page 233 for complete register and bit definitions. Finally, the memory window range is 0x8000–0xFFFF. This 32K window is set in the PCI Configuration space using the Memory\_Window\_Base\_Address register (see Figure 38). Bits 23:15 set the window aperture and bits 14:2 are effectively ignored/masked off. Bits 14–2 are relevant when host software uses memory indirection and the Memory\_Window\_Data register.

Figure 38: Memory Window Base Address Register



Figure 39 on page 151 shows how the 32K window can float in the Ethernet controller's local memory. The window aligns on 32K boundaries.

**Example:** The memory window may start on the following addresses: 0x8000, 0x10000, and 0x18000. The window aperture may be positioned in the internal memory range 0x00000000 to 0x0001FFFF. When host software reads/writes to PCI\_BAR + 32K + OFFSET in the host memory space, the Ethernet controller translates this read/write access to Memory\_Window\_Base\_Address + OFFSET. Host software must not read/write from any address greater than PCI\_BAR + 64K, since this memory space is not decoded by the Ethernet controller. Such an access may be decoded by another device, or simply go unclaimed on the PCI bus. Figure 39 on page 151 shows the relationship between the Memory Window Base Address register and the Memory Window.

Figure 39: Standard Mode Memory Window

Standard Mode Memory Window

**PCI Configuration Space Host Memory Address Space** Local Memory Address Space 0x00000000 0x00000000 32K Physical BusX Memory DeviceY Function Z Window may be located anywhere Mem Wnd Base Addr Internal Host software may access the BCM57XX **Ethernet Controller local** Window may be located anywhere Registers memory using this window 32K Memory Window 32K 32K

Broadcom 571X-5720-PG101

0x00020000

Figure 40: Techniques for Accessing Ethernet Controller Local Memory





# 9.1.3 Memory Mapped I/O Registers

The following Ethernet controller registers are used in the mode configuration of the PCI memory-mapped I/O.

### 9.1.3.1 PCI Command Register

The PCI\_Command register is 16-bits wide (see Figure 41). The Ethernet controller does not have I/O mapped I/O. The I/O\_Space bit is deasserted by hardware. The Ethernet controller does support Memory\_Mapped\_Memory and hardware will assert the Memory\_Space bit. Both these bits are read-only and are usually read by the PnP BIOS/OS. The BIOS/OS examines these bits to assign non-conflicting resources to PCI devices.

Figure 41: PCI Command Register



## 9.1.3.2 PCI State Register

The PCI\_State register is 32-bits wide. Operating mode is set with the Flat\_View bit in the PCI\_State register. When the Flat\_View bit is asserted, the Ethernet controller decodes a 32M of block host memory. When the Flat\_View bit is deasserted, the Ethernet controller decodes a 64K block of host memory.

### 9.1.3.3 PCI Base Address Register

The PCI\_Base\_Address Register (BAR) specifies the location of an Ethernet controller memory mapped I/O block. The Ethernet controller mode configuration (Flat vs. Standard) affects how the BAR is setup (see Figure 42 on page 155).

- Bits 4–31 in the PCI\_Base\_Address register are selectively programmable based on the amount of host memory requested. The PnP BIOS/OS will use an algorithm to test the BAR bits and determine the amount of physical memory requested.
- The Memory\_Space\_Indicator bit designates whether the BAR is memory or I/O mapped. The Ethernet controller hard codes the Memory Space Indicator bit to zero (deasserted).
- The Location/Type bits specify locations in host memory space where a device can decode physical addresses. The Ethernet controller memory mapped I/O range may be placed anywhere in 64-bit address space (Type = 10).
- The Ethernet controller deasserts the Prefetchable bit to indicate that the memory range should not be cached.

Figure 42: PCI Base Address Register



The Ethernet controller 64K memory mapped I/O block is determined by the first programmable bit in the BAR. When the MAC is configured in standard mode, the mask 0xFFFF0000 identifies the programmable BAR bits. Bit 16 is the first bit encountered in the scan upward, which is programmable; bits 0–3 are ignored. Host software will read zero values from bits 4–16. Figure 43 shows the BAR register and the bits returned to the OS/BIOS during resource allocation.

Figure 43: PCI Base Address Register Bits Read in Standard Mode



# 9.2 Bus Interface

# 9.2.1 Description

The read/write DMA engines both drive the PCIe interface. Typically, each DMA engine alternates bursts to the PCIe bus, and both interfaces may have outstanding transactions on the PCI bus. The BCM571X/BCM5720 family architecture identifies two channels—a read DMA channel and a write DMA channel. Each channel corresponds to the appropriate DMA engine (see Figure 44). The configuration of the DMA engines and the PCI interface is discussed in this section.

Figure 44: Read and Write Channels of DMA Engine



The following architectural components are involved in the configuration of the PCI/DMA interface:

- DMA read engine
- DMA write engine
- DMA read FIFO
- DMA write FIFO
- PCIe interface
- PCI state register
- DMA read/write register

# 9.2.2 Operational Characteristics

### 9.2.2.1 Read/Write DMA Engines

Software must enable the bus master DMA bit for the Ethernet controller. The Ethernet controller is a bus-mastering device and the PCI interface requires that the Bus\_Master enable bit be set by either the BIOS or host device driver. The bus master is the PCI transaction initiator. A PCI target will claim the transaction driven by the bus master. The Bus\_Master enable bit is located in the PCI configuration space Command register and this bit is read/write. The bit defaults to cleared/disabled after device reset.

The read and write DMA channels use FIFOs to buffer small amounts of PCI bus data. The FIFOs provide elasticity for data movement between internal memory and the PCI interface. Host software may configure DMA watermarks—values where PCI activity is enabled/disabled.

When enqueued data is less than the watermark value, PCI bus transactions are inhibited. The DMA channel will wait until the FIFO fills above the threshold before initiating PCI transactions. Host software may configure the DMA\_Write\_Watermark bit fields to set the activity threshold in the write FIFO. The DMA\_Write\_Watermark bit field is read/write and is also located in the DMA Read/Write register. The write watermark registers default to zero after power-on reset.

# 9.3 Expansion ROM

# 9.3.1 Description

The expansion ROM on the Ethernet controller is intended for implementation of PXE (Preboot Execution Environment). The devices support expansion ROM of up to 16 MB.

# 9.3.2 Operational Characteristics

By default, the Expansion ROM is disabled and the firmware has to explicitly enable this feature by setting PCI\_State.PCI\_Expansion\_ROM\_Desired bit to one (see "PCI State Register (offset: 0x70)" on page 248). Once this bit is enabled, the boot code firmware handles the Expansion ROM accesses of the device.

### 9.3.3 BIOS

The BIOS detects if a PCI device supports Expansion ROM or not by writing the value 0xFFFFFFE to Expansion\_ROM\_Base\_Register (register 0x30 of PCI configuration). The BIOS then reads back from this register. If the value is nonzero, then this PCI device supports Expansion ROM; otherwise, it does not. The Ethernet controller returns a nonzero value appropriate for the expansion ROM size selected in NVRAM (see Section 4: "Common Data Structures," on page 48) when Expansion ROM is enabled (PCI\_State.PCI\_Expansion\_ROM\_Desired bit is set to 1). On the other hand, if the PCI\_Expansion\_ROM\_Desired bit cleared, then the Ethernet controller returns a value of 0x000000000. This indicates to the BIOS that no Expansion ROM is supported.

If a PCI device supports Expansion ROM, the BIOS will assign an Expansion Base address to the device. It then checks for a valid ROM header (0x55 0xAA as first two bytes, and so forth) and checksum. If the ROM header and image are valid, the BIOS will copy the Expansion ROM image to HOST's Upper Memory Block (UMB) and invoke the initializing entry point.

### 9.3.3.1 Preboot Execution Environment

Preboot Execution Environment (PXE) is implemented as an Expansion ROM in the NIC implementation. In the LOM implementation, PXE normally resides in the system BIOS. In the NIC implementation, PXE image is stored in the NVRAM. Upon power on reset of the Ethernet controller, the RX RISC will load the boot code from the NVRAM into RX RISC scratch pad and execute. This boot code will program the device with programmable manufacturing information (such as MAC address, PCI vendor ID/device ID, etc.). If PXE is enabled, the boot code responds to the Expansion ROM accesses of system BIOS.

Boot code is executed when the Ethernet controller is reset via PCI Reset or S/W device reset. PXE initialization should only be necessary after a PCI reset. The boot code differentiates PCI Reset and driver initiated software reset by checking content in Internal Memory at 0xb50. If the content is 0x4B657654, then the reset is due to driver initiated software reset. Therefore, the device driver has to initialize 0xb50 with 0x4B657654 before issuing a S/W device reset.

# 9.4 Power Management

# 9.4.1 Description

The Ethernet controller is compliant with the PCI v2.0 (PCI v2.1 for BCM5719) power management specification. The MAC is programmable to two ACPI states: D0 and D3. The D0 state is a full power, operational mode—all the MAC core functions run at the highest clocking frequency, and components are fully functional. The MAC may be either initialized or uninitialized in the D0 ACPI state. An uninitialized D0 state is entered through a device reset or PME event; the MAC functional blocks are not started and initialized. Host software must reset/initialize hardware blocks to transition the device to a D0 initialized (active) state. The D0 active state places the device into a full power/operational mode. Receive and transmit data paths are fully operational, and the PCI block is initialized for bus mastering DMA.

Host device drivers do not differentiate between D3 hot and D3 cold states. ACPI-compliant device drivers are unloaded and quiescent in the D3 state and PCI slot power state is transparent. When the MAC is in D3 hot state, PCI slot power (3.3V or 5.0V) is available to power the PCI I/O pins. The PCI configuration and memory space may be accessed in D3 hot state. The core clock must remain enabled, so the MAC can respond to PCI configuration and memory transactions. The Disable\_Core\_Clock bit, in the PCI Clock Control register enables/disables clocking in the core clock domain. A D3 cold state provides only the PCI Vaux supply—PCI slot power is not present. The MAC will consume a maximum of 375 mA in a D3 cold power management mode.

The following functional blocks are integral to MAC power management:

- PMSCR register
- PCI Clock Control register
- Miscellaneous Control register
- WOL
- PCI Vaux Supply
- PCI Slot Power Supply
- GPIO

# 9.4.2 Operational Characteristics

Figure 45 on page 159 applies to the Ethernet controller reference designs. The MAC GPIO pins are available for application specific usage; however, Broadcom encourages both software and hardware engineers to follow the Broadcom design guidelines and application notes. NIC and LOM designs use external board level logic to switch power regulators for D3 ACPI mode.

Figure 45: Power State Transition Diagram



### 9.4.2.1 Device State D0 (Uninitialized)

The D0 state is entered after a PCI reset or device (software) reset. The assertion of PME causes the PCI bridge to drive RST. The MAC hardware blocks are not initialized in this state.

**Example:** The RX engine, TX engine, multicast filter, and memory arbiter are all uninitialized. All the MAC functional blocks are powered.

### 9.4.2.2 Device State D0 (Active)

Host software has initialized the MAC hardware blocks. The RX and TX data paths are ready to send/receive Ethernet packets. The PCI block is available to DMA packets to host memory. This is a full power ACPI operational state. Host software/drivers must follow the initialization procedure (see "Initializing the MAC Hash Registers" on page 112) to move the MAC into a D0 active state.

When the BCM571X/BCM5720 family NetXtreme devices detect that main power is lost and it is still in the D0 state, it will reset itself to the D3 (Cold) state and then operate in 10/100 mode, like the OOB WOL state.

### 9.4.2.3 Device State D3 (Hot)

The MAC's configuration space and memory mapped I/O blocks are accessible in D3 hot state. The PCI I/O drivers are still powered by slot power in this state. However, host software has switched the MAC to use PCI Vaux for VDD\_CORE and VDD\_IO. GPIO pins 0, 1, and 2 are configured before the transition to this state. The RX RISC processor clock has been stopped in this state. The core clock remains active so PCI transactions may be processed by the MAC. This is a low-power

state where some key components have been powered down. The physical layer auto-advertises 10 Mbps capability in this state, and link is set to 10 Mbps half-duplex or full-duplex. The PHY is configured for WOL mode. WOL pattern filters are initialized and active; the MAC will process Magic Packets<sup>™</sup>. The host chipset implements the power management policy for the PCI bus; the MAC driver does not influence the PCI Vaux or Slot power supply.

**NOTE:** The drivers should use configuration cycles (not the memory write cycles) to write to the PMCSR register at offset 0x4C for putting the device in D3 Hot state.

### 9.4.2.4 Device State D3 (Cold)

The MAC is completely powered by PCI Vaux in D3 cold. PCI configuration space and memory mapped I/O are not available. The only portion of the MAC active is the WOL pattern and Magic Packet filters<sup>2</sup>. The MAC will assert a PME in this state and indicate to the host bridge that a wake up event has occurred. The host bridge will normally provide PCI Slot power and then reset the device. GPIO pins 0, 1, and 2 are configured the same as D3 hot. Host software does not differentiate between D3 hot/cold. The MAC and PHY will not consume more than 375 mA in this mode. The integrated PHY must negotiate for 10 Mbps half/duplex speed. The PHY WOL mode is configured.

NOTE: The PCIe devices support the PCIe power management which is compatible with PCI bus power management.

### 9.4.3 Wake on LAN

See "Wake on LAN Mode/Low-Power" on page 181.

Magic Packet<sup>™</sup> is a registered trade mark of AMD.

### 9.4.4 GPIO

The use of GPIO pins for power management is design-specific, though Broadcom-delivered drivers use GPIO pins in the manner listed in Table 49. This usage is only applicable when the Ethernet controller is configured for a NIC design; it is not applicable to LAN-on-Motherboard (LOM) designs.

Table 49: GPIO Usage for Power Management for Broadcom Drivers<sup>a</sup>

| Function | Description                     | GPIO0 | GPIO1 | GPIO2 |
|----------|---------------------------------|-------|-------|-------|
| VAux     | Sequence for switching to VAux  | 0     | 1     | 1     |
|          |                                 | 1     | 1     | 1     |
|          |                                 | 1     | 1     | 0     |
| VMain    | Sequence for switching to VMain | x     | 1     | х     |
|          |                                 | x     | 0     | x     |
|          |                                 | x     | 1     | x     |

a. x= Don't Care

# 9.4.5 Power Supply in D3 State

Table 50 shows the power supply to various power pins on the Ethernet controller, and it is assumed that host software has switched power regulators using GPIO pins 0, 1, and 2.

**Table 50: Ethernet Controller Power Pins** 

| Supply Pins | D0 Normal       | D3 Hot, D3 Cold |
|-------------|-----------------|-----------------|
| VDDIO       | PCIe Slot Vmain | PCIe Slot Vaux  |
| VDDC        | PCIe Slot Vmain | PCIe Slot Vaux  |

### 9.4.6 Clock Control

Certain functional blocks in the MAC architecture should be powered down before a transition to D3 ACPI state. MAC clock generators/PLLs drive transistor level logic, which switches states on every clock pulse. Transistor level switching consumes power (mW). Software should selectively disable clocking to non-essential functional blocks. Software must set the Enable\_Clock\_Control\_Register bit in the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245); the assertion of this bit allows host software to configure the PCI clock control register. The following clock bits should be configured in the PCI Clock Control register:

- RX RISC clock disable
- Select alternate clock—the 133 MHz PLL is not used as reference clock.

NOTE: For the 57818 family chip, the clock control register (offset: 0x68) does not need to be configured.

### 9.4.7 Device ACPI Transitions

Host software must program the Power Management Control/Status (PMSCR) register to transition the device between D0 and D3 ACPI states. The Power State bit field in the PMSCR (see "Power Management" on page 158) may be programmed to D0, D1, D2, and D3 states.

**NOTE:** The D1 and D2 configurations are not supported in the Ethernet controller. The D1 and D2 bit configurations are available for applications, where D1 and D2 states are introduced for board level designs—the bits provide flexibility to the application. The Broadcom reference NIC/LOM designs do not use D1 and D2 states; therefore, host software should avoid setting these states. Before the Mac is moved into the D3 state, the clocks and GPIO must be configured (see above sections).

The PME signal is enabled in the PMSCR by asserting the PME\_Enable bit. Device drivers/BIOS may also read the PME\_Status bit to determine whether the event has been driven; PME\_Status is a write to clear bit. The type and supported power management features for the Ethernet controller are reported in the Power Management Capabilities (PMC) register. System software and BIOS may read this register to enumerate and detect the power management features supported by the NIC/LOM. For example, the Ethernet controller can assert PME from both D3 hot and cold states. The PME\_Support bit field in the PMC register will reflect this capability.

# 9.4.8 Disable Device Through BIOS

The Ethernet controllers can be disabled (that is, placed in Low Power IDDQ mode) through BIOS by writing the value of DEADDEADh to shared memory location of B50h. This eliminates the need for BIOS to execute the device specific procedure for disabling the MAC device. The BIOS must do the following steps to disable the device.

- 1. Config cycle, write 88h to location 68h.
- 2. Config cycle, write 0B50h to location 7Ch.
- 3. Config cycle, write DEADDEADh to location 84h.

**NOTE:** The BIOS should first place the controller into the D3 power state prior to writing the 0xDEADDEAD signature value.

# 9.5 Endian Control (Byte and Word Swapping)

**NOTE:** Setting register 0x68 bit 2 (Enable Endian Byte Swap) causes PCI configuration reads to the following registers to become swapped:

- 0x40
- 0x68 0x9C
- 0xF4 0xFF

This is different behavior from previous NetXtreme controllers. Reference BCM571X/BCM5720 Family errata relating to byte swap control for additional information.

# 9.5.1 Background

There are two basic formats for storing data in memory—little-endian and big-endian. The endianess of a system is determined by how multibyte quantities are stored in memory. A big-endian architecture stores the most significant byte at the lowest address offset while little-endian architecture stores the least significant byte at the lowest address offset.

For example, the 32-bit hex value 0x12345678 would be stored in memory as shown in the following table.

Table 51: Endian Example

| Address       | 00 | 01 | 02 | 03 |
|---------------|----|----|----|----|
| Big Endian    | 12 | 34 | 56 | 78 |
| Little Endian | 78 | 56 | 34 | 12 |

Another method of viewing how this data would be stored is shown in the following tables.

Table 52: Storage of Big-Endian Data

| Storage Byte  | 00 | 01 | 02 | 03 |
|---------------|----|----|----|----|
| Data Contents | 12 | 34 | 56 | 78 |

Table 53: Storage of Little-Endian Data

| Storage Byte  | 03 | 02 | 01 | 00 |
|---------------|----|----|----|----|
| Data Contents | 12 | 34 | 56 | 78 |

Examples of big-endian platforms include SGI Irix, IBM RS6000, and SUN.

Examples of little-endian platforms include Intel x86 and DEC Alpha.

PCI assumes a little-endian memory model. PCI configuration registers are organized so that the least significant portion of the data is assigned to the lower address.

# 9.5.2 Architecture

The Ethernet controller is internally a big-endian machine, and its internal processors are big-endian devices. The Ethernet controller stores data internally in big-endian format using a 64-bit memory subsystem.

However, many hosts (e.g., x86 systems) use the little-endian format, and the PCI bus uses the little-endian format. Therefore the Ethernet controller has a number of byte swapping options that may be configured by software so that Little or Big Endian hosts can interface as seamlessly as possible with Ethernet controller over PCI. The Ethernet controller has the following bits that control byte and word swapping:

- Enable Endian Word Swap (bit 3, Miscellaneous Host Control register (offset 0x68 into PCI Config register, see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). If 1, this register enables 32-bit word swapping when accessing the Ethernet controller via the PCI target interface.
- Enable Endian Byte Swap (bit 2, Miscellaneous Host Control register (offset 0x68 into PCI Config register, see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). If 1, this register enables byte swapping (within a 32-bit word) when accessing the Ethernet controller via the PCI target interface.
- Word Swap Data (bit 5, Mode Control register (offset 0x6800 into the Ethernet controller registers). If 1, this register enables word swapping of frame data when it comes across the bus.
- Byte Swap Data (bit 4, Mode Control register (offset 0x6800 into the Ethernet controller registers). If 1, this register enables byte swapping of frame data when it comes across the bus.
- Word Swap Non-Frame Data (bit 2, Mode Control register (offset 0x6800 into the Ethernet controller registers). If 1, this register enables word swapping of non frame data (i.e., buffer descriptors, statistics, etc.) when it comes across the bus.
- Byte Swap Non-Frame Data (bit 1, Mode Control register (offset 0x6800 into the Ethernet controller registers). If 1, this register enables byte swapping of non frame data (i.e., buffer descriptors, statistics, etc.) when it comes across the bus.

The setting of the above swapping bits will affect the order of how data is represented when it is transferred across PCI. Since byte swapping is a confusing subject, examples will be shown that reflect how each byte swapping bit works.

# 9.5.3 Enable Endian Word Swap and Enable Endian Byte Swap Bits

The Enable Endian Word Swap, and Enable Endian Byte Swap bits affect whether words or bytes are swapped during target PCI accesses. Thus, these bits affect the byte order when the host is directly reading/writing to registers or control structures that are physically located on the Ethernet controller. These bits do not affect the byte ordering of packet data or other structures that are mastered (DMAed) by the Ethernet controller.

When the Ethernet controller is accessed via PCI (which is little endian) as a PCI target, the Ethernet controller must implicitly map those accesses to internal structures that use a 64-bit Big Endian architecture. In the default case where no swap bits are set the Ethernet controller maps PCI data to internal structures shown in Table 54 and Table 55 on page 165.

Table 54: Default Translation (No Swapping) on 64-Bit PCI

|                 | MSB      |    |          |    |          |    |          | LSB |
|-----------------|----------|----|----------|----|----------|----|----------|-----|
| Internal Byte # | 0        | 1  | 2        | 3  | 4        | 5  | 6        | 7   |
| Internal Bit #  | 63       | 48 | 47       | 32 | 31       | 16 | 15       | 0   |
| Example Content | 88       | 89 | 8A       | 8B | 8C       | 8D | 8E       | 8F  |
|                 | <b>‡</b> |    | <b>†</b> |    | <b>†</b> |    | <b>†</b> |     |
|                 | MSB      |    |          |    |          |    |          | LSB |
| PCI Byte #      | 7        | 6  | 5        | 4  | 3        | 2  | 1        | 0   |

#### Table 54: Default Translation (No Swapping) on 64-Bit PCI (Cont.)

| PCI Bit #       | 63 | 48 | 47 | 32 | 31 | 16 | 15 | 0  |
|-----------------|----|----|----|----|----|----|----|----|
| Example Content | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F |

#### Table 55: Default Translation (No Swapping) on 32-bit PCI

|      | 31 | 16 | 15 | 0  |
|------|----|----|----|----|
| 0x00 | 88 | 89 | 8A | 8B |
| 0x04 | 8C | 8D | 8E | 8F |

| 31 | 16 | 15 | 0  |      |
|----|----|----|----|------|
| 8C | 8D | 8E | 8F | 0x00 |
| 88 | 89 | 8A | 8B | 0x04 |

As illustrated above, because the Ethernet controller uses an internal 64-bit big endian architecture, it will map (by default) the most significant byte of an 8-byte (64-bit) internal quantity to the most significant byte on a 64-bit PCI bus. This works nicely for quantities (fields) that are 64 bits in size (e.g., a host physical address). However, this can be confusing for quantities that are 32 bits in size. Without Word Swapping enabled, the host could easily access the wrong 32-bit quantity when making a 32-bit access.

Take, for example, a Ring Control Block (RCB). RCBs are on-chip structures and read/written by the host via PCI target accesses. The table below shows the big-endian layout of an on-chip RCB:

Table 56: RCB (Big Endian 32-Bit Format)

| Byte # |     | 0                | 1                 |     |    | 2   | 3    |      |
|--------|-----|------------------|-------------------|-----|----|-----|------|------|
| Bit #  | 31  |                  |                   | 16  | 15 |     |      | D    |
|        | MSB |                  | Host Ring Address |     |    |     | 0x00 |      |
|        |     |                  |                   |     |    |     | LSE  | 0x04 |
|        | MSB | MAX_             | Len               | LSB |    | Fla | ags  | 80x0 |
|        |     | NIC Ring Address |                   |     |    |     | 0x0C |      |

If Word Swapping is not enabled, and the host made a 32-bit read request to address 0x08, the four bytes of data returned on the PCI bus would actually be the NIC Ring Address rather than the Max\_Len and Flags fields. This initially might seem counter-intuitive, but is explained in Table 57. Therefore, if a software driver running on an x86 host (Little Endian) referenced on-chip data structures as they are defined in the Ethernet controller data sheet, the driver should set the Enable Endian Word Swap bit. By setting this bit, the translation would be as follows:

Table 57: Internal Byte OrderingPCI Byte Ordering

|      | 31 | 16 | 15 | 0  |
|------|----|----|----|----|
| 0x00 | 88 | 89 | 8A | 8B |
| 0x04 | 8C | 8D | 8E | 8F |

| 31 | 16 | 15 | 0  |      |
|----|----|----|----|------|
| 88 | 89 | 8A | 8B | 0x00 |
| 8C | 8D | 8E | 8F | 0x04 |

The only side effect for a little endian host that sets the Enable Endian Word Swap bit would be that the driver would have to perform an additional word swap on any 64-bit fields (e.g., a 64-bit physical address) that were given to the driver by the Network Operating System (NOS).

Little-endian hosts will not want to set the Enable Endian Byte Swap bit for target accesses. This bit is intended to be used by big endian systems that needed PCI data (little endian) translated back to big endian format.

**NOTE:** Some big endian systems automatically do this depending on the architecture of the host's PCI to memory interface.

The following figures show the translation of data when the Enable Endian Byte Swap bit is set:

Table 58: Byte Swap Enable Translation on 32-Bit PCI (No Word Swap)

# Internal Byte Ordering PCI Byte Ordering

0x00 0x04

| 31 | 16 | 15 | 0  |
|----|----|----|----|
| 88 | 89 | 8A | 8B |
| 8C | 8D | 8E | 8F |

| 31 | 16 | 15 | 0  |      |
|----|----|----|----|------|
| 8F | 8E | 8D | 8C | 0x00 |
| 8B | 8A | 89 | 88 | 0x04 |

# Internal Byte Ordering PCI Byte Ordering

0x00 0x04

| 31 | 16 | 15 | 0  |
|----|----|----|----|
| 88 | 89 | 8A | 8B |
| 8C | 8D | 8E | 8F |

| 31 | 16 | 15 | 0  |      |
|----|----|----|----|------|
| 8B | 8A | 89 | 88 | 0x00 |
| 8F | 8E | 8D | 8C | 0x04 |

# 9.5.4 Word Swap Data and Byte Swap Data Bits

The Word Swap Data, and Byte Swap Data bits affect how packet data is ordered on the PCI bus. These only affect how packet data is ordered, and do not affect non-frame data (i.e., buffer descriptors, statistics block, etc.). In other words, these bits affect how data is transferred to/from host send/receive buffers.

**Example:** If Ethernet controller were to receive a packet that had the following byte order:

|    | 02 |    |    |    |    |    |    |    |    |    |    |    |    |     |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
| D1 | D2 | D3 | D4 | D5 | D6 | S1 | S2 | S3 | S4 | S5 | S6 | T1 | T2 | IP1 | IP2 |

#### Where:

- D1-D6 consists of the packet's destination address (Byte D0 is the first byte on the wire);
- S1–S6 is the source address:
- T1-T2 is the Ethernet type/length field;
- IP1–IP2 are the first two bytes of the IP header which immediately follow the type/length field.

The packet would be stored internally in big endian format:

Table 59: Big-Endian Internal Packet Data Format

| В0    | B1    | B2    | В3    | B4    | B5    | В6   | В7  |
|-------|-------|-------|-------|-------|-------|------|-----|
| 63–56 | 55–48 | 47–40 | 39–32 | 31–24 | 23–16 | 15–8 | 7–0 |
| D1    | D2    | D3    | D4    | D5    | D6    | S1   | S2  |
| S3    | S4    | S5    | S6    | T1    | T2    | IP1  | IP2 |

However, when the data gets transferred across PCI, there could be confusion about the correct byte ordering because PCI is Little Endian whereas Ethernet controller is a Big Endian device. To provide flexibility for different host processor/memory architectures, Ethernet controller can order this data on PCI in four different ways depending on the settings of the Word Swap Data, and Byte Swap Data bits. The following figures illustrate how data would appear on the PCI AD[63:0] pins depending on the settings of those swap bits:

### 9.5.4.1 Word Swap Data = 0, and Byte Swap Data = 0

Table 60: 64-Bit PCI Bus (WSD = 0, BSD = 0)

| В7    | 7B6   | B5    | B4    | В3    | B2    | B1   | В0  |
|-------|-------|-------|-------|-------|-------|------|-----|
| 63–56 | 55–48 | 47–40 | 39–32 | 31–24 | 23–16 | 15–8 | 7–0 |
| D1    | D2    | D3    | D4    | D5    | D6    | S1   | S2  |
| S3    | S4    | S5    | S6    | T1    | T2    | IP1  | IP2 |

Table 61: 32-Bit PCI Bus (WSD = 0, BSD = 0)

| В3    | B3 B2       |     | В0  |
|-------|-------------|-----|-----|
| 31–24 | 31–24 23–16 |     | 7–0 |
| D5    | D6          | S1  | S2  |
| D1    | D2          | D3  | D4  |
| T1    | T2          | IP1 | IP2 |

Table 61: 32-Bit PCI Bus (WSD = 0, BSD = 0) (Cont.)

| В3    | B2    | B1   | В0  |  |
|-------|-------|------|-----|--|
| 31–24 | 23–16 | 15–8 | 7–0 |  |
| S3    | S4    | S5   | S6  |  |

# 9.5.4.2 Word Swap Data = 0, and Byte Swap Data = 1

Table 62: 64-Bit PCI Bus (WSD = 0, BSD = 1)

| В7    | В6    | B5    | B4    | В3    | B2    | B1   | В0  |
|-------|-------|-------|-------|-------|-------|------|-----|
| 63–56 | 55–48 | 47–40 | 39–32 | 31–24 | 23–16 | 15–8 | 7–0 |
| D4    | D3    | D2    | D1    | S2    | S1    | D6   | D5  |
| S6    | S5    | S4    | S3    | IP2   | IP1   | T2   | T1  |

Table 63: 32-Bit PCI Bus (WSD = 0, BSD = 1)

| B3 B2 |         | B1   | В0  |  |
|-------|---------|------|-----|--|
| 31–24 | 23–16   | 15–8 | 7–0 |  |
| S2    | S1      | D6   | D5  |  |
| D4    | D3      | D2   | D1  |  |
| IP2   | IP2 IP1 |      | T1  |  |
| S6    | S5      | S4   | S3  |  |

# 9.5.4.3 Word Swap Data = 1, and Byte Swap Data = 0

Table 64: 64-Bit PCI Bus (WSD = 1, BSD = 0)

| B7    | В6    | B5    | B4    | В3    | B2    | B1   | В0  |
|-------|-------|-------|-------|-------|-------|------|-----|
| 63–56 | 55–48 | 47–40 | 39–32 | 31–24 | 23–16 | 15–8 | 7–0 |
| D5    | D6    | S1    | S2    | D1    | D2    | D3   | D4  |
| T1    | T2    | IP1   | IP2   | S3    | S4    | S5   | S6  |

Table 65: 32-Bit PCI Bus (WSD = 1, BSD = 0)

| В3    | B2    | B1   | В0  |
|-------|-------|------|-----|
| 31–24 | 23–16 | 15–8 | 7–0 |
| D1    | D2    | D3   | D4  |
| D5    | D6    | S1   | S2  |
| S3    | S4    | S5   | S6  |
| T1    | T2    | IP1  | IP2 |

# 9.5.4.4 Word Swap Data = 1, and Byte Swap Data = 1

Table 66: 64-Bit PCI Bus (WSD = 1, BSD = 1)

| B7    | В6    | B5    | B4    | В3    | B2    | B1   | В0  |
|-------|-------|-------|-------|-------|-------|------|-----|
| 63–56 | 55–48 | 47–40 | 39–32 | 31–24 | 23–16 | 15–8 | 7–0 |
| S2    | S1    | D6    | D5    | D4    | D3    | D2   | D1  |
| IP2   | IP1   | T2    | T1    | S6    | S5    | S4   | S3  |

Table 67: 32-Bit PCI Bus (WSD = 1, BSD = 1)

| В3    | B2    | B1   | В0  |
|-------|-------|------|-----|
| 31–24 | 23–16 | 15–8 | 7–0 |
| D4    | D3    | D2   | D1  |
| S2    | S1    | D6   | D5  |
| S6    | S5    | S4   | S3  |
| IP2   | IP1   | T2   | T1  |

So, for a little-endian (e.g., x86) host, software should set both the Word Swap Data, and Byte Swap Data bits. This is because a little endian host will expect the first byte on the wire (byte D1) to be placed into memory at the least significant (starting) address of the packet data.

# 9.5.5 Word Swap Non-Frame Data and Byte Swap Non-Frame Data Bits

The Word Swap Non-Frame Data, and Byte Swap Non-Frame Data bits affect the byte ordering of certain shared memory data structures (buffer descriptors, statistics block, etc.) when those structures are transferred across PCI.

The following table shows an example of how a Send Buffer Descriptor is stored internally in the Ethernet controller.

Table 68: Send Buffer Descriptor (Big-Endian 64-Bit format)

| Byte # | 0   |        | 1   | 2               | 3   | 4    | 5    | 6  | 7  |      |  |
|--------|-----|--------|-----|-----------------|-----|------|------|----|----|------|--|
| Bit #  | 63  |        | 48  | 47              | 32  | 31   | 16   | 15 | 0  |      |  |
|        | MSB |        |     | Host Address LS |     |      |      |    |    |      |  |
|        |     |        |     |                 |     |      |      |    |    |      |  |
|        | MSB | Length | LSB | FI              | ags | Rese | rved | VL | AN | 80x0 |  |

Since the Ethernet controller uses a 64-bit memory subsystem, the above diagram is shown in 64-bit format. Furthermore, the table shows both the internal byte offset for each field and the bit position for each byte.

**NOTE:** This may seem confusing because big-endian notation normally has the bit positions incrementing from left to right. However, in this case, the bit positions are relevant because they correspond to the bit positions on PCI (AD[63:0]) if neither of the non-frame data swap bits are set. For clarification, the following table shows the same structure in 32-bit format.

Table 69: Send Buffer Descriptor (Big-Endian 32-Bit format)

| Byte # | (   | )     | 1            |             | :    | 2 |  | 3    |      |
|--------|-----|-------|--------------|-------------|------|---|--|------|------|
| Bit #  | 31  |       |              | 16          | 15   |   |  | 0    |      |
|        | MSB |       | Host Address |             |      |   |  |      |      |
|        |     |       |              |             |      |   |  | LSB  | 0x04 |
|        | MSB | Leng  | gth          | n LSB Flags |      |   |  | 0x08 |      |
|        |     | Reser | ved          |             | VLAN |   |  |      | 0x0C |

To provide flexibility for different host processor/memory architectures, the Ethernet controller can order the data in memory in four different ways depending on the settings of the Word Swap Non-Frame Data and Byte Swap Non-Frame Data bits. The following tables show how data will appear depending on the settings of those swap bits:

## 9.5.5.1 Word Swap Non-Frame Data = 0 and Byte Swap Non-Frame Data = 0

This would require the software to use the following little-endian data structure on the host:

Table 70: Send Buffer Descriptor (Little-Endian 32-Bit format) with No Swapping

| Byte # |     | 3        | 2      | 2    |       | 1 | 0  |   |      |
|--------|-----|----------|--------|------|-------|---|----|---|------|
| Bit #  | 31  |          |        | 16   | 15    |   |    | 0 |      |
|        |     |          | LSB    | 0x00 |       |   |    |   |      |
|        | MSB |          |        |      |       |   |    |   | 0x04 |
|        |     | Reserved |        |      | VLAN  |   |    |   | 80x0 |
|        | MSB | Len      | Length |      | Flags |   | js |   | 0x0C |

In this case, the data structure takes on a slightly new format because the words have been swapped.

### 9.5.5.2 Word Swap Non-Frame Data = 1 and Byte Swap Non-Frame Data = 0

This requires the software to use the following little-endian data structure on the host:

Table 71: Send Buffer Descriptor (Little-Endian 32-Bit format) with Word Swapping

| Byte # |     | 3      | 2    |      | <u> </u> |  | 0 |     |      |
|--------|-----|--------|------|------|----------|--|---|-----|------|
| Bit #  | 31  |        |      | 16   | 15       |  |   | 0   |      |
|        | MSB |        |      | 0x00 |          |  |   |     |      |
|        |     |        |      |      |          |  |   | LSB | 0x04 |
|        | MSB | Length |      | LSB  | Flags    |  |   |     | 80x0 |
|        |     | Rese   | rved |      | VLAN     |  | N |     | 0x0C |

The disadvantage of this approach is if the host operating system supported a 64-bit data type for a physical address, the host device driver would have to swap the two 32-bit words that comprise the 64-bit address that the host operating system used.

### 9.5.5.3 Word Swap Non-Frame Data = 0 and Byte Swap Non-Frame Data = 1

This requires the software to use the following big-endian data structure on the host:

Table 72: Send Buffer Descriptor (Big-Endian 32-bit format) with Byte Swapping

| Byte # |     | 0    | 1        | 1       |      | 2    | 3  |      |      |
|--------|-----|------|----------|---------|------|------|----|------|------|
| Bit #  | 31  |      |          | 16      | 15   |      |    | 0    |      |
|        | MSB |      |          | Host Ad |      | •    |    | 0x00 |      |
|        |     |      |          |         |      |      |    | LSB  | 0x04 |
|        |     | Rese | Reserved |         | VLAN |      |    |      | 80x0 |
|        | MSB | Lenç | gth      | LSB     |      | Flag | js |      | 0x0C |

# 9.5.5.4 Word Swap Non-Frame Data = 1 and Byte Swap Non-Frame Data = 1

This requires the software to use the following big-endian data structure on the host:

Table 73: Send Buffer Descriptor (Big-Endian 32-bit format) with Word and Byte Swapping

| Byte # |     | 0    |              | 1  |       | 2   | 3  |     |      |
|--------|-----|------|--------------|----|-------|-----|----|-----|------|
| Bit #  | 31  |      |              | 16 | 15    |     |    | 0   |      |
|        | MSB |      | Host Address |    |       |     |    |     |      |
|        |     |      |              |    |       |     |    | LSB | 0x04 |
|        | MSB | Len  | Length       |    | Flags |     |    |     | 0x08 |
|        |     | Rese | rved         |    |       | VLA | .N |     | 0x0C |

# **Chapter 10: Ethernet Link Configuration**

## 10.1 Overview

The Ethernet controller supports multiple link operating modes. It can operate at multiple link speeds: 10 Mbps, 100 Mbps, or 1000 Mbps. It can also operate at half-duplex (IEE 802.3 CSMA/CD) or full-duplex. The MAC is compliant with IEEE 802.3, IEEE 802.3u, IEEE 802.3x, and IEEE 802.3z specifications.

# **10.2 GMII/MII**

The Gigabit Media Independent Interface (GMII) is normally used to interface the controller to a transceiver that supports Gigabit Ethernet over copper wiring (1000BASE-T). The Media Independent Interface (MII) is used to interface the controller to a transceiver that is capable of 10/100 Mbps Ethernet. Depending upon the link speed, driver software will need to configure the Ethernet controller to operate in either GMII mode.

NOTE: The integrated PHY transceiver of the BCM571X/BCM5720 has a fixed PHY address value of 1.

# 10.2.1 Configuring the Ethernet Controller for GMII and MII Modes

Configuring the Ethernet controller to operate in GMII or MII mode is simple. During initialization, software should configure the Ethernet\_MAC\_Mode.Port\_Mode bits to a value that corresponds to the correct interface speed (01b for MII, 10b for GMII).

Configuring How MAC Detects Link Up/Down

The Ethernet controller can determine if the Ethernet link is up or down. The link will be down if the Ethernet cable is not properly attached at both ends of the network. Link will be up only if the cable is properly attached and the devices at both ends of the cable recognize that link has been established. The device cannot successfully transfer packets on the link unless it determines that it has a valid link up.

The controller involves using the Ethernet controller's LNKRDY input signal. This method allows the Ethernet controller to determine the link status based on the link status output from integrated PHY connected to LNKRDY input of MAC. The Transmit\_MAC\_Status.Link Up bit (see "Transmit MAC Status Register (offset: 0x460)" on page 281) will reflect the link status input on LNKRDY signal to MAC from PHY. Host software can enable this method by clearing the MII Mode.Port Polling bit (bit-4 of offset 0x454).

The link state of the Ethernet controller can also be forced by disabling both the auto-polling function and the LNKRDY signal and forcing the link status by directly writing to the MII\_Status.Link\_Status bit.

# 10.2.2 Link Status Change Indications

It is advantageous for host software to know when the status of the Ethernet link has changed. To generate an interrupt to the host when link status changes, software should set the Ethernet\_MAC\_Event\_Enable.Link\_State\_Changed bit (see "EMAC Event Enable Register (offset: 0x408)" on page 274) and the Mode\_Control.Interrupt\_on\_MAC\_Attention bit (see "Mode Control Register (offset: 0x6800)" on page 416). With this configuration, the

Ethernet\_MAC\_Status.Link\_State\_Changed bit and Link\_State\_Changed bit in the status block (see "Status Block" on page 60) will be set when the link has changed state.

# 10.2.3 Configuring the GMII/MII PHY

GMII/MII transceivers (PHYs) contain registers that a software driver can manipulate to change parameters in the PHY. These parameters include the link speed or duplex that the PHY is currently running at, or the speed/duplex options that the PHY advertises during the auto-negotiation process. NIC device drivers will typically access PHY registers during the driver initialization process to configure the PHYs speed/duplex or to examine the results of the auto-negotiation process.

The integrated PHY registers are accessed via a process called MDIO. The integrated PHY is connected to the Ethernet controller through an internal MDIO bus (MDIO and MDC pins). Software accesses PHY's registers via MDIO through the Ethernet controller's MII\_Communication register. The following example code describes accessing the PHY registers through the MII Communication registers of the Ethernet controller.

### 10.2.3.1 Reading a PHY Register

```
// Setup the value that we are going to write to MI Communication register
// Set bit 27 to indicate a PHY read.
// Set bit 29 to indicate the start of a MDIO transaction
Value32 = ((PhyAddress << 21) | (PhyRegOffset << 16) | 0x28000000)
// Write value to MI communication register
MII Communication Register = Value32
// Now read back MI Communication register until the start bit
// has been cleared or we have timed out (>5000 reads)
Loopcount = 5000
While (LoopCount > 0)
Begin
   Value32 = MII Communication Register
   If (!(Value32 | 0x2000000)) then BREAK loop
   Else Loopcount --
// Print message if error
If (Value32 | 0x20000000) then
Begin
   // It a debug case-cannot read PHY
   Procedure (Print Error Message)
   Value32 = 0
End
// Now return the value that we read (lower 16 bits of reg)
Return (Value32 & Oxffff)
```

### 10.2.3.2 Writing a PHY Register

```
// Setup the value that we are going to write to MI Communication register
// Set bit 26 set to indicate a PHY write.
// Set bit 29 to indicate the start of a MDIO transaction
// The lower 16 bits equal the value we want to write to the PHY register
Value32 = ((PhyAddress << 21) | (PhyRegOffset << 16) | RegValue | 0x24000000)
// Write value to MI communication register
MII Communication Register = Value32
// Now read back MI Communication register until the start bit
// has been cleared or we have timed out (>5000 reads)
Loopcount = 5000
While (LoopCount > 0)
Begin
   Value32 = MII Communication Register
   If (!(Value32 | 0x2000000)) then BREAK loop
   Else Loopcount --
End
```

```
// Print message if error
If (Value32 | 0x20000000) then
Begin
    // It a debug case - can't write PHY
    Procedure (Print Error Message)
    Value32 = 0
End
// If auto-polling is enabled, turn it back on
```

### 10.2.3.3 PHY Loopback Configuration

### 10.2.3.3.1 External PHY Loopback

```
10Base-T
- Write 0x0100 to PHY register 00h // Force 10Base-T, full duplex
- Write 0x1000 to PHY register 1Eh // Force link (required for 10Base-T)
- Set MAC register 0x400[3:2] = 01b // Set MII
- Set MAC register 0x400[1] = 0 // Force full-duplex operation
100Base-TX
- Write 0x2100 to PHY register 00h // Force 100Base-TX, full duplex
- Write 0x1000 to PHY register 1Eh // Force link (required for 100Base-TX)
- Set MAC register 0x400[3:2] = 01b // Set MII
- Set MAC register 0x400[1] = 0 // Force full-duplex operation
1000Base-T
- Write 0x1B00 to PHY register 09h // Enable 1000Base-T master mode
- Write 0x8400 to PHY register 18h // Enable external loopback mode
- Write 0x1000 to PHY register 1Eh // Force link (optional for 1000Base-T)
- Write 0x0140 to PHY register 00h // Force 1000Base-T operation
- Set MAC register 0x400[3:2] = 10b // Set GMII
                                   // Force full-duplex operation
- Set MAC register 0x400[1] = 0
```

#### 10.2.3.3.2 Internal PHY Loopback

```
10Base-T
- Write 0x4100 to PHY register 00h // Force 10Base-T, full duplex, internal loopback
- Write 0x1000 to PHY register 1Eh // Force link (required for 100Base-TX)
- Set MAC register 0x400[3:2] = 01b // Set MII
- Set MAC register 0x400[1] = 0 // Force full-duplex operation
100Base-TX
- Write 0x6100 to PHY register 00h // Force 100Base-TX, full duplex, internal loopback
- Write 0x1000 to PHY register 1Eh // Force link (required for 100Base-TX)
- Set MAC register 0x400[3:2] = 01b // Set MII
- Set MAC register 0x400[1] = 0 // Force full-duplex operation
1000Base-T
- Write 0x4140 to PHY register 00h // Force 1000Base-T, full duplex, internal loopback
- Write 0x1000 to PHY register 1Eh // Force link (optional for 1000Base-T)
- Set MAC register 0x400[3:2] = 10b // Set GMII
- Set MAC register 0x400[1] = 0
                                // Force full-duplex operation
```

# 10.2.3.4 PHY Configuration Auto-Negotiation (10/100/1000 Speed with Half and Full Duplex Support)

Basic PHY pseudo-code:

- Enable 10/100/1000 PHY loopback mode
- Enable/disable Auto-MDI crossover
- Enable auto-negotiation
- Forced 10/100/1000 link speeds

```
PHY Reset Procedure
______
uint16 t val16;
// Initiate PHY reset by setting 0x00[15] = 1
phy write (0x00, 0x8000);
// Wait up to 100ms for 0x00[15] = 0
for (int i = 0; i < 100; i++) {
 val16 = phy read(0x00);
 if ((val16 \& 0x8000) == 0)
   break;
 // Delay for 1ms
  delay us(1000);
PHY Loopback Procedure
// Force link down by enabling loopback
phy write (0x00, (1 << 14));
// Wait up to 15ms for link to drop
for (int i = 0; i < 15000; i++) {
  if ((phy read(0x01) & (1 << 4) == 0)
   break;
  // Wait 10us
 delay_us(10);
}
______
Configure Auto-MDIX (Cable pair swapping for 10/100)
// Read Misc Control Register (PHY 18h, Shadow 7)
phy write (0x18, 0x7007);
val16 = phy read(0x18)
//Set Force Auto MDIX Mode (Phy 18h, Shadow 7, bit 9)
val16 \mid = (1 << 9);
// Write Misc control Register (set write enable bit)
phy write (0x18, val16 | (1 << 15));
// Enable Auto MDIX Crossover (Phy 10h, bit 14)
val16 = phy read(0x10);
val16 &= \sim (1 << 14);
phy write(0x10, val16);
```

```
______
Autonegotiation (10/100/1000 speed with half and full duplex support)
uint16 t gig = 0, anar = 0;
// Reset PHY
// Enable auto-MDIX
// Force loopback
// Select pause and asymmetric pause advertisement for Ethernet
anar = (1 << 11) | (1 << 10) | (00001b << 0);
// Select 10/100 half/full duplex advertisement
anar |= (1 << 8) | (1 << 7) | (1 << 6) | (1 << 5);
// Enable 10/100 autoneg advertisement
phy write (0x04, anar);
// Select 1000Mb full-duplex operation
gig = (1 << 9);
// Advertise full-duplex operation
phy write (0x09, gig);
// Enable and restart autonoegotiation
phy write (0x00, ((1 << 12) | (1 << 9)));
______
10Base-T Half-Duplex
uint16_t bmcr = 0;
// Reset PHY
// Enable auto-MDIX
\ensuremath{//} Set link speed to 10Mb
bmcr = (0 << 6) | (0 << 13);
// Set half-duplex operation
bmcr |= (0 << 8);
// Force loopback
// Disable 1000Mb autoneg advertisement
phy write (0x09, 0);
// Disable 10/100 autoneg advertisement
phy_write(0x04, (00001b << 0));
// Write forced link speed
phy_write(0x00, bmcr);
```

```
_____
10Base-T Full-Duplex
______
uint16_t bmcr = 0;
// Reset PHY
// Enable auto-MDIX
// Set link speed to 10Mb
bmcr = (0 << 6) | (1 << 13);
// Set full-duplex operation
bmcr |= (1 << 8);
// Force loopback
// Disable 1000Mb autoneg advertisement
phy write (0x09, 0);
// Disable 10/100 autoneg advertisement
phy write(0x04, (00001b << 0));
// Write forced link speed
phy_write(0x00, bmcr);
100Base-TX Half-Duplex
uint16_t bmcr = 0;
// Reset PHY
// Enable auto-MDIX
// Set link speed to 10Mb
bmcr = (0 << 6) | (1 << 13);
// Set half-duplex operation
bmcr |= (0 << 8);
// Force loopback
// Disable 1000Mb autoneg advertisement
phy_write(0x09, 0);
// Disable 10/100 autoneg advertisement
phy write(0x04, (00001b << 0));
// Write forced link speed
phy_write(0x00, bmcr);
100Base-TX Full-Duplex
```

```
uint16 t bmcr = 0;
// Reset PHY
// Enable auto-MDIX
// Set link speed to 10Mb
bmcr = (0 << 6) | (1 << 13);
// Set full-duplex operation
bmcr |= (1 << 8);
// Force loopback
// Disable 1000Mb autoneg advertisement
phy_write(0x09, 0);
// Disable 10/100 autoneg advertisement
phy write (0x04, (00001b << 0));
// Write forced link speed
phy_write(0x00, bmcr);
1000Base-T Half-Duplex
_____
- Half duplex operation not supported at 1000Mb per 802.3 specification
1000Base-T Full-Duplex
- Forced speed not supported, must use autoneg but only advertise 1000Mb speed
uint16_t bmcr = 0, gig = 0;
// Reset PHY
// Enable auto-MDIX
// Set link speed to 1000Mb
bmcr = (1 << 6) | (0 << 13);
// Select full-duplex operation
gig = (1 << 9);
// Force loopback
// Disable 10/100 autoneg advertisement
phy write (0x04, (00001b << 0));
// Advertise full-duplex operation
phy_write(0x09, gig);
\ensuremath{//} Enable and restart autonoegotiation
phy write (0x00, (bmcr | (1 << 12) | (1 << 9)));
```

# 10.3 MDI Register Access

Configuring physical devices and querying the status of physical devices are done via the MDIO interface (MDC and MDIO).

NOTE: This procedure is PHY-independent. The MAC access to the PHY is the same for the entire NetXtreme family.

There are two modes in which the internal MII Management interface signals (MDC/MDIO) can be controlled for communication with the internal transceiver registers. These modes are as follows:

- Autopolling mode. Enabled by setting the Enable bit in the MAC Ethernet MI Mode register. The device will poll for the link status bit in the transceiver.
- Command Control. Writing to the MI Communications register directly to either read or write the transceiver registers.

Autopolling mode has the lower priority and it will be stalled any time there is an active operation through the MI Communications register.

# 10.3.1 Operational Characteristics

The interface between the MAC and physical devices is with the two signals of:

- MDIO clock (MDC)
- Bidirectional serial data (MDIO)

The details of the MDIO interface can be found in the IEEE 802.3 specification.

### 10.3.2 Access Method

The MAC provides the auto-access method to access the Physical Device register via the MDIO interface.

### 10.3.2.1 Auto-Access Method

The Ethernet controller has a built-in interface to access physical device registers without having to control MDC and MDIO pins by software/firmware. It provides an easy way to access the physical device register.

To use this mode, MDI\_Control\_Register.MDI\_Select has to be cleared to 0. The MII\_Communication\_Register is used to access physical device.

**NOTE:** Programmers must be careful to wait for the start \_busy bit to clear. Writing to the MI Communication register prior to the completion of a previous MDI access will yield unpredictable MDI data. The previous access will not complete successfully.

For example, to read a 16-bit PHY register at offset 0x2 of a PHY device that is strapped to PHY address 1, perform the following steps:

- 1. MII Communication Register.Register Address is set to 0x2.
- 2. MII\_Communication\_Register.PHY\_Addr is set to 1.
- 3. MII Communication Register.Command is set to 0x2.
- 4. MII\_Communication\_Register.Start\_Busy is set to 1.
- 5. Poll Until MII\_Communication\_Register.Start\_Busy is cleared to 0.
- 6. MII Communication Register. Transaction Data contains 16-bit data of the PHY register.

See "Configuring the GMII/MII PHY" on page 174 for example code.

To write a value of 0x1000 into 16-bit PHY register at offset 0x0 of a PHY device which is strapped to PHY address 1, perform the following steps:

- 1. MII Communication Register.Register Address is set to 0x0.
- 2. MII\_Communication\_Register.PHY\_Addr is set to 1.
- 3. MII Communication Register.Command is set to 0x1.
- 4. MII\_Communication\_Register.Transaction\_Data is set to 0x1000
- 5. MII Communication Register. Start Busy is set to 1.
- 6. Poll Until MII\_Communication\_Register.Start\_Busy is cleared to 0.

See "Configuring the GMII/MII PHY" on page 174 for example code.

# 10.4 Wake on LAN Mode/Low-Power

## 10.4.1 Description

The Ethernet controller uses the ACPI D3 hot/cold (low-power) state to conserve energy. The OS power management policy notifies device drivers to initiate power management transitions. The device driver should move the MAC into the D3 hot/cold power state—a response to the power management request. While the Ethernet controller is in a D3 state, the RX MAC will filter incoming packets. The RX MAC compares incoming traffic for Interesting Packet pattern matches. The Ethernet controller asserts the PCI PME signal, when a positive WOL packet comparison is made. The PME signal notifies the Operating System and host device driver to transition the MAC into the D0 (high power) state.

WOL mode is a combination of PHY and MAC configurations. Both the PHY and MAC must be configured correctly to enable Broadcom's WOL technology. The Ethernet controller provides WOL pattern filters for 10/100 wire speeds.

The Ethernet controller supports both Interesting Packet pattern matching the AMD Magic Packet proprietary technology for WOL. The WOL support for the AMD Magic Packet format does not require host software to configure a pattern filter. The Magic Packet comparison is made in hardware and is enabled through a register interface. The AMD Magic Packet can be either broadcast or directed, and must contain the receiver's MAC address at least six times (repeating) in the packet. The Magic Packet wake-up is configured different from pattern match wake-up.

The following components are involved in WOL operation:

- Internal memory
- WOL Pattern Pointer register
- WOL Pattern Configuration register
- WOL streams
- Pattern data structure
- GPIO
- Firmware mailbox
- PHY auto-negotiation
- Ethernet controller power management

### 10.4.2 Functional Overview

The Ethernet controller is capable of WOL in 10/100 Mbps for copper-based controllers.

**NOTE:** When configured for WOL in 1000 Mbps mode, the Ethernet controller draws more than the 375 mA allowed by the PCI specification.

The Ethernet controller uses the TX FIFO to store pattern data (see Figure 46). During WOL operation, the transmit engine is disabled and its FIFO is free for use. The TDE fetches data from the memory arbiter starting at a location specified in the WOL\_Pattern\_Pointer register. The WOL pattern checker pulls data off the TX FIFO for packet comparisons. The RX MAC will move incoming frame(s) to the pattern checker, and the remaining RX data path is not utilized. A state machine controls the Magic Packet comparisons. The WOL state machine will move out of an Idle state, when ACPI power management is enabled. The WOL state machine will clear the TX FIFO and Match register. The Match register indicates a positive Magic Packet comparison(s) on a stream.

In 10/100 Mbit mode, data is received once every four clock cycles. The pattern checker compares the first three patterns in the first cycle, the second three patterns in the second cycle, and the third three patterns in the last cycle. It is idle during the fourth cycle. In Gigabit mode, the pattern checker gets three pattern words from the FIFO at one time.

Figure 46: WOL Functional Block Diagram



## 10.4.3 Operational Characteristics

### 10.4.3.1 Internal Memory

The WOL pattern must be stored in the Ethernet controller miscellaneous memory region. All memory locations require the host software to reinitialize the WOL pattern before each D0 to D3 transition. The RX/TX MAC places packets into this internal memory and the WOL pattern is overwritten during normal operation. When the Ethernet controller operates in D0 state, internal data structures use the same memory location as the WOL pattern. Host software should reinitialize the WOL pattern before each WOL sleep transition.

Table 74 shows the required memory regions for the WOL pattern.

Table 74: Required Memory Regions for WOL Pattern

| Internal Address Range | Size | Name                        |
|------------------------|------|-----------------------------|
| 0x8000-0x8FFF          | 8 KB | Miscellaneous Memory Region |

For 5718 Family chip, the address range starts from 0x20000 (ASF Disable) / 0x24000 (ASF Enable).

### **WOL Pattern Pointer Register**

The WOL\_Pattern\_Pointer specifies a location within Ethernet controller address space where the pattern buffers reside (see "WOL Pattern Pointer Register (offset: 0x430)" on page 277 for the register definition). The internal memory subsection discusses how host programmers can choose an address range. The WOL\_Pattern\_Pointer register uses a pointer value, not an internal memory location. The pointer value is calculated by dividing an internal memory location by the value 8. Do not program the WOL\_Pattern\_Pointer register with the actual internal memory location. Rather, host software must first convert the base address to a pointer value. Here are example conversion from memory base to pointer values:

- 0x0000 (Misc Memory)/8 = 0x00 (required value)
- 0x400 (base addr)/8 = 0x80 (pointer value)
- 0x8000 (base addr)/8 = 0x1000 (pointer value)
- 0xF000 (base addr)/8 = 0x1E00 (pointer value)

### 10.4.3.2 WOL Pattern Configuration Register

The WOL\_Pattern\_Configuration register contains two programmable data fields. Both fields use different units of measurement, so the host programmer should be careful (see "WOL Pattern Configuration Register (offset: 0x434)" on page 277 for the register definition). This register is used to position and extract data from RX Ethernet frames.

- Offset Field—The Offset field in the WOL\_Pattern\_Configuration register specifies a position in RX Ethernet frame(s), where comparisons for WOL patterns should begin. This register uses a unit of measurement specified in terms of 2-byte chunks. Software should not program this field with a byte value, but should first normalize to a 2-byte unit. Hardware cannot begin WOL comparisons on odd byte alignments (i.e., 3,5,7,9 offsets). Host software must begin all pattern matching on even byte boundaries (i.e., 2,4,6,8 offsets). The 2 bytes per unit forces even byte alignment. For example:
  - 0x14 (byte offset)/2 = 0x0A (register ready)
  - 0x28 (byte offset)/2 = 0x14 (register ready)
  - 0xFC (byte offset)/2 = 0x7E (register ready)

■ Length Field—The Length field in the WOL\_Pattern\_Configuration register specifies the number of clock cycles required to compare a variable number of bytes, in the RX stream. The Length field uses a unit of measurement specified in terms of memory arbiter clock cycles. Software should not program this field with a byte value. The Length field should be programmed with the maximum number of clocks required to compare the largest pattern size for the nine streams (10/100 mode only).

**NOTE:** The Ethernet controller only supports one pattern stream at Gigabit wire speed, so the length field will always be the largest pattern size.

The programmer must use the following equation to calculate the number of clock cycles required to match patterns at 10/100 wire-speed: (Length/2) \* 3 MA clocks. The equation breaks down as follows:

- Determine the number of bytes in the RX Ethernet frame to compare. This value is a byte length.
- The WOL pattern checker can compare two bytes simultaneously. Divide length by two bytes and round up to nearest integer value.
- The Ethernet controller compares 2 bytes every three memory arbiter (MA) clock cycles. Multiply (Length/2) by three clock cycles.
- The following are example clock cycle calculations:
  - Data stream length = 25 bytes
  - 25 bytes/2 = 12.5 byte-pairs
  - Round(12.5) = 13 byte-pairs
  - 13 byte-pairs \* 3 clocks/byte-pairs = 39 clocks (register ready)
  - Data stream length = 83 bytes
  - 83 bytes/2 = 41.5 byte-pairs
  - Round(41.5) = 42 byte-pairs
  - 42 byte-pairs \* 3 clocks/byte-pair = 126 clocks (register ready)

#### 10.4.3.3 WOL Streams

A stream is a comparison operation on RX frame(s). When the MAC is running at 10/100 Mbps wire speed, nine different patterns can be compared against the RX frame(s). The Ethernet controller moves RX frame(s) into nine parallel comparators, and the frame is matched simultaneously. The MAC is capable of filtering nine different patterns in 10/100 modes. The WOL pattern checker breaks frames into 2-byte pairs, so all nine comparators can begin matching data. In Figure 47 on page 185, three Ethernet frames are compared against the nine available patterns.

Figure 47: Comparing Ethernet Frames Against Available Patterns (10/100 Ethernet WOL)

# 10/100 Ethernet WOL



#### 10.4.3.4 Pattern Data Structure

The maximum number of entries in either 10/100 or 1000 mode is 128. The Ethernet controller cannot process a pattern that requires more than 128 entries. The size of an entry will vary based on 10/100 or 1000 Mbps mode. Additionally, all unused rows must be initialized with zeros. The WOL hardware cannot process an entry unless unused rows and rules have been zeroed out (see Figure 48).

Figure 48: Unused Rows and Rules Must Be Initialized with Zeros



Frame patterns are stored as data structures in memory. A control word is always present in a 64-bit entry/row. The control word describes proceeding data fields in the entry.

In 10/100 Mbps mode, one WOL entry requires three 64-bit wide rows (see Table 76). The total length of an entry is 192 bits. Each 64-bit row contains a 16-bit control word, which identifies byte enables (see Table 76). The remaining 48-bits contain 2-byte rules. The 2-byte rules are distributed across three streams: S, S+1, and S+2. The next row's 2-byte rules will correspond to three more streams: S+3, S+4, and S+5. Both Table 75 and Table 76 use Sx notation to denote separate comparison streams. The D0 notation indicates the first 2 bytes in the packet stream are compared.

Table 75: 10/100 Mbps Mode Frame Patterns Memory

| 63      | 48 47 | 32 31 | 16 15   | 0  |
|---------|-------|-------|---------|----|
| CTRL012 | S0D0  | S     | 1D0 S2[ | 00 |
| CTRL345 | S3D0  | S     | 4D0 S5[ | 00 |
| CTRL678 | S6D0  | S     | 7D0 S8I | 00 |

Table 76: Frame Control Field for 10/100 Mbps Mode

| Bits  | Field               | Description                          | Access |
|-------|---------------------|--------------------------------------|--------|
| 63:62 | Reserved            |                                      |        |
| 61    | S0 High Byte Enable | Enable S0 higher byte for comparison | RW     |
| 60    | S0 Low Byte Enable  | Enable S0 lower byte for comparison  | RW     |
| 59    | S1 High Byte Enable | Enable S1 higher byte for comparison | RW     |
| 58    | S1 Low Byte Enable  | Enable S1 lower byte for comparison  | RW     |
| 57    | S2 High Byte Enable | Enable S2 higher byte for comparison | RW     |
| 56    | S2 Low Byte Enable  | Enable S2 lower byte for comparison  | RW     |

Table 76: Frame Control Field for 10/100 Mbps Mode (Cont.)

| Bits  | Field    | Description      | Access |
|-------|----------|------------------|--------|
| 55:51 | Reserved | -                | _      |
| 50    | S0 Done  | End of S0 Stream | RW     |
| 49    | S1 Done  | End of S1 Stream | RW     |
| 48    | S2 Done  | End of S2 Stream | RW     |

Table 77 shows an example of how 10/100 Mbps frame data is split up in the pattern data structure. Eight streams are compared simultaneously with three 64-bit rows comprising one WOL entry. Rows 0–2 compare frame data0 against eight rules. Rows 3–5 compare frame data1 against the next eight rules. Rows 6–9 compare data2 against the final eight rules. The eight rules may be uniquely defined for all three WOL entries.

Table 77: Example of Splitting 10/100 Mbps Frame Data in Pattern Data Structure

| Data[63:48]  | Data[47:32]     | Data[31:16]     | Data[15:0]      |
|--------------|-----------------|-----------------|-----------------|
| Control Bits | Stream 0 data 0 | Stream 1 data 0 | Stream 2 data 0 |
| Control Bits | Stream 3 data 0 | Stream 4 data 0 | Stream 5 data 0 |
| Control Bits | Stream 6 data 0 | Stream 7 data 0 | Stream 8 data 0 |
| Control Bits | Stream 0 data 1 | Stream 1 data 1 | Stream 2 data 1 |
| Control Bits | Stream 3 data 1 | Stream 4 data 1 | Stream 5 data 1 |
| Control Bits | Stream 6 data 1 | Stream 7 data 1 | Stream 8 data 1 |
| Control Bits | Stream 0 data 2 | Stream 1 data 2 | Stream 2 data 2 |
| Control Bits | Stream 3 data 2 | Stream 4 data 2 | Stream 5 data 2 |
| Control Bits | Stream 6 data 2 | Stream 7 data 2 | Stream 8 data 2 |

### 10.4.3.5 Firmware Mailbox

When the Ethernet controller initializes (the firmware boot code is loaded from NVRAM when the chip powers on or when reset completes), the boot code checks the T3\_FIRMWARE\_MAILBOX in shared memory. When the T3\_MAGIC\_NUM signature (0x4B657654) is present, the boot code does not issue a hard reset to the PHY. This is especially important in WOL mode since the PHY should not be reset.

Before the host software issues a reset to the Ethernet controller, it must write the T3\_MAGIC\_NUM to the shared memory address T3\_FIRMWARE\_MAILBOX (0xb50). This address is a software mailbox, which boot code polls before it resets the PHY. The boot code will acknowledge the signature by writing the one's complement of the T3\_MAGIC\_NUM back into the T3\_FIRMWARE\_MAILBOX. If the T3\_MAGIC\_NUM is present, the boot code will not reset the PHY. After resetting the Ethernet controller, host software should poll for the one's complement of the T3\_MAGIC\_NUM before it proceeds, otherwise, boot code initialization may interfere with the host software initialization.

If the host software will be controlling the WOL configuration, it should write the DRV\_WOL\_SIGNATURE (0x474c0000) to the shared memory address DRV\_WOL\_MAILBOX (0xd30) so that the boot code will not take over the WOL initialization. If the DRV\_WOL\_SIGNATURE is not present, and WOL has been enabled, the boot code will assume that the host software is a legacy driver and skip the WOL initialization. If WOL is disabled, the boot code will take over the WOL initialization based on the NVRAM configuration.

**Table 78: Firmware Mailbox Initialization** 

| Name                | Address | Recommended Value |
|---------------------|---------|-------------------|
| T3_FIRMWARE_MAILBOX | 0x0B50  | 0x4B657654        |

**Table 78: Firmware Mailbox Initialization (Cont.)** 

| Name            | Address | Recommended Value |
|-----------------|---------|-------------------|
| DRV_WOL_MAILBOX | 0xd30   | 0x474c0000        |

### 10.4.3.6 PHY Auto-Negotiation

The integrated PHY should be configured to auto-negotiate for a 10 Mbps connection (see Table 79). This step is required if the NIC must be placed into a D3 cold state. Half- or full-duplex operation is acceptable. Software must modify auto-advertise configurations in the PHY's MDI registers. The link partner will read advertisement settings to find a highest common capability. Since WOL requires 10 Mbps wire speed, the two PHYs will effectively auto-negotiate for half- or full-duplex connection.

Table 79: Recommended Settings for PHY Auto-Negotiation

| Register                      | Bit                      | Recommended Value |
|-------------------------------|--------------------------|-------------------|
| Auto_Negotation_Advertisement | 10_BASE_TX_Half_Duplex   | Enable            |
| Auto_Negotation_Advertisement | 10_BASE_TX_Full_Duplex   | Enable            |
| Auto_Negotation_Advertisement | 100_BASE_TX_Half_Duplex  | Disable           |
| Auto_Negotation_Advertisement | 100_BASE_TX_Full_Duplex  | Disable           |
| 1000BASE-T_Control            | 1000_BASE_TX_Half_Duplex | Disable           |
| 1000BASE-T_Control            | 1000_BASE_TX_Full_Duplex | Disable           |

### 10.4.3.7 Power Management

The clocking inputs need to be modified for WOL mode (see Table 80). The RX CPU is not required during WOL operation, so its clock can be disabled. The MAC has an internal phase-locked loop that clocks internal logic at 133 MHz. Software must select an alternate clocking source and then disable this PLL.

**Table 80: WOL Mode Clock Inputs** 

| Register          | Bit                    | Recommended Value |
|-------------------|------------------------|-------------------|
| PCI Clock_Control | RX RISC_Clock_Disable  | Set the bit to 1  |
| PCI Clock_Control | Select_Alternate_Clock | Set the bit to 1  |
| PCI Clock_Control | PLL133                 | Set the bit to 1  |

The settings shown in Table 81 on page 189 enable Magic Packet detection logic in the MAC. These settings also enable the MAC to assert PME on the PCI bus. The RX MAC should maintain the multicast and broadcast settings that were previously configured by the NOS. The Microsoft® power management specification states:

"Only a frame that passes the device's MAC, broadcast, or multicast address filter and matches on the previously loaded sample patterns will cause the wake-up signal to be asserted."

The ACPI\_Power-on bit needs to be set for pattern match, but not for Magic Packet recognition. The Magic Packet detection mechanism is separate from the pattern match mechanism. Host software may configure WOL using four filter permutations:

- Pattern match WOL disabled. Magic Packet disabled.
- Pattern match WOL enabled. Magic Packet disabled.
- Pattern match WOL disabled. Magic Packet enabled.
- Pattern match WOL enabled. Magic Packet enabled.

**Table 81: Magic Packet Detection Logic Enable** 

| Register                            | Bit(s)                 | Recommended Value |
|-------------------------------------|------------------------|-------------------|
| PCI Power_Management_Control/Status | PME_Enable             | Enable            |
| PCI Power_Management_Control/Status | Power_State            | 0x03              |
| Ethernet_MAC_Mode                   | ACPI_Power-On          | See above         |
| Ethernet_MAC_Mode                   | Magic_Packet_Detection | See above         |

# 10.4.3.8 Integrated MACs

Table 82 lists the WOL mode control registers in the Ethernet controllers.

Table 82: Integrated MAC WOL Mode Control Registers

| Register                           | Bit(s) Name                  | Description                                                                                                                      | Cross Reference                                                         |
|------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| WOL_Pattern_<br>Pointer            | All                          | This register points to an internal memory location. Programmers should calculate pointer value by dividing a base address by 8. | "WOL Pattern Pointer Register (offset: 0x430)" on page 277.             |
| WOL_Pattern_<br>Configuration      | Length                       | The number of memory arbiter clock cycles needed to read X bytes in the RX stream/ frame.                                        | "WOL Pattern Configuration<br>Register (offset: 0x434)" on<br>page 277. |
|                                    | Offset                       | The number of bytes into the RX stream/ frame to begin the pattern comparison.                                                   |                                                                         |
| Ethernet_MAC_<br>Mode              | Port_Mode                    | This bit field specifies the type of interface the Ethernet controller port is currently using: MII, GMII, or none.              | "EMAC Mode Register (offset: 0x400)" on page 272.                       |
|                                    | Magic_Packet_<br>Detection   | Enable WOL pattern filtering.                                                                                                    |                                                                         |
|                                    | Promiscuous_mode             | All frames are forwarded, without any filtering, when this bit is enabled.                                                       |                                                                         |
| PCI Clock_Control                  | RX RISC_Clock_Disable        | Disable the clock to the receive CPU.                                                                                            | Clock Control Register as per PCI                                       |
|                                    | Alternate_Clock_Source       | Use an alternate clock as a reference, rather than the PLL 133.                                                                  | specifications.                                                         |
|                                    | PLL133                       | Disable the 133 MHz phase-locked loop.                                                                                           |                                                                         |
| Misc Local Control                 | Misc_Pin_0_Output            | GPIO pin 0.                                                                                                                      | "Miscellaneous Local Control                                            |
|                                    | Misc_Pin_0_Output_<br>Enable | When asserted, MAC drives pin output.                                                                                            | Register (offset: 0x6808)" on page 418.                                 |
|                                    | Misc_Pin_1_Output            | GPIO pin 1.                                                                                                                      |                                                                         |
|                                    | Misc_Pin_1_Output_<br>Enable | When asserted, MAC drives pin output.                                                                                            |                                                                         |
|                                    | Misc_Pin_2_Output            | GPIO pin 2.                                                                                                                      |                                                                         |
|                                    | Misc_Pin_2_Output_<br>Enable | When asserted, MAC drives pin output.                                                                                            |                                                                         |
| Power Management<br>Control/Status | PME_Enable                   | Enable the Ethernet controller to assert PME on PCI bus.                                                                         | "Power Management Control/<br>Status Register (offset: 0x4C)" on        |
|                                    | Power_State                  | Set the ACPI power state: D0, D3.                                                                                                | page 242                                                                |

# 10.4.4 WOL Data Flow Diagram

The Ethernet controller and PHY are both configured for WOL mode. The process is as follows:

- 1. Clear the PME\_Status bit in the Power Management Control/Status Register (offset: 0x4C) (see "Power Management Control/Status Register (offset: 0x4C)" on page 242). This bit must be cleared, so the PME interrupt is not immediately generated once the NIC is moved to the D3 state. The bit could be asserted from a previous D3–D0 transition.
- Set the Mask\_PCI\_Interrupt\_Output bit in the Miscellaneous\_Host\_Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). This bit should be set, so the Ethernet controller does not generate interrupts during the WOL configuration of the PHY. The device driver's ISR may attempt to reset and reconfigure the PHY as part of an error recovery code path.
- 3. If host software must place the NIC into D3 cold state, the following step is necessary. Set the 10\_Base\_TX\_Half\_Duplex and 10\_BASE\_TX\_Full\_Duplex Capability bits, in the Auto-Negotiation Advertisement Register. Clear the 100\_BASE\_TX\_Full\_Half\_Duplex and 100\_BASE\_TX\_Full\_Duplex Capability bits, in the Auto-Negotiation Advertisement Register. Clear the 1000\_BASE\_TX\_Half\_Duplex and 1000\_BASE\_TX\_Full\_Duplex Capability bits, in the 1000BASE-T Control Register. The link partner will now only be able to auto-negotiate for 10 Mbps speed full/half-duplex.
- 4. Set the Restart\_Auto\_Negotiation bit in the MII Control Register. The integrated PHY and link partner will now reconfigure for 10 Mbps wire speed. Essentially, 10 Mbps link must be auto-negotiated or forced.
- 5. Disable the FHDE, RDE, TDE bits of the "EMAC Mode Register (offset: 0x400)" on page 272", and on-chip RISCs.
- 6. Host software must write the signature 0x4B657654 to internal memory address 0x0B50. Check for one's complement of 0x4B657654.
- 7. Enable the Wake\_On\_LAN bit in the AUXILIARY Control Register.
- 8. For Interesting Packet WOL Only: Set up the Interesting Packet pattern in Ethernet controller local memory.
- 9. For Interesting Packet WOL Only: Write a pointer value to the "WOL Pattern Pointer Register (offset: 0x430)" on page 277. This register uses a normalized pointer value, not a device base address. The value written to this register is BCM5700\_BASE\_ADDR/8. The base address must be a specific location in local memory: 0x8000, 0xC000, or 0xD000. The choice of memory location depends upon other MAC configurations, and the selection is not arbitrary.
- 10. For Interesting Packet WOL Only: Write the Offset field in the "WOL Pattern Configuration Register (offset: 0x434)" on page 277. The WOL pattern checker will position into received frames on two-byte intervals. The pattern checker compares two bytes in parallel, so host software should program the offset field accordingly. Host software may perceive this unit as OFFSET BYTE/2 units.
- 11. For Interesting Packet WOL Only: Write the Length field in the "WOL Pattern Configuration Register (offset: 0x434)" on page 277. The length value is specified in terms of Memory Arbiter clock cycles, not bytes/words/dwords. A comprehensive discussion of how the clock cycles are calculated will be presented.
- 12. Set the Port\_Mode field in the "EMAC Mode Register (offset: 0x400)" on page 272 to GMII mode. These bits enable the GMII between the MAC and internal PHY.
- 13. For Interesting Packet WOL Only: Enable the ACPI\_Power-On bit in the "EMAC Mode Register (offset: 0x400)" on page 272. This bit will enable logic for D3 hot/cold transitions to D0 ACPI state. The MAC will also be capable of asserting PME on the PCI bus.
- 14. For Interesting Packet WOL Only: Enable the Magic\_Packet\_Detection bit in the "EMAC Mode Register (offset: 0x400)" on page 272. The WOL logic will compare RX frames for Magic Packet patterns.

- 15. Set the RX RISC\_Clock\_Disable bit in the PCI Clock\_Control register (see "Power Management Control/Status Register (offset: 0x4C)" on page 242). The receive CPU will be stopped, and the clocking circuitry disabled.
- 16. Set the Enable\_Alternate\_Clock bit in the PCI Clock\_Control register. The Ethernet controller's 133 MHz Phase Locked Loop (PLL) no longer clocks internal logic and an alternate clock reference is used. Set the PLL LowPowerClock bit while keeping the Enable\_Alternate\_Clock bit set. Wait at least 27 μs and then clear the Enable\_Alternate\_Clock bit. The Ethernet controller's PLL is then switched to its lower power consumption mode.
- 17. In NIC applications, switch from VMAIN to VAUX to prevent a GRC reset. Set the required GPIOs of Ethernet controller if any of them are used for switching the power from VMAIN to VAUX.
- 18. Enable the RX MAC by setting the Enable bit of "Receive MAC Mode Register (offset: 0x468)" on page 282" and put it in promiscuous mode by setting the Promiscuous Mode bit of "Receive MAC Mode Register (offset: 0x468)" on page 282.
- 19. Enable the PME bit in the PCI Power Management Control/Status Register (offset: 0x4C) (see "Power Management Control/Status Register (offset: 0x4C)" on page 242). The Ethernet controller asserts PME to wake up the system. Set the Power\_State bits to D3 in the PCI Power Management Control/Status Register (offset: 0x4C).

## 10.5 Flow Control

# 10.5.1 Description

The Ethernet controller supports IEEE 802.3x flow control. Flow control is a switched Ethernet capability, where link partners may pause traffic. The 802.3x flow control specifies that a MAC sublayer may transmit pause frames. The pause frames instruct the MAC's link partner to wait a specified amount of time, before sending additional frames. This delay provides the MAC time to free packet buffers. Conversely, the MAC sublayer must also accept/receive pause frames. Flow control is used by switches and bridges to prevent clients of dissimilar speeds from exhausting switching packet buffers. Clients and servers may use flow control for similar reasons. A very important requirement is that both link partners must share a full-duplex connection for flow control to be enabled. IEEE 802.3x flow control does not operate on a half-duplex connection. More information on flow control can be found in Appendix A: "Flow Control," on page 507.

The following architectural blocks are integral to flow control:

- Transmit MAC
- Receive MAC
- Statistics Block
- PHY Auto-negotiation
- PHY Auto-Advertise

# 10.5.2 Operational Characteristics

The Ethernet controller implements pause functionality using Xon and Xoff states. The MAC will extract a pause quantum from a pause control frame. Then, the MAC will configure its internal timer with the pause\_time specified by the link partner. Frames that are currently in the transmit engine will be completed before the transmit engine is inhibited. The MAC has moved flow control into a Xoff state once the transmit engine is inhibited. Note that the transmit engine is not completely disabled since the IEEE 802.3 specification stipulates that MAC control frames should not be paused.

One of the following conditions moves the Ethernet controller into an Xon state:

- Link partner sends a pause frame with pause time = 0.
- Internal pause timer expires.

### 10.5.2.1 Transmit MAC

The transmit MAC is responsible for sending flow control frames. Software enables the transmit MAC to send flow control frames by setting the Enable\_Flow\_Control bit in the Transmit\_MAC\_Mode register (see "Transmit MAC Mode Register (offset: 0x45C)" on page 279). When software clears the Enable\_Flow\_Control bit, the transmit MAC will not generate flow control frames. The MAC\_RX\_MBUF\_Low\_Water\_Mark register value triggers PAUSE frames to be transmitted when a threshold value is passed. Software may alter the watermark to tune system performance.

**Table 83: Transmit MAC Watermark Recommendation** 

| Register                   | Recommended Value |
|----------------------------|-------------------|
| MAC_RX_MBUF_Low_Water_Mark | 24                |

As soon as PAUSE frame is transmitted, any incoming packet can be dropped, and the ifInDiscard counter in statistics will increase. When packet size is small (64 bytes) with 1000 Mbps, more frames can be dropped. Even if the PAUSE frame is transmitted, Pause frames cannot inhibit MAC control frames.

Low Water Mark Maximum Receive Frames register (see "Low Watermark Maximum Receive Frame Register (offset: 0x504)" on page 287) control the number of good frames to receive after the RX MBUF Low Water Mark has been reached. After the RX MAC receives this number of frames, it will drop subsequent incoming frames until the MBUF High Water Mark is reached.

The IEEE 802.3 pause control frame contains a pause\_time field. The Ethernet controller inserts a time quanta into the pause\_time field. Software should set the Enable\_Long\_Pause bit in the Transmit\_MAC\_Mode register to configure long pause quanta. Clearing the Enable\_Long\_Pause bit will default the pause\_time back to the shorter quanta. Table 84 shows the pause quanta based on the Enable\_Long\_Pause bit setting.

Table 84: Pause Quanta

| Enable_Long_Pause Bit | Pause_Time |
|-----------------------|------------|
| DISABLED (0)          | 0x1FFF     |
| ENABLED (1)           | 0xFFFF     |

#### 10.5.2.2 Receive MAC

The Ethernet controller receive MAC's link partner may want to inhibit frame transmission until upstream resources become available. The receive MAC must be configured to accept IEEE 802.3x pause frames (see Table 85). Software should set the Enable\_Flow\_Control bit in the Receive\_MAC\_Mode\_Control register to enable automatic processing of flow control frames. If software clears the Enable\_Flow\_Control bit, IEEE 802.3x pause frames will be discarded. The Keep\_Pause bit in the Receive\_MAC\_Mode\_Control register will instruct the RX engine to forward pause frames to host memory. Software may be interested in setting this bit for debugging or promiscuous/sniffer configurations. Passing pause frames to the host will increase DMA and protocol processing and consume available host buffers. The receive MAC will filter pause control frames when the Keep\_Pause bit is disabled.

Table 85: Keep\_Pause Recommended Value

| Register.Bit                        | Recommended Value |  |
|-------------------------------------|-------------------|--|
| Receive_MAC_Mode_Control.Keep_Pause | DISABLED          |  |

### 10.5.2.3 Statistics Block

The statistic block shown in Table 86 is a common data structure. The relationships of flow control statistics are discussed in this section. Xon/Xoff statistical counters are related to internal Ethernet controller flow control states. Xon is associated with transmit enabled state and Xoff is associated with transmit disabled state. These Xon/Xoff states are not part of the IEEE 802.3 specification; the Ethernet controller uses Xon/Xoff to manage flow control state and transitions. The Xon/Xoff statistics provide programmers with a high level of granularity for the measurement of Ethernet controller flow control performance in a LAN (see Appendix A: "Flow Control," on page 507).

Table 86: Statistic Block

| Statistic               | Description                                                                                                                           |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|
| xoffStateEntered        | This counter is bumped under the following conditions:                                                                                |  |  |
|                         | ■ IEEE 802.3 MAC flow control pause frame received with valid CRC.                                                                    |  |  |
|                         | <ul><li>(Pause_time &gt; 0) The link partner requests transmission inhibit.</li></ul>                                                 |  |  |
|                         | The counter increments independently of the enabled/disabled state of Receive_MAC_Mode_Control.Flow_Enabled.                          |  |  |
| xonPauseFramesReceived  | This counter is incremented under the following conditions:                                                                           |  |  |
|                         | ■ IEEE 802.3 MAC flow control pause frame received with valid CRC.                                                                    |  |  |
|                         | <ul> <li>(Pause_time == 0) The link partner no longer requires the device family to pause/wait/delay<br/>outgoing packets.</li> </ul> |  |  |
|                         | The counter increments independently of the enabled/disabled state of Receive_MAC_Mode_Control.Flow_Enabled.                          |  |  |
| xoffPauseFramesReceived | This counter is incremented under the following conditions:                                                                           |  |  |
|                         | ■ IEEE 802.3 MAC flow control pause frame received with valid CRC.                                                                    |  |  |
|                         | <ul> <li>(Pause_time &gt; 0) The link partner requires the BCM571X/BCM5720 family to pause/wait/delay outgoing packets.</li> </ul>    |  |  |
|                         | The counter increments independently of the enabled/disabled state of                                                                 |  |  |
|                         | Receive_MAC_Mode_Control.Flow_Enabled.                                                                                                |  |  |
| outXon                  | This counter is incremented under the following conditions:                                                                           |  |  |
|                         | <ul><li>Transmit_MAC_Mode_Control.Flow_Enabled bit is set.</li></ul>                                                                  |  |  |
|                         | <ul><li>(MAC_RX_MBUF_Low_Water_Mark &gt; Threshold Value MAC resources are available.</li></ul>                                       |  |  |
|                         | ■ (pause_time == 0) 802.3 MAC flow control frame is sent.                                                                             |  |  |
| outXoff                 | This counter is incremented under the following conditions:                                                                           |  |  |
|                         | <ul><li>Transmit_MAC_Mode_Control.Flow_Enabled bit is set.</li></ul>                                                                  |  |  |
|                         | <ul> <li>(MAC_RX_MBUF_Low_Water_Mark &lt; Threshold Value) MAC resources are running low and a<br/>pause is desired.</li> </ul>       |  |  |
|                         | <ul><li>(pause_time &gt; 0) IEEE 802.3 MAC flow control frame is sent.</li></ul>                                                      |  |  |

### 10.5.2.4 PHY Auto-Negotiation

The PHY encodes flow control capability into Fast Link Pulse (FLPs) bursts. Link partners will extract encoded flow control capability from FLPs and then create a Link Code Word (LCW). The LCW is a message, which contains a selector and technology ability field. The technology ability field contains a bit called Pause\_Operation\_for Full\_Duplex\_Link (A5). Refer to Annex 28-B of the IEEE 802.3 specifications. The A5 bit signifies that a link partner has implemented pause functionality. If both link partners support auto-negotiation, they will further exchange data regarding flow control, using the next page bit in the LCW.

Auto-advertise is integrally tied to auto-negotiation. If link partner does not support pause functionality, the PHY Auto\_Negotation\_Link\_Partner\_Ability\_Register does not set the Pause\_Capable bit. The Ethernet controller should not send pause frames to this link partner since flow control is not implemented or disabled. The Ethernet controller can still accept pause frames, but sending a pause frame does not yield a preferred result.

### 10.5.2.5 Integrated MACs

Table 86 on page 193 lists the flow control registers in the Ethernet controllers.

**Table 87: Integrated MAC Flow Control Registers** 

| Register                       | Bit(s) Name                                                                                          | Description                                                    | Cross Reference                                                                       |
|--------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------|
| Receive MAC Mode               | Enable_Flow_Control                                                                                  | Enable automatic processing of IEEE 802.3 flow control frames. | See "Receive MAC Mode Register (offset: 0x468)" on page 282.                          |
| Transmit MAC Mode              | Enable_Flow_Control                                                                                  | Enable automatic processing of IEEE 802.3 flow control frames. | See "Transmit MAC Mode Register (offset: 0x45C)" on page 279.                         |
| MAC_RX_MBUF_<br>Low_Water_Mark | All 32 bits  The number of internal buffers that must be available before the RX engine can accept a |                                                                | See "Low Watermark Maximum<br>Receive Frame Register (offset:<br>0x504)" on page 287. |
|                                |                                                                                                      | Threshold value for initiating flow control.                   |                                                                                       |

## 10.5.3 Flow Control Initialization Pseudocode

```
//Check the Link State
If (MII Status Reg.Link Status == TRUE) Then
   //Check PHY status register for full-duplex configuration
   If (MII Aux Status Reg.Auto Neg HCD ==
       (1000 FULL DUPLEX Or 100 FULL DUPLEX Or 10 FULL DUPLEX) ) Then
          //Check if USER has forced either auto-negotiation or auto-advertise
          If ( (Driver Auto Neg Variable == ENABLED) And
             (Driver Auto Advertise Variable != FORCED SPEED DUPLEX )) Then
             // Probe Phy control registers for advertised flow control info
             // Expected abilities should match the configured abilities. Expected abilities
             // are based on the IEEE 803.3ab flow control subsection.
             If ( (Auto_Neg_Advertise_Reg.Asymetric_Pause != 802.3ab Table 28B-3 ) And
                 (Auto Neg Advertise Reg.Pause Capable != 802.3ab Table 28B-3 ) ) Then
                 //The current advertised state does not match 802.3 specifications
                Driver Link link state = LINK STATUS DOWN
             }
             Else
             {
                    (Auto Neg Advertise Reg.Pause Capable == ENABLED)
                    If ( Auto Neg Advertise Reg.Asymetric Pause == ENABLED) ) Then
                       If (Auto_Neg_Link_Partner_Ability_Reg.Pause_Capable == ENABLED) Then
                           Driver Flow Capability = FLOW CONTROL TRANSMIT PAUSE \
                              | FLOW CONTROL RECEIVE PAUSE
                       Else If (Auto Neg Link Partner Ability Reg. Asymetric Pause == \
                          ENABLED) Then
                          Driver Flow Capability = FLOW CONTROL RECEIVE PAUSE
                       Else
                          Driver Flow Capability = NONE
                    //The local physical layer was not configured to advertise Asymmetric pause
                    Else
                           (Auto Neg Link Partner Ability Reg. Pause Capable == ENABLED) Then
                       Τf
                           Driver Flow Capability = FLOW CONTROL TRANSMIT PAUSE \
                              | FLOW CONTROL RECEIVE PAUSE
                       }
                       Else
                           Driver Flow Capability = NONE
                 // The local physical layer was not configured to advertise Pause capability
```

```
Else If (Auto Neg Advertise Reg. Asymetric Pause == ENABLED) Then
                 If (Auto Neg Link Partner Ability Reg.Pause Capable == ENABLED) Then
                     Driver Flow Capability = FLOW CONTROL TRANSMIT PAUSE
                 }
                 Else
                     Driver Flow Capability = NONE
       } //Link Status is up
    } // Auto negotiation was not disabled && Speed Duplex was not forced
   Else
       // The use forced speed/duplex, so the partner's flow control capabilities are
       // indeterminate - software cannot use the Link Partner Abitity
       // registers.
       Driver Flow Capability= DISABLED
} //The current link is full-duplex at 10/100/1000 wire speeds
{
       //Full-Duplex mode is not available or forced half-duplex
       //Flow control is not available in half-duplex mode.
       Driver Flow Capability = NONE
//Configure MAC Flow Control Registers
if ( Driver Flow Capability & FLOW CONTROL RECEIVE PAUSE )
   Receive MAC Mode Control Register. Enable Flow Control = ENABLED
if ( Driver Flow Capability & FLOW CONTROL TRANSMIT PAUSE ) Then
   Transmit MAC Mode Control Register. Enable Flow Control = ENABLED
// Link is up on the local PHY
```

# **Chapter 11: Interrupt Processing**

# 11.1 NetXtreme Legacy Interrupt Model

For reference, this section reviews the legacy NetXtreme interrupt model.

When the controller completes a transmit or a receive event, it updates a status block in host memory. This status block contains information that tells the host which transmit buffers have been DMAed by the controller, and which receive buffer descriptors (Rx BDs) have been consumed by a newly received packet. Normally, host software checks this status block whenever an interrupt is generated. In addition, host software could also poll the status block to determine whether it had been updated by the hardware since the last time it read the status block (this is called during interrupt processing). The legacy status block format is shown in Table 88.

Whenever the controller updates the status block, it decides whether to assert the interrupt line (INTA#). If MSI were enabled, the controller would DMA the MSI data DWORD instead of asserting a line interrupt (or, in the case of PCIe, instead of sending an assert interrupt message).

The controller has interrupt avoidance mechanisms ("host interrupt coalescing") that allow the host to instruct the controller not to generate an interrupt every time it writes a status block into host memory. In addition, it has mechanisms that allow host software to control when and how often the status block is updated in host memory. Since the status block updates and interrupt generation need not happen one-to-one, the following mechanism is in place to communicate to host software if the status block was updated since it was last read by the host—essentially avoiding race conditions:

- The controller DMAs the status block into host memory before a line interrupt or MSI is generated.
- 2. The host interrupt service routine (ISR) reads an "update bit" at the top of the status block and checks whether this bit is set to 1.
- 3. When set to 1, the update bit of the status block indicates to host that the status block has been refreshed by the controller.
- 4. The ISR must then write a zero to clear/deassert this bit to dirty the status block, and then the ISR may proceed to read the updated producer/consumer index pointers, etc.
- 5. If the update bit is not set to 1, the interrupt may be considered spurious and the ISR may wish to abort.

This mechanism allows host software to determine if the status block has been updated. Due to various platform-dependent asynchronous timing issues, an ISR may occasionally see stale status block data. In this case, the ISR may either spin and wait for the status block DMA to complete and explicitly flush the status block, or just wait for the next line interrupt.

Table 88: NetXtreme Legacy Status Block Format

| Offset | 3116                                          | 150                                                              |                 |  |
|--------|-----------------------------------------------|------------------------------------------------------------------|-----------------|--|
| 0x00   | Status Word                                   |                                                                  |                 |  |
| 0x04   | [31:8] Reserved 0x0                           |                                                                  | [7:0]Status Tag |  |
| 0x08   | Receive Standard Producer Ring Consumer Index | e Standard Producer Ring Consumer Index Receive Return Ring 1 Pr |                 |  |
| 0x0C   | Receive Return Ring 2 Producer Index          | ndex Receive Return Ring 3 Producer Index                        |                 |  |
| 0x10   | Send BD Consumer Index                        | Receive Return Ring 0 Producer Index                             |                 |  |
| 0x14   | Reserved 0x0                                  | Receive Jumbo Producer Ring Consumer Index                       |                 |  |

### **Legacy Status Word Format:**

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bit [2]: Error/Attention
- Bit [3]: Resvd–always 0
- Bit [4]: Resvd–always 0
- Bit [5]: Resvd–always 0
- Bits [31:6]: Reserved 0x0

### 11.1.1 ISR Flow

The basic flow of an ISR is as follows:

- Acknowledge interrupt. Write a nonzero value (i.e., value = 1) to interrupt mailbox 0 (see Interrupt Mailbox 0 Register 0x200) for host standard and flat modes, and other Interrupt Mailbox Registers 0x5800-0x40 for indirect mode, to indicate to the controller that the driver is currently processing the interrupt. This step temporarily disables further device interrupts.
- 2. Read and save the value of the status tag field of the status block.
- 3. Claim the interrupt. Determine if action is required. Read the updated bit of the status word. If the update bit is asserted then the controller has updated the status block.
- 4. Clear the update bit of the status word in the status block. This indicates that the host driver either has or will touch the status block. If a during interrupt event occurs, the host driver can examine the update bit later to determine if a fresh status block has been moved to host memory space since.
- 5. Check for Rx traffic indications:
  - a. Loop through enabled Rx Return Rings (0 to 3).
  - b. Check for differences between Rx return ring producer indices (status block) and Rx return ring consumer indices (value written to mailbox on previous call) as this indicates the number of Rx frames to process from the Rx return ring.
  - c. Process the Rx packets.
  - d. Update the Rx return ring consumer indices in each mailbox.
- 6. Check for Tx completions:
  - a. Check for differences between previous consumer index (tracked by host driver) and current consumer index in the status block. These are the Tx BDs which can be made available again to the next send operation.
  - b. Update the previous consumer index (i.e., next call) to the value of the status block consumer index.
- 7. Compare the current value of the status tag to the saved value of the status tag. Flush the status block (i.e., flush status blocks cached by intermediate PCI bridges).
- 8. Check the update bit in the status word of the status block. If the update bit is asserted, then new data has been DMAed to the host.
  - a. Repeat steps 5 and 6.
- 9. Check error bit in status word. The driver may check the state machine/FTQ status registers for various attentions.
- 10. Reenable interrupts. When the "status tagged" status mode bit of the miscellaneous host control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245) is set to 1, write the saved status tag to the upper 8 bits of Interrupt Mailbox 0, and 0 to the remaining bits (23 down to 0) to indicate that the ISR is finished processing Rx and Tx. Otherwise, write 0 to Interrupt Mailbox 0 register. This step also clears existing interrupts.

## 11.1.1.1 Legacy Status TAGGING Mode

This mode is enabled by setting the "status tagged" mode bit of the miscellaneous host control register (0x68). When enabled, a unique 8-bit tag value is inserted into the status block status tag at location [7:0]. The status tag can be returned to the [31:24] field of the INT mailbox register by the driver. When the mailbox register field [23:0] is written with a zero value, the tag field of the mailbox register is compared with the tag field of the last status block to be DMAed to the host. If the tag returned is not equivalent to the tag of the first status block DMAed, then the controller triggers another interrupt immediately.

# 11.2 Basic Driver Interrupt Processing Flow

# 11.2.1 Flowchart for Servicing an Interrupt

The following figure shows the basic driver interrupt service routine flow.

Figure 49: Basic Driver Interrupt Service Routine Flow



## 11.2.2 Interrupt Procedure

- 1. Acknowledge interrupt. Write a nonzero value (i.e., value = 1) to the interrupt mailbox 0 (see registers 0x270–0x304) to indicate that the driver is currently processing the interrupt. This step disables device interrupts except during interrupt feature.
- 2. Read and save the value of the Status Tag field of the Status Block (see "Status Block" on page 60).
- 3. Claim interrupt. Determine if the Ethernet controller action is required. Read the Updated bit of the status word. If the Updated bit is asserted, then the host coalescing engine has updated the status block.
- 4. Clear the Updated bit of the status word. This indicates that the host driver either has or will touch the status block. If a during interrupt event is driven, the host driver can examine the Updated bit to determine if a fresh status block has been moved to host memory space.
- 5. Check for RX traffic.
  - Loop through enabled RX Return Rings (0 to 3).
  - Check for difference between RX Return Ring Producer index (Status block) and RX Return Ring Consumer index (value written to mailbox on previous call) is the number of frames to process for RX Return Ring.
  - · Process the packet.
  - Update the RX Return Ring consumer pointer in each mailbox for new RX frames.
- 6. Check for TX completes.
  - · Loop through enabled TX Send Rings.
  - Check for difference between previous consumer index (software kept) and current consumer index in the status block. These are the TX BDs that can be made available for the next send operation.
  - · Update the previous consumer index (i.e., next call) to the value of the status block consumer index.
- 7. Compare the current value of the Status Tag to the saved value of the Status Tag. Flush status block (i.e., force update of status blocks cached by PCI bridge).
  - Read interrupt mailbox (see "Interrupt Mailbox 0 (High Priority Mailbox) Register (offset: 0x200-207) for host standard and "Interrupt Mailbox 0 Register (offset: 0x5800)" for indirect mode).
  - Check the Updated bit in the status word located in the status block. If the Updated bit is asserted, then new data has been DMAed to the host. Repeat steps 5 and 6.
- 8. Check the Error bit in status word (optional). The driver may check the state machine/FTQ status registers for various attentions.
- 9. Enable interrupts. When Status Tagged Status mode bit of the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245) is set to 1, then write the saved Status Tag to the upper 8 bits of Interrupt Mailbox 0, and 0 to the remaining bits (23 down to 0) to indicate that the ISR is done processing RX/TX. Otherwise, write 0 to Interrupt Mailbox 0 register. This step also clears existing interrupts.

# 11.3 Host Coalescing

Interrupt coalescing (or interrupt moderation) is a common technique used by NIC vendors to increase the performance of NICs. High-level descriptions of the benefits of interrupt coalescing can be found at:

- http://www.microsoft.com/<u>HWDEV</u>/devdes/optinic.htm
- http://support.microsoft.com/support/kb/articles/Q170/6/43.ASP
- http://msdn.microsoft.com/library/books/serverdg/networkadapterrequirements.htm

## 11.3.1 Description

The Ethernet controller supports the concept of host coalescing. Host coalescing controls when status information is returned to the host, and when interrupts are generated. The Ethernet controller provides a number of software configurable registers that control when/how it updates the host with status information and how often it asserts an interrupt.

When the Ethernet controller has completed transmit or receive events, it updates a Status block in host memory. This status block contains information that tells the host which transmit buffers have been DMAed by the NIC, and which receive Buffer Descriptors (BDs) have been consumed by a newly arrived received packet. Normally, the host will check this status block when an interrupt is generated. In addition, the host could also poll the status block to determine whether or not it had been updated by the hardware since the last time the host had read the status block (this is called during interrupt processing).

When the NIC updates the status block, it will decide whether to assert the interrupt line (INTA) or not. The Ethernet controller has special interrupt avoidance mechanisms that allow the host to tell the NIC not to generate an interrupt when it writes a status block back to the host. In addition, some mechanisms allow the host software to control when and how often the status block is updated.

**Example:** The host could configure the NIC to only update status block after it receives two packets, as opposed to one packet. These mechanisms are documented in more detail to follow.

# 11.3.2 Operational Characteristics

The Ethernet controller DMAs the status block to host memory before a line interrupt or MSI is generated. The host ISR reads the update bit at the top of the status block and checks whether this bit is set to 1 or not. When set to 1, the updated bit of status block indicates to the host that the status block has been refreshed by the MAC. The ISR must then write to clear/deassert this bit to dirty the status block, and then the ISR may proceed to read the updated producer/consumer index pointers. This mechanism allows host system software to determine if the status block has been updated. Due to various asynchronous timing issues (dependent upon platform) the ISR may occasionally see stale data. The ISR may either spin and wait for the status block DMA to complete and explicitly flush the status block or just wait for the next line interrupt.

# 11.3.3 Registers

The Ethernet controller supports a variety of registers that affect status block updates and interrupt generation (see Table 89).

Table 89: Interrupt-Related Registers

| Register                                                                                                                   | Cross Reference                                                         |
|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Miscellaneous Host Control register.  The two bits of this register that are related to interrupts are:                    | "Miscellaneous Host Control Register (offset: 0x68)" on page 245.       |
| Mask PCI Interrupt Output (aka Mask Interrupt) bit     Clear Interrupt INTA bit                                            |                                                                         |
| Miscellaneous Local Control register.                                                                                      | "Miscellaneous Local Control Register (offset: 0x6808)" on              |
| The two bits of this register that are related to interrupts are:                                                          | page 418.                                                               |
| Set Interrupt bit                                                                                                          |                                                                         |
| Clear Interrupt bit                                                                                                        |                                                                         |
| Interrupt Mailbox 0 register                                                                                               | "Interrupt Mailbox 0 Register (offset: 0x5800)" on page 409             |
| Receive Coalescing Ticks register                                                                                          | ."Receive Coalescing Ticks Register (offset: 0x3C08)" on page 368       |
| Send Coalescing Ticks register                                                                                             | ."Send Coalescing Ticks Register (offset: 0x3C0C)" on page 369          |
| Receive Max Coalesced BD Count register                                                                                    | ."Receive Max Coalesced BD Count Register (offset: 0x3C10)" on page 370 |
| Send Max Coalesced BD Count register                                                                                       | "Send Max Coalesced BD Count Register (offset: 0x3C14)" on page 372.    |
| Mode Control register.                                                                                                     | "Mode Control Register (offset: 0x6800)" on page 416                    |
| <ul> <li>Interrupt on Flow Attention (Bit 28) causes a host interrupt when<br/>an enabled flow attention occurs</li> </ul> |                                                                         |
| <ul> <li>Interrupt on DMA Attention (Bit 27) causes a host interrupt when<br/>an enabled DMA attention occurs</li> </ul>   |                                                                         |
| ■ Interrupt on MAC Attention (Bit 26) causes a host interrupt when an enabled MAC attention occurs                         |                                                                         |
| ■ Interrupt on RX RISC Attention (Bit 25) causes a host interrupt when an enabled RX-RISC attention occurs                 |                                                                         |

## 11.4 MSI

PCI Specification 2.2 defines a new mechanism for a device to request services from its device driver. It is called Message Signaled Interrupt (MSI). MSI will eventually deprecate the traditional interrupt mechanism. In MSI, device DMAs a specified DWORD data to a specified host address if it needs to request services by its device driver. The MSI state machine can be enabled/disabled by setting/resetting the Enable bit of MSI Mode register (offset 0x6000). By default, this bit is set to 1 indicating that the MSI state machine is enabled. The main advantages of MSI generation versus using a traditional interrupt are as follows:

- Eliminates the need for interrupt signal trace on the PCI device.
- Eliminates the need to perform a dummy read from the device by the device driver in its interrupt service routine. The dummy read is done at the beginning of ISR to force all posted memory writes to be flushed to the host memory.

## 11.4.1 Traditional Interrupt Scheme

A simplified block diagram showing a traditional interrupt scheme is depicted in Figure 50.

Figure 50: Traditional Interrupt Scheme



To clarify second issue in traditional interrupt scheme, an example is given. The Ethernet controller receives one or more packets from the networks. The Ethernet controller does the following:

- DMAs data of received packets to the host.
- DMAs receive buffer descriptors to Receive Return Ring in the host memory.
- DMAs status block to the host memory.

Generates an interrupt to request its device driver for processing.

The writes are posted and are actually performed at some later time by the PCI host bridge. When interrupt service routine of device driver is executed, the driver reads the status block from the host memory and finds that status block does not contain latest index information if the writes for status block are not performed by the PCI host bridge yet. The scheme to resolve this problem is to do a dummy read of the Ethernet controller in the beginning of the interrupt service routine. The dummy read has to traverse the same bridge that memory writes from the Ethernet controller have to traverse to get to the host memory. The ordering rules for bridges dictate that the bridge must flush its posted write buffers before permitting a read to traverse the bridge. As a result, writes for status block are flushed to the host memory by the bridge before dummy read cycle is completed.

# 11.4.2 Message Signaled Interrupt

A simplified block diagram showing a possible MSI scheme is depicted in Figure 51.

Figure 51: Message-Signaled Interrupt Scheme



Similar example in traditional interrupt scheme is used again here to illustrate MSI concept. The Ethernet controller receives one or more packets from the networks. The Ethernet controller does the following:

- DMAs data of received packets to the host.
- DMAs receive buffer descriptors to receive return ring in the host memory.
- DMAs status block to the host memory.
- Writes specified DWORD data to specified host address.

In this mode, the Ethernet controller writes DWORD data to specified host address instead of generating an interrupt. The specified data and address are configurable. The specified address is typically a memory-mapped IO port within the PCI host bridge. The PCI host bridge is the gateway to the main memory controller. This means that the DWORD data write (MSI message) to PCI host bridge is in the posted write buffers and was posted after the writes for the status block update. It is the rule that PCI host bridge must perform posted writes in the same order that they were received. This means that by the time MSI message arrives at the PCI host bridge, the status block has already been posted to the host memory. Upon receipt of the MSI message write, the PCI host bridge generates the interrupt request to the processor. Interrupt service routine of the device driver is invoked. It is not necessary to do a dummy read because updated status block is already in the host memory.

## 11.4.3 PCI Configuration Registers

Operating system/system software can configure the specified DWORD data and specified 64-bit host address for the device with MSI\_DATA (Offset 0x64) and MSI\_Address register (Offset 0x5c), respectively.

#### 11.4.3.1 MSI Address

This is a 64-bit field. MSI address at offset 0x5c and 0x60 should be programmed with the low-order and high-order bits of the 64-bit physical address. If the host only supports 32-bit physical address, the high-order address should be programmed with zeros.

### 11.4.3.2 MSI Data

This is a 16-bit field. The least significant three bits can be modified by the Ethernet controller when it writes MSI message to host. The DWORD data for the MSI message is depicted as shown in Figure 52.

Figure 52: MSI Data Fleld



The Ethernet controller can support up to eight message types, and these MSI messages can be generated by either of the two sources:

- Host coalescing engine
- Firmware

## 11.4.4 Host Coalescing Engine

After the host coalescing engine updates the status block on the host (due to receive indication, transmit completion, and so on), it either generates an interrupt or writes a MSI message if MSI is enabled. The least significant 3-bits of the MSI message originating from host coalescing block is configurable and can be configured by programming bits 4, 5, and 6 of the Host Coalesing Mode register. The default of these bits is zeros.

### 11.4.5 Firmware

The Ethernet controller provides a way for firmware executed by RX RISC to generate MSI messages. Firmware can generate MSI messages by using MSI\_FIFO\_Access register (Offset 0x6008). For example, if firmware wants to generate an MSI message with least significant 3-bit as 0x2, it will write 2 to MSI\_FIFO\_Access register. It also needs to verify that the MSI message is written successfully by reading back MSI\_FIFO\_Access Overflow. If this bit is zero, then the MSI message is encoded successfully and will be sent to HOST. Otherwise, the message is not encoded.

**NOTE:** Without any special firmware supporting multiple MSIs, the device can generate only 1 MSI message even though the device requests for 8 MSI messages through Multiple Message Capable field (bits 3:1) of Message Control register (offset 0x5A). The least significant 3-bits of the MSI message generated by the device are always taken from bits 6:4 of Host\_Coalesing\_Mode register (offset 0x3C00).

## 11.5 MSI-X

The BCM571X/BCM5720 family introduces PCIe<sup>™</sup>-compliant message signal interrupts (MSI-X), supporting a maximum of 17 vectors (BCM5718).

This is accomplished without disturbing the legacy interrupt system model. The introduction of interrupt vectoring provides per-receive-queue indication and per-transmit-queue completion to the device driver. The maximum number of MSI-X vectors attainable is indirectly determined by certain controller modes of operation.

The existence of multiple receive queues (Rx return rings) in the BCM571X/BCM5720 family stems either from the Receive Side Scaling (RSS) feature or from the I/O Virtualization (IOV) feature.

**NOTE:** RSS and IOV are mutually exclusive—only one of these features may be enabled in the BCM571X/BCM5720 family at any time.

When both RSS and IOV are disabled, all of the received packets are posted in the default receive queue (Rx Return Ring 0). This default Rx return ring is sometimes referred to as "the Receive Return Ring". The number of transmit queues is also limited to one in this use case.

In RSS enabled mode, receive traffic classification (also known as sorting) is done purely based on the RSS hash lookup table. Four RSS receive queues and a single transmit queue exist in this mode for the controller. Therefore, up to 5 MSI-X vectors are offered in RSS mode.

In IOV mode, receive traffic classification is performed by VRQ filters. Sorted Rx traffic is routed among 17 Virtual Receive queues (VRQs). The transmit side offers up to 16 transmit queues. Therefore, while in IOV mode, there is an opportunity to map packet indication and completions into 17 MSI-X vectors.

The MSI-X specification allows a device to advertise the availability of a chosen number of vectors in its PCIe capabilities list; however, it does not specify a mechanism for an operating system (OS) to negotiate the number of vectors down to the number it would actually want to use. So, one simple way for an OS to allocate fewer vectors than a device has asked for is to fill out all of the vector table entries advertised by a device. In such an event, the device would first need to identify the situation, and then reassign or regroup the internal interrupt sources into the limited number of table entries allocated by the OS. But, the device hardware would not possess all of the information necessary to accomplish either task. This means that device driver involvement is required. In the BCM571X/BCM5720 family, it has been assumed that, in most cases, an OS would allocate the requested number of vectors. A deviation from that would be considered an exception; in that case, because support for MSI-X has already been advertised to the BIOS, there would be no way to fall back to INTx mode. This situation could be handled by forcing everything into MSI-X Vector#0 and not using other vectors, disregarding however many of the originally requested vectors the OS actually allocated.

Thus, the BCM571X/BCM5720 family offers two vector modes within the MSI-X mode:

- Single Vector mode
- Multivector mode

Each of these two modes in turn offers the following submodes:

- Single Vector mode (Restrict to Vector#0)
  - Single Vector RSS mode
  - Single Vector IOV mode
- Multivector mode
  - Multivector RSS mode (5 Vectors Requested)
  - Multivector IOV mode (17 Vectors Requested)

The idea is that during boot up, if either RSS or IOV mode is to be enabled, the driver would program the controller into the appropriate Multivector submode first. Subsequently, if the OS does not allocate the requested number of MSI-X vectors (five for RSS and 17 for IOV), then the driver must reprogram the controller into the appropriate Single Vector submode. All of this must be performed before the driver enables the EMAC to receive or transmit traffic. Once traffic is started, the MSI-X Vector mode must not be reprogrammed. The controller will behave unpredictably if that is done.

Single Vector mode or Multivector mode may be chosen by the driver by programming register bit 0x6000[7]. Such submodes are derived by the controller from the appropriate RSS, IOV and Multiple Send queue mode settings. All permissible combinations are shown in the table below.

**NOTE:** IOV mode enables 16 VRQs but does not necessarily enable multiple Tx queues, which may be enabled independent of IOV-mode selection. Hence the send completion, when Single Send queue is chosen, will always be indicated on Vector#0 while Multiqueue Send Completions will be paired with Rx queue indications in the respective vectors.

Table 90: MSI-X Vector Mode Selection

| MSI-X Vector Mode |              | Multivector Enable 0x6000[7] | RSS Mode Enable 0x468[23] | IOV Mode Enable 0x6800[8] | Multi TXQ Enable 0x1800[5] |
|-------------------|--------------|------------------------------|---------------------------|---------------------------|----------------------------|
| Single Vector—    | Single TXQ   | 0x0                          | 0x1                       | 0x0                       | 0x0                        |
| RSS Mode          | Multiple TXQ | 0x0                          | 0x1                       | 0x0                       | 0x1                        |
| Single Vector—    | Single TXQ   | 0x0                          | 0x0                       | 0x1                       | 0x0                        |
| IOV Mode          | Multiple TXQ | 0x0                          | 0x0                       | 0x1                       | 0x1                        |
| Multivector—RSS   | Single TXQ   | 0x1                          | 0x1                       | 0x0                       | 0x0                        |
| Mode              | Multiple TXQ | 0x1                          | 0x1                       | 0x0                       | 0x1                        |
| Multivector—IOV   | Single TXQ   | 0x1                          | 0x0                       | 0x1                       | 0x0                        |
| Mode              | Multiple TXQ | 0x1                          | 0x0                       | 0x1                       | 0x1                        |

Vector allocation in each mode is shown below:

#### Single Vector Mode:

- RSS mode: Vector#0–Aggregate of the following:
- Rx Return Ring Indication (Active only when RSS is Disabled)
- Send Completion
- Link Status Change
- Error/Attention
- Rx Return Ring3 through Ring0 Indications
- IOV mode: Vector#0—Aggregate of the following:
  - All 16 Send queue Completions
  - All 17 VRQ Indications
  - VRQ Active Bit-Map
  - Link Status Change
  - Error/Attention

#### **Multivector Mode:**

- RSS (5 Vector) mode: Vector allocation would be as follows:
  - Vector#0–Aggregate of the following:
    - Send Completion (Only in Single TXQ mode)
    - Link Status Change

- Error/Attention
- Vector#1–RSS Return Ring 0 Indication/TXQ 1 Completion (in Multi TXQ mode)
- Vector#2–RSS Return Ring 1 Indication/TXQ 2 Completion (in Multi TXQ mode)
- Vector#3–RSS Return Ring 2 Indication/TXQ 3 Completion (in Multi TXQ mode)
- Vector#4–RSS Return Ring 3 Indication/TXQ 4 Completion (in Multi TXQ mode)
- IOV (17 Vector) mode: Vector allocation would be as follows
  - Vector#0—Aggregate of the following:
    - VRQ0 Indication (Default VRQ)
    - Send Completion (Only in Single TXQ mode)
    - Link Status Change
    - Error/Attention
    - VRQ Active Bit-Map
  - Vector#1—Aggregate of the following:
    - VRQ1 Indication
    - Transmit queue 1 Completion (in Multi TXQ mode)
    - Link Status Change
  - Vector#2–Aggregate of the following
    - VRQ2 Indication
    - Transmit queue 2 Completion (in Multi TXQ mode)
    - Link Status Change

.

- Vector#16–Aggregate of the following
  - VRQ16 Indication
  - Transmit queue 16 Completion (in Multi TXQ mode)
  - Link Status Change

In the case of Multivector selection, it is not mandatory to enable all four RSS queues or enable all VRQs/send queues. So, in the case of Multivector, RSS vector#1 through vector#4 are useful only in conjunction with the respective number of RSS queues or CPU# enable. For example, if only three receive queues are receiving traffic, and the Multivector mode is selected by the driver, then even though vectors 0, 1, 2, and 3 remain active, vector#4 never triggers. Hence, in Multivector RSS mode the receive queues are hard-mapped 1:1 with MSI-X vectors 1 through 4. Therefore it is not permissible to regroup receive queues into vectors in an arbitrary manner. This policy also applies to Multivector IOV mode.

Consequently, Multivector mode must only be selected in conjunction with the enabling of either RSS or IOV.

**NOTE:** There is no known use case for enabling Multiple Tx queues (TSS) without enabling either RSS or IOV. Therefore, doing so is not permitted.

In Single Vector mode, all receive traffic is indicated via Vector#0. In RSS mode, all four receive queue indications, and all four Send Completions are thus grouped together in Vector#0. While in IOV mode, all 17 Rx queues and all 16 Tx queues are grouped into Vector#0. Also, this mode must be used when RSS and IOV are both disabled (but MSI-X is enabled, although it is not anticipated that doing this has any real-world usefulness). There could be instances when the OS enables RSS but allocates only one MSI-X vector to our device. The Broadcom driver would resort to choosing Single Vector mode in such a scenario.

**NOTE:** When MSI-X is disabled, INTx or MSI continue to function as in legacy device implementations. The data structures used in INTx and MSI mode are identical to those in Single Vector MSI-X mode.

The BCM571X/BCM5720 family offers two product SKUs. The MSI-X table size requested by each differs:

- BCM5717: This controller advertises MSI-X table size = 5.
- BCM5718: This controller advertises an MSI-X table size = 17 by default; however, an NVRAM Configuration option is provided to limit the Table Size to 5 if desired.

# 11.6 MSI-X Plumbing

The basic interrupt/ISR model for NetXtreme controllers remains largely unchanged even with the introduction of vectored interrupts in the form of MSI-X. However, there are four basic design changes:

- Replication of status blocks, mailboxes, etc. This essentially scales the legacy model from one vector to five or 17 vectors.
- Implement MSI-X capability structures in PCIe configuration space.
- Implement PCI-mandated MSI-X data structures within each MAC core, including new base address register (BAR) decoder, MSI-X table, pending bit array (PBA) structure, etc.
- Add per Rx queue host coalescing attributes.

Each item is discussed in detail in the following sections.

# 11.6.1 Replication of Status Blocks and INT Mailboxes

As shown in Table 91, all four Rx Return Consumer Indices are indicated in the legacy Status Block. When MSI-X Multivector RSS mode is enabled, it leads to logically five interrupt vectors. Each of these vectors is bound to its own status block; thus, there are five different status blocks, numbered *Status-Block0* through *Status-Block4*. Each of these five vectors is also bound to its own INT Mail-Box registers.

Each Status Block has a fixed location in the Host Memory. Hence, there are five Status Block Host Address Registers (64-bit). Table 91 shows all five Status-Block Host Address Registers and INT Mail-Box Registers.

Similarly, in the case of MSI-X Multivector IOV mode, there are 17 sets of Status Blocks and MailBox registers.

Table 91: MIS-X Status-Block and Mail Box Addresses

|                           |                                                      |           | IOV Mode            |                                        | RSS Mode                    |                                                                                                              |
|---------------------------|------------------------------------------------------|-----------|---------------------|----------------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------|
| Status<br>Block<br>Number | Status Block<br>Host Address<br>Register<br>(64-bit) |           | Indication Items    | INT Mail<br>Box<br>Register<br>Address | Indication Items            | Comments                                                                                                     |
| Legacy                    | 0x3C3C,<br>0x3C38                                    | 0x200 (*) | ALL                 | 0x200(*)                               | ALL                         | Legacy Status Block.<br>Used by INTx or MSI. Also<br>used in MSI-X Single-<br>Vector RSS mode or IOV<br>mode |
| 0                         | 0x3C3C,                                              | 0x200     | VRQ 0 RR Prod Index | 0x200 (*)                              | Link-Status change          | Used only in MSI-X                                                                                           |
|                           | 0x3C38                                               |           | Error/Attention     |                                        | Error/Attention             | Multivector RSS mode                                                                                         |
|                           |                                                      |           | Single SBD Cons     |                                        | Single SBD Cons Index       | or                                                                                                           |
|                           |                                                      |           | Index               |                                        | StdRBD Cons Indx            | Multivector IOV mode                                                                                         |
|                           |                                                      |           | Link Status         |                                        | JmbRBD Cons Indx            | for                                                                                                          |
|                           |                                                      |           | RBD 0 Cons Indexes  |                                        |                             | Vector#0 Vector#2.                                                                                           |
|                           |                                                      |           | VRQ Active Bit-Map  |                                        |                             |                                                                                                              |
| 1                         | 0x3D00,                                              | 0x208     | VRQ1 RR Prod Index  | 0x208 (*)                              | Rx Return Ring 0 Prod Index |                                                                                                              |
|                           | 0x3D04                                               |           | SBD1 Cons Index     |                                        | SBD1 Cons Index             |                                                                                                              |
|                           |                                                      |           | RBD 1 Cons Index    |                                        |                             |                                                                                                              |
| 2                         | 0x3D08,                                              | 0x210     | VRQ2 RR Prod Index  | 0x210 (*)                              | Rx Return Ring 1 Prod Index |                                                                                                              |
|                           | 0x3D0C                                               |           | SBD2 Cons Index     |                                        | SBD2 Cons Index             |                                                                                                              |
|                           |                                                      |           | RBD 2 Cons Index    |                                        |                             |                                                                                                              |

Table 91: MIS-X Status-Block and Mail Box Addresses (Cont.)

|                           |                                                      |                                        | IOV Mode                                                        |                                        | RSS Mode                                       |                                                                  |
|---------------------------|------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------|----------------------------------------|------------------------------------------------|------------------------------------------------------------------|
| Status<br>Block<br>Number | Status Block<br>Host Address<br>Register<br>(64-bit) | INT Mail<br>Box<br>Register<br>Address | Indication Items                                                | INT Mail<br>Box<br>Register<br>Address | Indication Items                               | Comments                                                         |
| 3                         | 0x3D10,<br>0x3D14                                    | 0x218                                  | VRQ3 RR Prod Index<br>SBD3 Cons Index<br>RBD 3 Cons Index       | 0x218 (*)                              | Rx Return Ring 2 Prod Index<br>SBD3 Cons Index | Used only in MSI-X<br>Multivector RSS<br>mode or Multivector IOV |
| 4                         | 0x3D18,<br>0x3D1C                                    | 0x220                                  | VRQ4 RR Prod Index<br>SBD4 Cons Index<br>'RBD 4 Cons Index      | 0x220 (*)                              | Rx Return Ring 3 Prod Index<br>SBD4 Cons Index | mode<br>for<br>Vector#3 Vector#4.                                |
| 5                         | 0x3D20,<br>0x3D24                                    | 0x228                                  | VRQ5 RR Prod Index<br>SBD5 Cons Index<br>RBD 5 Cons Index       | N/A                                    | N/A                                            | Used in MSI-X<br>Multivector IOV mode<br>for                     |
| 6                         | 0x3D28,<br>0x3D2C                                    | 0x22C                                  | VRQ6 RR Prod Index<br>SBD6 Cons Index<br>RBD 6 Cons Index       | N/A                                    | N/A                                            | Vector#5 Vector#16                                               |
| 7                         | 0x3D30,<br>0x3D34                                    | 0x230                                  | VRQ7 RR Prod Index<br>SBD7 Cons Index<br>RBD 7 Cons Indexes     | N/A                                    | N/A                                            |                                                                  |
|                           |                                                      |                                        |                                                                 | N/A                                    | N/A                                            | -                                                                |
| 16                        | 0x3D78,<br>0x3D7C                                    | 0x254                                  | VRQ16 RR Prod<br>Index<br>SBD16 Cons Index<br>RBD 16 Cons Index | N/A                                    | N/A                                            | -                                                                |

Each replicated Status Block has its own format; however, each of the new status block formats is extrapolated from the legacy status block format.

**NOTE:** Although High Priority INT Mail Boxes are DWORD (32-bit) registers, the original four were placed on QWORD (64-bit) boundaries for legacy PCI 64-bit target access purposes. Broadcom's PCIe does not allow 64-bit target accesses. Thus, the new Mailboxes are being placed 32-bits apart; however, we are keeping the original four addresses intact.

### 11.6.1.1 Single-Vector RSS Mode Status Block Format

Table 92 on page 213 shows the Status-Block format used by Vector#0 in the Single-Vector RSS mode. Note that first 24B of this structure is identical to the legacy Status Block.

Table 92: Status Block Format (MSI-X Single-Vector RSS Mode)

| Offset | 3116                                                                               | 150                                  |                 |
|--------|------------------------------------------------------------------------------------|--------------------------------------|-----------------|
| 0x00   | Status Word                                                                        |                                      |                 |
| 0x04   | [31:8] Reserved 0x0                                                                |                                      | [7:0]Status Tag |
| 0x08   | Receive Standard Producer Ring Consumer Index Receive Return Ring 1 Producer Index |                                      | cer Index       |
| 0x0C   | Receive Return Ring 2 Producer Index                                               | Receive Return Ring 3 Producer Index |                 |

Table 92: Status Block Format (MSI-X Single-Vector RSS Mode) (Cont.)

| Offset | 3116                                      | 150                                        |  |
|--------|-------------------------------------------|--------------------------------------------|--|
| 0x10   | Send BD [1] Consumer Index                | Receive Jumbo Producer Ring Consumer Index |  |
|        | (Acts as Single Send queue Cons Index)    |                                            |  |
| 0x14   | Send BD 2 Consumer Index (IF Multi SendQ) | Receive Return Ring 0 Producer Index       |  |
| 0x18   | Send BD 3 Consumer Index (IF Multi SendQ) | Send BD 4 Consumer Index (IF Multi SendQ)  |  |

Status-Block [0] Status Word Format (Single-Vector RSS):

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bit [2]: Error/Attention
- Bits [31:4]: Reserved 0x0

## 11.6.1.2 Single-Vector IOV Mode Status Block Format

In Single-Vector IOV mode, all events are reported in the same Status Block used by Vector#0.

Table 93: Status Block format (MSI-X Single-Vector IOV Mode)

| Offset | 3116                                                          | 150                             |                 |  |
|--------|---------------------------------------------------------------|---------------------------------|-----------------|--|
| 0x00   | Status Word                                                   |                                 |                 |  |
| 0x04   | [31:8] Reserved 0x0                                           |                                 | [7:0]Status Tag |  |
| 0x08   | Single Send BD Consumer Index (IF Single Send queue ELSE 0x0) | Receive Return Ring 0 Produ     | cer Index       |  |
| 0x0C   | Send BD 1 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 1 Produ     | cer Index       |  |
| 0x10   | Send BD 2 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 2 Produ     | cer Index       |  |
| 0x14   | Send BD 3 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 3 Produ     | cer Index       |  |
| 0x18   | Send BD 4 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 4 Produ     | cer Index       |  |
| 0x1C   | Send BD 5 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 5 Produ     | cer Index       |  |
| 0x20   | Send BD 6 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 6 Produ     | cer Index       |  |
| 0x24   | Send BD 7 Consumer Index (IF Multi SendQ)                     | Receive Return Ring 7 Produ     | cer Index       |  |
|        |                                                               |                                 |                 |  |
| 0x48   | Send BD 16 Consumer Index (IF Multi SendQ)                    | Receive Return Ring 16 Prod     | ucer Index      |  |
| 0x4C   | Standard RBD Ring 0 Consumer Index                            | Jumbo RBD Ring 0 Consume        | r Index         |  |
| 0x50   | Standard RBD Ring 1 Consumer Index                            | Jumbo RBD Ring 1 Consume        | r Index         |  |
| 0x54   | Standard RBD Ring 2 Consumer Index                            | Jumbo RBD Ring 2 Consumer Index |                 |  |
| 0x58   | Standard RBD Ring 3 Consumer Index                            | Jumbo RBD Ring 3 Consumer Index |                 |  |
|        |                                                               |                                 |                 |  |
| 0x8C   | Standard RBD Ring 16 Consumer Index                           | Jumbo RBD Ring 16 Consum        | er Index        |  |

Status-Block Status Word Format (Single-Vector IOV):

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bit [2]: Error/Attention
- Bits[5:3]: Resvd–always 0x0
- Bit [6]: Change in VRQ Active Bit Map

- Bits [14:7]: Resvd–always 0x0
- Bit[15]: VRQ Active Bit-Map[16]
- Bits [31:16]: VRQ Active Bit-Map[15:0]

### 11.6.1.3 Multivector RSS Mode Status Block Format

There are five slightly different Status-Block formats used by the Multivector RSS mode—each of these formats associate with their respective vector numbers as shown in Table 94.

Table 94: Status Block [0] Format (MSI-X Multivector RSS Mode]

| offset | 3116                                                          | 150                                        |  |
|--------|---------------------------------------------------------------|--------------------------------------------|--|
| 0x00   | Status Word                                                   |                                            |  |
| 0x04   | [31:8] Reserved 0x0                                           | [7:0] Status Tag                           |  |
| 0x08   | Receive Standard Producer Ring Consumer Index                 | Reserved 0x0                               |  |
| 0x0C   | Reserved 0x0                                                  | Reserved 0x0                               |  |
| 0x10   | Single Send BD Consumer Index (IF Single Send queue ELSE 0x0) | Reserved 0x0                               |  |
| 0x14   | Reserved 0x0                                                  | Receive Jumbo Producer Ring Consumer Index |  |

Status-Block [0] Status Word Format (Multivector RSS):

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bit [2]: Error/Attention
- Bit [3]: Resvd–always 0
- Bit [4]: Resvd–always 0
- Bit [5]: Resvd–always 0
- Bits [31:6]: Reserved 0x0

Table 95: Status Block [1 N ≤ 4] Formats (MSI-X Multivector RSS Mode)

| offset | 3116                                                                                 | 150                                                                               |                                                                |  |
|--------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------|--|
| 0x00   | Status Word {Valid for all Status Blocks}                                            |                                                                                   |                                                                |  |
| 0x04   | [31:8] Reserved 0x0                                                                  |                                                                                   | [7:0] Status Tag[n]<br>{Independent for each Status<br>Blocks} |  |
| 0x08   | Reserved 0x0                                                                         | Receive Return Ring 1 Producer Index (Valid only for Status Block2 else Rsvd 0x0) |                                                                |  |
| 0x0C   | Receive Return Ring 2 Producer Index (Valid only for Status Block3 else Rsvd 0x0)    | Receive Return Ring 3 Producer Index (Valid only for Status Block4 else Rsvd 0x0) |                                                                |  |
| 0x10   | Send BD [1 $\leq$ N $\leq$ 4] Consumer Index (IF Multi Send queue Enabled, ELSE 0x0) | Receive Return Ring 0 Producer Index (Valid only for Status Block1 else Rsvd 0x0) |                                                                |  |
| 0x14   | Reserved 0x0                                                                         | Reserved 0x0                                                                      |                                                                |  |

Status-Block [1-4] Status Word Format (Multivector RSS):

- Bit [0]: Update-Bit
- Bit [31:1]: Reserved 0x0

### 11.6.1.4 Multivector IOV Mode Status Block Format

Two slightly varying Status Block formats are used in this mode: one format for Status Block#0 and the other for Status Block#1 through Status Block#16, as shown in Table 96.

Table 96: Status Block [0] Format (MSI-X Multivector IOV Mode)

| offset | 3116                                                          | 150                                     |  |
|--------|---------------------------------------------------------------|-----------------------------------------|--|
| 0x00   | Status Word                                                   |                                         |  |
| 0x04   | [31:8] Reserved 0x0                                           | [7:0] Status Tag                        |  |
| 80x0   | RBD0 Standard Producer Ring Consumer Index                    | Reserved 0x0                            |  |
| 0x0C   | Reserved 0x0                                                  | Reserved 0x0                            |  |
| 0x10   | Single Send BD Consumer Index (IF Single Send queue ELSE 0x0) | Receive Return Ring 0 Producer Index    |  |
| 0x14   | Reserved 0x0                                                  | RBD0 Jumbo Producer Ring Consumer Index |  |

Status-Block [0] Status Word Format (Multivector IOV):

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bit [2]: Error/Attention
- Bits[5:3]: Resvd–always 0x0
- Bit [6]: Change in VRQ Active Bit Map
- Bits [14:7]: Resvd–always 0x0
- Bit[15]: VRQ Active Bit-Map[16]
- Bits [31:16]: VRQ Active Bit-Map[15:0]

Table 97: Status Block [ $1 \ge N \le 16$ ] Format (MSI-X Multivector IOV Mode)

| offset | 3116                                                         | 150                                        |                  |
|--------|--------------------------------------------------------------|--------------------------------------------|------------------|
| 0x00   | Status Word                                                  |                                            |                  |
| 0x04   | [31:8] Reserved 0x0                                          |                                            | [7:0] Status Tag |
| 80x0   | RBD[N] Standard Producer Ring Consumer Index                 | Reserved 0x0                               |                  |
| 0x0C   | Reserved 0x0                                                 | Reserved 0x0                               |                  |
| 0x10   | Send BD [N] Consumer Index (IF Multiple Send queue ELSE 0x0) | Receive Return Ring [N] Producer Index     |                  |
| 0x14   | Reserved 0x0                                                 | RBD [N] Jumbo Producer Ring Consumer Index |                  |

Status-Block [1–16] Status Word Format (Multivector IOV):

- Bit [0]: Update-Bit
- Bit [1]: Link Status Change
- Bits [31:1]: Resvd–always 0x0

# 11.6.2 MSI-X Capability Structure

MSI-X requires that its device-resident data structures or registers be addresses over BARs, as opposed to MSI, which declares its device structure addresses directly in related configuration registers. There are certain restrictions related to the BARs:

- If a BAR is shared with MSI-X for other device purposes, the MSI-X region must be isolated within a 4 KB naturally aligned region. Or, the MSI-X structures may be placed in their own captive BARs.
- MSI-X has been placed in its own set of BARs: BAR4 and BAR5 (64-bit).
- Each PCIe Function of the BCM571X/BCM5720 family, that is Function0 and Function1, advertises availability of their BAR4 and BAR5 as MSI-X BARs. This is done via the MSI-X Capability structure.

The MSI-X Capability structure is implemented inside the EP-RC core. It points to two structures that must be implemented inside a device: the MSI-X Table and a Pending Bit Array (PBA). There is also a Message Control Register. The Capability structure is shown in Table 98.

Table 98: MSI-X Capability Structure

| 3116                | 158          | 73            | 20 |  |  |  |
|---------------------|--------------|---------------|----|--|--|--|
| Message Control Reg | Next Pointer | Capability ID | _  |  |  |  |
| MSI-X Table Offset  |              |               |    |  |  |  |
| PBA Offset          |              |               |    |  |  |  |

The BIR bits point to the BAR registers that a device function uses to base the respective data structures. In the BCM571X/BCM5720 family, both BIRs have a hard-wired value of 0x4, which implies BAR4 and BAR5.

**NOTE:** BAR4 and BAR5 must support 8/16- and 32-bit accesses from the host. However, unaligned 16/32-bit access support is not required.

**NOTE:** PCI 2.3 specification notes that "For all accesses to MSI-X Table and MSI-X PBA fields, software must use aligned full DWORD or aligned full QWORD transactions; otherwise, the result is undefined".

#### 11.6.3 MSI-X Data Structures

Full specification of MSI-X is available in PCI Specification rev. 2.3; it is not repeated here. The MSI-X Table hosted by BCM571X/BCM5720 family is described here:

- This structure is placed at offset 0x0 pointed by BAR4 and BAR5. The content of the MSI-X Table structure is shown in Table 99 on page 218.
- Depending on whether IOV mode is selected, the PCle core advertises either a 17-entry MSI-X table or a 5-entry MSI-X table. The advertisement choice is made only once following POR and cannot be changed afterward (see the Table Size field). Selection of Single-Vector/Multivector mode does not affect Table Size.
- This table comprises multiple 4 DWORD-long entries and each entry corresponds to one MSI-X vector. Thus, in the BCM571X/BCM5720 family, there is a maximum of 17 such entries.
- Each entry consists of four fields:
  - The Message Address High and Message Address Low fields point to a 64-bit Host Address where the corresponding vector message must be posted.
  - Message Data contains a 32-bit vector data. Every time the BCM571X/BCM5720 family wants to send an interrupt message corresponding to this vector, it writes the value provided by this field into the address pointed by Message Address field(s).
  - Host software is allowed to replicate the same physical host address into multiple entries; that amounts to interrupt vector aliasing. The BCM571X/BCM5720 family can handle such aliasing.
  - Only one bit, bit[0] of the Vector Control field, is implemented by PCI/PCIe. This is the (per vector) Mask bit. When this bit is 1, the device function must not send a corresponding interrupt vector message to the host. Instead, the function must set the corresponding Pending bit in the PBA. When this bit is 1 and a 0 is written to it, a device must schedule an interrupt vector in case one was already "Pending".

- The PBA Structure in the BCM571X/BCM5720 family is only 4 DWORDs or 128 bits wide, out of which bits [16:0] are useful, while bits [127:17] are reserved for future use. Each PBA bit index corresponds to the respective MSI-X vector#—that is why only 17 bits are implemented in the BCM571X/BCM5720 family. The PBA is placed at the offset 0x120 relative to the addresses pointed by BAR4 and BAR5. See Table 99 on page 218.
- There is room for expansion of up to 18 MSI-X vectors in future NetXtreme controllers.
- In the Message Control Register, only three fields are important to the respective MAC Core:
  - MSI-X Enable: This is the feature enable/disable bit. The MAC Core must dynamically snoop CFG writes to this bit in order to determine if MSI-X gets enabled or not. When MSI-X is enabled, Line Interrupt Message and MSI Message must be gated off by MAC Core. (Though PCIe allows host software to enable MSI and MSI-X concurrently, albeit erratically, MSI is preempted in such a scenario.)
  - Function Mask: This bit acts like a device function-wide vector mask. When this bit is 1, all vectors in the function, i.e., 0 through 16 in the BCM571X/BCM5720 family must be masked. If any interrupt vector event occurs while Function Mask is 1, the corresponding Pending bit in PBA must be set. When this bit is 0, the per-vector Mask bits found in each Table Entry determine whether a vector is masked or not.
  - Table Size: This field may declare a value of either 5 or 17. This is accomplished by Boot Code programming the appropriate Private Register of the PCIe core.

Table 99 depicts the implemented address regions of BAR4 and BAR5 in the BCM571X/BCM5720 family. Only two structures are present: the MSI-X Table and the Pending Bit Array in the offsets shown in the table. Any host accesses to the non-implemented addresses in these BARs must be gracefully handled by the controller; i.e., Reads return 0x0 and Writes have no effect whatsoever on the MAC.

Table 99: MSI-X Table and PBA Structures in BCM571X/BCM5720 Family

| MSI-X Table Entry# | DW3 Content (32-<br>bit) | DW2 Content (32-<br>bit) | DW1 Content (32-<br>bit) | DW0 Content (32-<br>bit) | BAR4 and BAR5<br>Offset |
|--------------------|--------------------------|--------------------------|--------------------------|--------------------------|-------------------------|
| N/A                | Reserved Bits [127:17    | 7] (PBA)                 | Pending Bits[            | 16:0]                    | 0x120                   |
| Reserved Entry     |                          |                          |                          |                          | 0x110                   |
| 16                 | Vec#16 Control           | Msg#16 Data              | Msg#16 Addr H            | Msg#16 Addr L            | 0x100                   |
| 15                 | Vec#15 Control           | Msg#15 Data              | Msg#15 Addr H            | Msg#15 Addr L            | 0xF0                    |
|                    |                          |                          |                          |                          |                         |
|                    |                          |                          |                          |                          |                         |
| 4                  | Vec#4 Control            | Msg#4 Data               | Msg#4 Addr H             | Msg#4 Addr L             | 0x40                    |
| 3                  | Vec#3 Control            | Msg#3 Data               | Msg#3 Addr H             | Msg#3 Addr L             | 0x30                    |
| 2                  | Vec#2 Control            | Msg#2 Data               | Msg#2 Addr H             | Msg#2 Addr L             | 0x20                    |
| 1                  | Vec#1 Control            | Msg#1 Data               | Msg#1 Addr H             | Msg#1 Addr L             | 0x10                    |
| 0                  | Vec#0 Control            | Msg#0 Data               | Msg#0 Addr H             | Msg#0 Addr L             | 0x00                    |

#### 11.6.4 MSI-X Cognizant Host Coalescing

After sending a complete Transmit packet to the wire, the controller updates the Send BD Ring consumer index internally. Similarly, after moving each full Received packet to the host memory, the controller updates its internal copy of the Rx Return Ring producer index. The controller notifies the host software or the network stack of such consumer and producer index updates by DMAing the Status Block and then sending an interrupt to the Host CPU.

Host software does not necessarily need to get indication for every packet received from the network, nor does it need to get completion for every packet sent to the wire. Heavy interrupt processing would degrade host CPU performance. However, the stack must communicate with application processes in a timely manner to keep up with network bandwidth demanded by the application. Thus, host software must have control in regulating—however coarsely—when and how often it gets interrupts from the controller. The controller, in turn, accumulates update events. When the accumulation reaches a threshold value, as configured by the host software, the controller sends an interrupt. This scheme is known as interrupt coalescing or host coalescing.

Legacy NetXtreme architecture already offers a set of Host Coalescing (HC) Parameters.

#### 11.6.4.1 Legacy Host Coalescing Parameters

This section lists the legacy set of host coalescing parameters that NetXtreme already offered prior to BCM571X/BCM5720 family.

#### 11.6.4.1.1 Receive Coalescing Ticks Register (Offset: 0x3c08)

The value in this register can be used to control how often the status block is updated (and how often interrupts are generated) due to receiving packets. The value in this register controls how many ticks, in units of 1 µs each, get loaded in an internal receive tick timer register. The timer is reset to the value of this register and starts counting down after every status block update (regardless of the reason for the status block update). The timer is reset only after status block updates, and is not reset after any given packet is received. When the timer reaches 0, it is considered to be in the expired state. When the counter is in the expired state, a status block update will occur if a packet had been received and copied to host memory (via DMA) since the last status block update.

This register must be initialized by host software. A value of 0 in this register disables the receive tick coalescing logic. In this case, status block updates occur for receive events only if the Receive Max Coalesced BD value is reached. Status block updates for other reasons (e.g., transmit events) also include any updates to the receive indices. By setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to receiving packets. This generally increases performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. For host environments where receive interrupt latency must be very low, and the host is not close to saturation, it is recommended that this register be set to 1.

#### 11.6.4.1.2 Send Coalescing Ticks Register (Offset: 0x3c0c)

The value in this register can be used to control how often the status block is updated (and how often interrupts are generated) according to the completion of transmit events. The value in this register controls how many ticks, in units of 1 µs each, get loaded in an internal transmit tick timer register. The timer is reset to the value of this register and starts counting down after every status block update (regardless of the reason for the status block update). The timer is reset only after status block updates, and is not reset after a transmit event completes. When the timer reaches 0, it is considered to be in

the expired state. When the counter is in the expired state, a status block update occurs if a transmit event has occurred since the last status block update. In this case, a transmit event is defined by an update to one of the device's Send BD Consumer Indices. A Send Consumer Index increments whenever the data associated with a particular packet has been successfully moved (via DMA) across the bus, rather than when the packet is actually transmitted over the Ethernet wire.

This register must be initialized by host software. A value of 0 in this register disables the transmit tick coalescing logic. In this case, status block updates occur for transmit events only if the Send Max Coalesced BD value is reached, or if the BD\_FLAG\_COAL\_NOW bit is set in a send BD. Status block updates for other reasons (e.g., receive events) also include any updates to the send indices. By setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to transmit completions. This generally increases performance in hosts that do not require their send buffers to be freed quickly. For host environments that do require their send buffers to be recovered quickly, it is recommended that this register be set to 0.

#### 11.6.4.1.3 Receive Max Coalesced Bd Count Register (Offset: 0x3c10)

This register contains the maximum number of receive return ring BDs that must be filled in by the device before the device updates the status block due to a receive event. Whenever the device completes the reception of a packet, it fills in a receive return ring BD, and then increments an internal receive coalesce BD counter. When this internal counter reaches the value in this register, a status block update occurs. This counter is reset (i.e., zeroed) whenever a status block update occurs regardless of the reason for the status block update. This register must be initialized by host software. A value of 0 in this register disables the receive max BD coalescing logic. In this case, status block updates occur for receive packets only via the Receive Coalescing Ticks mechanism. Status block updates for other reasons (e.g., transmit events) also include any updates to the receive indices. For simplicity, if a host wanted to get a status block update for every received packet, the host driver should just set this register to a value of 1. On the other hand, by setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to receiving packets. This can increase performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. However, in lower traffic environments, there is no guarantee that consecutive packets will be received in a timely manner. Therefore, for those environments, it is recommended that the Receive Coalescing Ticks register is used to make sure that status block updates due to receiving packets are not delayed for an infinite amount of time.

#### 11.6.4.1.4 Send Max Coalesced BD Count Register (Offset: 0x3c14)

This register contains the maximum number of send BDs that must be processed by the device before the device updates the status block due to the transmission of packets. Whenever the device completes the DMA of transmit packet buffer, it increments an internal send coalesce BD counter. When this internal counter reaches the value in this register, a status block update occurs. This counter is reset (i.e., zeroed) whenever a status block update occurs, regardless of the reason for the status block update. This register must be initialized by host software. A value of 0 in this register disables the send max BD coalescing logic. In this case, status block updates occur for receive packets only via the Send Coalescing Ticks mechanism. Status block updates for other reasons (e.g., receive events) also include any updates to the send indices. For simplicity, if a host wants to get a status block update for every transmitted packet, the host driver could set this register to a value of 1. However, by setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to transmitting packets. This can increase performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. However, in lower traffic environments, there is no guarantee that consecutive packets will be transmitted in a timely manner. Therefore, for those environments, it is recommended that the Send Coalescing Ticks register is used to ensure that status block updates due to transmitting packets are not delayed for an infinite amount of time.

#### 11.6.4.1.5 Receive Max Coalesced BD Count During Interrupt Register (Offset 0x3c18)

This register has the same attribute as 0x3C10 except that this parameter is active only during the During Interrupt state, which is the state during which the ISR has acknowledged an interrupt by writing a nonzero value to the MailBox register, and thus the interrupt is in a masked state. If this parameter triggers (while in During Interrupt state), the controller will DMA the latest Status Block to the host memory, but the interrupt will remain deasserted.

#### 11.6.4.1.6 Send Max Coalesced BD Count During Interrupt Register (Offset 0x3c1c)

This register has the same attribute as 0x3C14 except that this parameter is active only during the During Interrupt state, which is the state during which the ISR has acknowledged an interrupt by writing a nonzero value to the MailBox register, and thus the interrupt is in a masked state. If this parameter triggers (while in During Interrupt state), the controller DMAs the latest Status Block to the host memory, but the interrupt remains deasserted.

#### 11.6.4.2 BCM571X/BCM5720 Family Host Coalescing Parameter Sets

The legacy HC Parameter registers do not offer granularity in terms of individual Rx Return queues or individual Tx queues. Instead, in the legacy implementation, all Transmit/Return Rings are grouped together for metering.

The BCM571X/BCM5720 family offers HC parameters or control on a per-Rx-and-Tx-queue basis when and only when MSI-X Multivector mode is chosen. To that end, 16 more sets of Host Coalescing Parameter registers are added. Each such HC Parameter Set comprises of the following registers:

- Receive [n] Coalescing Ticks Register
- Send [n] Coalescing Ticks Register
- Receive [n] Max Coalesced BD Count Register
- Send [n] Max Coalesced BD Count Register
- Receive [n] Max Coalesced BD Count During Interrupt Register
- Send [n] Max Coalesced BD Count During Interrupt Register

Where, n ranges from 1 through 16. The legacy HC Parameter registers are now called HC Parameter Set [0].

Each of these new sets has the same behavior or attribute as defined in "Receive Coalescing Ticks Register (Offset: 0x3c08)" on page 219 and "Receive Max Coalesced Bd Count Register (Offset: 0x3c10)" on page 220, except one aspect: when MSI-X Multivector mode is enabled, each of these sets associates with its respective Status-Block[n]. However, when either MSI-X is disabled or MSI-X Single-Vector mode is enabled, none of these additional sets would exist. Note that, when MSI-X Single-Vector mode is enabled, even though 5 (or 17) vectors are advertised, only Vector#0 remains active.

**NOTE:** To further clarify, in Legacy INTx mode, MSI mode, or MSI-X Single Vector mode, all Transmit and Receive queues are metered collectively by HC Parameter Set [0]. Parameter Sets [1–16] do not exist. Only in Multivector MSI-X mode do HC Parameter Sets [1–16] come into existence.

Table 100 summarizes the existence of HC Parameter Sets, and their association with Status-Blocks. An "----" indicates that this register does not exist in this particular mode.

**Table 100: MSI-X Host Coalescing Parameters** 

| Valid                              | IOV-Mode + Multiple TXQ (Netqueue/ VMQ+TSS) |                                | IOV-Mode +<br>Single TXQ |                                       | Multiple TXC        | RSS-Mode +<br>Multiple TXQ            |                     | RSS-Mode +<br>Single TXQ                 |                    |
|------------------------------------|---------------------------------------------|--------------------------------|--------------------------|---------------------------------------|---------------------|---------------------------------------|---------------------|------------------------------------------|--------------------|
| HC<br>Parameter<br>Register<br>Set | Invokes<br>Status<br>Block#                 | HC Parameter Registers Address | Indication<br>Items      | (VMQ)  HC Parameter Registers Address | Indication<br>Items | (TSS)  HC Parameter Registers Address | Indication<br>Items | (Legacy)  HC Parameter Registers Address | Indication<br>Item |
| RCTR[0]                            | 0                                           | 0x3C08                         |                          | 0x3C08                                |                     |                                       |                     |                                          |                    |
| SCTR[0]                            |                                             |                                | VRQ 0                    | 0x3C0C                                | VRQ 0               |                                       |                     | 0x3C0C                                   |                    |
| RMCBCR[0]                          |                                             | 0x3C10                         |                          | 0x3C10                                | TX                  |                                       |                     |                                          | TX                 |
| SMCBCR[0]                          |                                             |                                | LinkStat                 | 0x3C14                                | LinkStat            |                                       | LinkStat            | 0x3C14                                   | LinkStat           |
| RMCBCDIR[0]                        |                                             | 0x3C18                         | Errors                   | 0x3C20                                | Errors              |                                       | Errors              |                                          | Errors             |
| SMCBCDIR[0]                        |                                             |                                | VRQ Map                  | 0x3C24                                | VRQ Map             |                                       |                     | 0x3C24                                   |                    |
| RCTR[1]                            | 1                                           | 0x3D80                         |                          | 0x3D80                                |                     | 0x3D80                                |                     | 0x3D80                                   |                    |
| SCTR[1]                            |                                             | 0x3D84                         | VRQ 1                    |                                       | VRQ 1               | 0x3D84                                | RSS 0               |                                          | RSS 0              |
| RMCBCR[1]                          |                                             | 0x3D88                         | TXQ 1                    | 0x3D88                                |                     | 0x3D88                                | TXQ 1               | 0x3D88                                   |                    |
| SMCBCR[1]                          |                                             | 0x3D8C                         |                          |                                       |                     | 0x3D8C                                |                     |                                          |                    |
| RMCBCDIR[1]                        |                                             | 0x3D90                         |                          | 0x3D90                                |                     | 0x3D90                                |                     | 0x3D90                                   |                    |
| SMCBCDIR[1]                        |                                             | 0x3D94                         |                          |                                       |                     | 0x3D94                                |                     |                                          |                    |
| RCTR[2]                            | 2                                           | 0x3D98                         |                          | 0x3D98                                |                     | 0x3D98                                |                     | 0x3D98                                   |                    |
| SCTR[2]                            | _                                           | 0x3D9C                         | VRQ 2                    |                                       | VRQ 2               | 0x3D9C                                | RSS 1               |                                          | RSS 1              |
| RMCBCR[2]                          |                                             | 0x3DA0                         | TXQ 2                    | 0x3DA0                                | VIIQ Z              | 0x3DA0                                | TXQ 2               | 0x3DA0                                   | 11001              |
| SMCBCR[2]                          |                                             | 0x3DA4                         | 17.0 2                   | OXODAO                                |                     | 0x3DA4                                | TAG Z               | OXOBAO                                   |                    |
| RMCBCDIR[2]                        |                                             | 0x3DA4<br>0x3DA8               |                          | 0x3DA8                                |                     | 0x3DA4                                |                     | 0x3DA8                                   |                    |
| SMCBCDIR[2]                        |                                             | 0x3DA6                         |                          | UXSDA6                                |                     | 0x3DA6                                |                     | UXSDA6                                   |                    |
|                                    | 0                                           |                                |                          | 00000                                 |                     |                                       |                     | 00000                                    |                    |
| RCTR[3]                            | 3                                           | 0x3DB0                         | \ /DO 0                  | 0x3DB0                                | \                   | 0x3DB0                                | B00.0               | 0x3DB0                                   | D00.0              |
| SCTR[3]                            |                                             | 0x3DB4                         | VRQ 3                    |                                       | VRQ 3               | 0x3DB4                                | RSS 2               |                                          | RSS 2              |
| RMCBCR[3]                          |                                             | 0x3DB8                         | TXQ 3                    | 0x3DB8                                |                     | 0x3DB8                                | TXQ 3               | 0x3DB8                                   |                    |
| SMCBCR[3]                          |                                             | 0x3DBC                         |                          |                                       |                     | 0x3DBC                                |                     |                                          |                    |
| RMCBCDIR[3]                        |                                             | 0x3DC0                         |                          | 0x3DC0                                |                     | 0x3DC0                                |                     | 0x3DC0                                   |                    |
| SMCBCDIR[3]                        |                                             | 0x3DC4                         |                          |                                       |                     | 0x3DC4                                |                     |                                          |                    |
| RCTR[4]                            | 4                                           | 0x3DC8                         |                          | 0X3DC8                                |                     | 0x3DC8                                |                     | 0X3DC8                                   |                    |
| SCTR[4]                            |                                             | 0x3DCC                         | VRQ 4                    |                                       | VRQ 4               | 0x3DCC                                | RSS 3               |                                          | RSS 3              |
| RMCBCR[4]                          |                                             | 0x3DD0                         | TXQ 4                    | 0x3DD0                                |                     | 0x3DD0                                | TXQ 4               | 0x3DD0                                   |                    |
| SMCBCR[4]                          |                                             | 0x3DD4                         |                          |                                       |                     | 0x3DD4                                |                     |                                          |                    |
| RMCBCDIR[4]                        |                                             | 0x3DD8                         |                          | 0x3DD8                                |                     | 0x3DD8                                |                     | 0x3DD8                                   |                    |
| SMCBCDIR[4]                        |                                             | 0x3DDC                         |                          |                                       |                     | 0x3DDC                                |                     |                                          |                    |
| RCTR[5]                            | 5                                           | 0x3DE0                         |                          | 0x3DE0                                |                     |                                       |                     |                                          |                    |
| SCTR[5]                            |                                             | 0x3DE4                         | VRQ 5                    |                                       | VRQ 5               | N/A                                   | N/A                 | N/A                                      | N/A                |
| RMCBCR[5]                          |                                             | 0x3DE8                         | TXQ 5                    | 0x3DE8                                |                     |                                       |                     |                                          |                    |
| SMCBCR[5]                          |                                             | 0x3DEC                         |                          |                                       |                     |                                       |                     |                                          |                    |
| RMCBCDIR[5]                        |                                             | 0x3DF0                         |                          | 0x3DE0                                |                     |                                       |                     |                                          |                    |
| SMCBCDIR[5]                        |                                             | 0x3DF4                         |                          |                                       |                     |                                       |                     |                                          |                    |
| RCTR[6]                            | 6                                           | 0x3EF8                         |                          | 0x3DE8                                |                     |                                       |                     |                                          |                    |
| SCTR[6]                            |                                             | 0x3EFC                         | VRQ 6                    |                                       | VRQ 6               | N/A                                   | N/A                 | N/A                                      | N/A                |
| RMCBCR[6]                          |                                             | 0x3E00                         | TXQ 6                    | 0x3DF0                                |                     |                                       |                     |                                          |                    |
| SMCBCR[6]                          |                                             | 0x3E04                         |                          |                                       |                     |                                       |                     |                                          |                    |
| RMCBCDIR[6]                        |                                             | 0x3E08                         |                          | 0x3DF8                                |                     |                                       |                     |                                          |                    |
| SMCBCDIR[6]                        |                                             | 0x3E0C                         |                          |                                       |                     |                                       |                     |                                          |                    |
|                                    |                                             |                                |                          |                                       |                     |                                       |                     |                                          |                    |
|                                    |                                             |                                |                          |                                       |                     | N/A                                   | N/A                 | N/A                                      | N/A                |
|                                    |                                             |                                |                          | 1                                     |                     |                                       |                     |                                          | 1.37.              |

Table 100: MSI-X Host Coalescing Parameters (Cont.)

| Valid<br>HC                  |                             | Multiple TXQ                            |                     | Single TXQ                              |                     | RSS-Mode +<br>Multiple TXQ<br>(TSS)     |                     | RSS-Mode +<br>Single TXQ<br>(Legacy)    |                    |
|------------------------------|-----------------------------|-----------------------------------------|---------------------|-----------------------------------------|---------------------|-----------------------------------------|---------------------|-----------------------------------------|--------------------|
| Parameter<br>Register<br>Set | Invokes<br>Status<br>Block# | HC<br>Parameter<br>Registers<br>Address | Indication<br>Items | HC<br>Parameter<br>Registers<br>Address | Indication<br>Items | HC<br>Parameter<br>Registers<br>Address | Indication<br>Items | HC<br>Parameter<br>Registers<br>Address | Indication<br>Item |
| RCTR[16]                     | 16                          | 0x3EE8                                  |                     | 0x3EE8                                  |                     |                                         |                     |                                         |                    |
| SCTR[16]                     |                             | 0x3EEC                                  | VRQ 16              |                                         | VRQ 16              | N/A                                     | N/A                 | N/A                                     | N/A                |
| RMCBCR[16]                   |                             | 0x3EF0                                  | TXQ 16              | 0x3EF0                                  |                     |                                         |                     |                                         |                    |
| SMCBCR[16]                   |                             | 0x3EF4                                  |                     |                                         |                     |                                         |                     |                                         |                    |
| RMCBCDIR[16]                 |                             | 0x3EF8                                  |                     | 0x3EF8                                  |                     |                                         |                     |                                         |                    |
| SMCBCDIR[16]                 |                             | 0x3EFC                                  |                     |                                         |                     |                                         |                     |                                         |                    |

Abbreviations:

RCTR[n] RECEIVE COALESCING TICKS REGISTER[n]
SCTR[n] SEND COALESCING TICKS REGISTER[n]

RMCBCR[n] RECEIVE MAX COALESCED BD COUNT REGISTER[n]

SMCBCR[n] SEND MAX COALESCED BD COUNT REGISTER[n]

RMCBCDIR[n] RECEIVE MAX COALESCED BD COUNT DURING INTERRUPT REGISTER[n]

SMCBCDIR[n] SEND MAX COALESCED BD COUNT DURING INTERRUPT REGISTER[n]

0x55AA New Registers in BCM571X/BCM5720 family (legend)

#### 11.6.4.3 MSI-X One Shot Mode

The BCM571X/BCM5720 family introduces a new method of MSI-X acknowledgment known as the One Shot mode. When this mode is set, an ISR is asked to skip the interrupt acknowledgment step in which it would otherwise write a nonzero value to the respective INT MailBox. This is sensible because MSI-X vector messages are equivalent to edge-triggered non-shared interrupt events; therefore, there is no need for ISR to explicitly acknowledge the event.

One Shot mode is enabled by default and could be disabled by writing a 1 to the register bit 0x6000[5]. the One Shot mode setting has no effect on the Line Interrupt or MSI modes.

The controller hardware stores a nonzero value to an INT Mailbox as soon as a respective MSI-X Message DMA is completed at the EP-RC (PCIe Core) interface.

#### 11.6.4.4 Coalesce Now or Forced Update

There is a Coalesce Now bit in the legacy Host Coalescing block, 0x3C00[3]. If set, the Host Coalescing block updates the Status Block immediately and sends an interrupt to host. This bit is self-clearing.

In the BCM571X/BCM5720 family, this bit retains the same functionality and associates with Status-Block0 and Vector#0 when MSI-X is enabled. Moreover, 16 additional Coalesce Now bits replicate the same function associated to vector numbers 1 through 16. Below are the definitions of the bits.

- 0x3C00[3]: Coalesce Now (When INTx or MSI Enabled)
- 0x3C00[3]: Coalesce vector#0 Now (When MSI-X Enabled)
- 0x3C00[13]: Coalesce vector#1 Now (When MSI-X Enabled and Multivector mode Enabled)
- 0x3C00[14]: Coalesce vector#2 Now (When MSI-X Enabled and Multivector mode Enabled)
- 0x3C00[15]: Coalesce vector#3 Now (When MSI-X Enabled and Multivector mode Enabled)
- 0x3C00[16]: Coalesce vector#4 Now (When MSI-X Enabled and Multivector mode Enabled)

- 0x3C00[17]: Coalesce vector#5 Now (When MSI-X Enabled and Multivector mode Enabled)
- **.....**
- 0x3C00[28]: Coalesce vector#16 Now (When MSI-X Enabled and Multivector mode Enabled)

#### 11.6.4.5 Misc Coalescing Controls

There are a few Host Coalescing controls in the legacy NetXtreme design in the HOST COALESCING MODE REGISTER (0x3C00) and HOST CONTROL REGISTER (0x68). Some of these controls apply equally to the newly added HC parameters or MSI-X feature in general, and some do not apply equally. Such controls are listed here for clarity:

#### 11.6.4.5.1 Broadcom Tagged Status Mode (0x68[9])

Enabled by setting the Status Tagged Status Mode bit of the Miscellaneous Host Control register. When enabled, a unique eight-bit tag value is inserted into the Status Block Status Tag at location 7:0. The Status Tag can be returned to the Mailbox 0 register at location 31:24 by the host driver. When the Mailbox 0 register field 23:0 is written with a zero value, the tag field of the Mailbox 0 register is compared with the tag field of the last Status Block to be DMAed to the host. If the tag returned is not equivalent to the tag of the first Status Block DMAed, the interrupt status is entered. This bit, 0x68[7], applies to all 17 MSI-X vectors.

#### 11.6.4.5.2 Clear Interrupt, Mask Interrupt, Mask Mode (0x68[0], 0x68[1], 0x68[8])

These bits have no effect on MSI-X operations.

#### 11.6.4.5.3 Clear Ticks On Rx Bd Events Mode (0x3c00[9])

Enabled by setting the Clear Ticks mode on Rx bit of the Host Coalescing Mode register. When enabled, the counters initialize to the idle state and begin counting only after a receive BD event is detected. This register bit also applies to all newly created RCTR Registers.

#### 11.6.4.5.4 No Interrupt On Force Update (0x3c00[11])

Enabled by setting the No Interrupt on Force bit of the Host Coalescing Mode register. After enabling this bit, subsequent writes to the Coalesce Now bit(s) of the Host Coalescing Mode register cause status block update(s) without the corresponding interrupt event. This bit applies to all MSI-X vectors and respective Status Blocks.

#### 11.6.4.5.5 No Interrupt On DMAD Force (0x3c00[12])

Enabled by setting the No Interrupt on DMAD force bit of the Host Coalescing Mode register. When enabled, the BD\_FLAG\_COAL\_NOW bit of the buffer descriptor may be set to force a status block update without a corresponding interrupt. This feature is associated to Send BDs only; hence, it applies to Vector#0 in MSI-X mode when Multiple Send Queues are not enabled.

Register Transfer Level (RTL) Note: The HC RTL honors the Coal\_Now Flag coming from both Send or Receive flow-through queues (FTQs). Rx FTQ never requests it, as the RBDs do not support any such flag.

#### 11.6.4.5.6 Do Not Interrupt On Receives (0x6800[14])

If set, an interrupt is not generated upon a Receive Return Ring producer update. This bit applies equally to vector#0 through vector#16 in Multivector mode.

#### 11.6.4.6 End of Receive Stream Interrupt

A new kind of forced interrupt is being introduced in the BCM571X/BCM5720 family. The End of Rx Stream Interrupt attempts to sense the end of a receive burst and, if it does, it fires an interrupt/MSI-X instantaneously.

After completing the DMA of every Return BD to the host memory, a hardware FSM checks if the Rx-MBUF is empty (discounting the effects of pre-allocation). If it is empty, hardware starts counting down a count value. While the countdown is in progress, if another Rx packet starts to pour into the Rx-MBUF, the FSM goes back to idle. However, if no other Rx packet arrives, it allows the counter to go down to zero, at which point the FSM triggers an interrupt/MSI-X. The counter basically debounces effects of IPG or short gaps among packets within a burst.

This feature may be enabled or disabled by a register bit. The countdown preload value is also programmable. When enabled in conjunction with Multivector MSI-X mode, there is a programmable option to fire either Vector#0 only or all Vectors.

#### 11.6.4.6.1 Host Coalescing Mode Register (Offset 0x3c00)

Table 101: Add Table Title Here

| Name                                              | Bits  | Access   | Default<br>Value | Description                                                               |
|---------------------------------------------------|-------|----------|------------------|---------------------------------------------------------------------------|
| As defined in Legacy                              | 31    | <u>'</u> |                  | ·                                                                         |
| End of Rx Stream Detector Fires ALL MSI-X Vectors | 30    | RW       | 0x0              | Write 1 to fire ALL MSI-X Vectors when an End of Rx Stream is detected.   |
|                                                   |       |          |                  | Write 0 to fire only MSI-X Vector#0 when an End of Rx Stream is detected. |
| Enable End of Rx Stream Interrupt                 | 29    | RW       | 0x0              | Write 1 to enable the End of Rx Stream Interrupt                          |
| Coalesce Now MSI-X Vector# [16–1]                 | 28:13 | WC       | 0x0              | Individual Coalesce Now bits associated with MSI-X Vector# 16 through 1.  |
|                                                   |       |          |                  | These bits are self-clearing.                                             |
| As defined in Legacy                              | 12:0  |          |                  |                                                                           |

#### 11.6.4.6.2 End Stream Debounce Register (Offset 0x3cd4)

Table 102: Add Table Title Here

| Name                 | Bits  |    | Default<br>Value | Description |  |  |
|----------------------|-------|----|------------------|-------------|--|--|
| As defined in Legacy | 31    | 31 |                  |             |  |  |
| Reserved             | 30:16 | RO | 0                | -           |  |  |

#### Table 102: Add Table Title Here (Cont.)

| Name                            | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| End of Rx Stream Debounce Count | 15:0 | RW     | 0x000F           | This field is meaningful only when 0x3C00[29] is 1. After completing the DMA of every Return BD to the Host memory, a hardware FSM checks if the Rx-MBUF is empty (discounting the effects of pre-allocation). If it is, hardware starts counting down a count value programmed by this field. While the count down is in progress, if another Rx packet starts to pour into the Rx-MBUF, the FSM goes back to idle. However, if no other Rx packet arrives, it allows the counter to go down to zero, at which point the FSM triggers an interrupt/MSI-X. The counter basically debounces effects of IPG or short gaps among packets within a burst.  The counter counts in Core-Clocks. |

### 11.7 Other Configuration Controls

#### 11.7.1 Broadcom Mask Mode

Enabled by setting the Mask\_Interrupt\_Mode bit (bit 8) of the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). When enabled, setting the mask bit of the Miscellaneous Host Control register will mask (deassert) the INTA signal at the pin, but it will not clear the interrupt state and it will not latch the INTA value. Clearing the mask bit will enable the interrupt state to propagate to the INTA signal. Note that the During Interrupt Coalescence registers are only used when the Mailbox 0 is set.

#### 11.7.2 Broadcom Tagged Status Mode

Enabled by setting the Status Tagged Status mode bit of the Miscellaneous Host Control register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). When enabled, a unique eight-bit tag value will be inserted into the Status Block Status Tag at location 7:0. The Status Tag can be returned to the Mailbox 0 register at location 31:24 by the host driver. When the Mailbox 0 register field 23:0 is written with a zero value, the tag field of the Mailbox 0 register is compared with the tag field of the last Status Block to be DMAed to the host. If the tag returned is not equivalent to the tag of the first Status Block DMAed, the interrupt status is entered.

#### 11.7.3 Clear Ticks on BD Events Mode

Enabled by setting the Clear Ticks mode on RX or the Clear Ticks mode on TX bits of the Host Coalescing Mode register (see "Miscellaneous Host Control Register (offset: 0x68)" on page 245). When enabled, the counters initialize to the idle state and begin counting only after a receive or transmit BD event is detected.

#### 11.7.4 No Interrupt on Force Update

Enabled by setting the No Interrupt on Force bit of the Host Coalescing Mode register (see "Host Coalescing Mode Register (offset: 0x3C00)" on page 367). When enabled, writing the Force update bit of the Host Coalescing Mode register will cause a status block update without a corresponding interrupt event.

#### 11.7.5 No Interrupt on DMAD Force

Enabled by setting the No Interrupt on DMAD force bit of the Host Coalescing Mode register (see "Host Coalescing Mode Register (offset: 0x3C00)" on page 367). When enabled, the BD\_FLAG\_COAL\_NOW bit of the buffer descriptor may be set to force a status block update without a corresponding interrupt.

## **Chapter 12: IO Virtualization (IOV)**

IO Virtualization or IOV is a solution to transparently share a physical IO device among the child/guest OS images in a virtualized environment. The NetXtreme (BCM5718/19/20) offers a cost efficient set of IO Virtualization features. The following list provides the feature highlights:

- Receive Side:
  - RX Traffic sorting over multiple RX queues
  - Hardware assisted RX Packet replication in Driver
  - Universal VLAN stripping (Not per queue based)
  - 24x Perfect Match Addresses Filters
  - One 128-bit MultiCast Addresses Hash Filter
  - 32-Element/31-Set Programmable Protocol Filter (VLAN, TCP, etc)
  - 16 Receive Queues + 1 Default Queue + 1 Drop Queue
  - 17 Standard Receive Producer Rings
  - 17 Jumbo Receive Producer Rings
  - 17 Return Rings
  - Per Queue synchronization with Driver
  - RX Packet Header Data Split and copy for VMQ

#### **NOTE:** No RSS support in IOV Mode.

- Transmit Side:
  - 16 Transmit Queues for use by NetQueue or NDIS-TSS
  - Per Frame Round Robin and Weighted RR scheduling in Hardware
- General
  - · IOV Mode is a static configuration
  - 18 MSI-X vectors 1 per TX/RX Queue Pair
  - · Per Queue nominal Statistics in Hardware
  - · No RX Bandwidth Limitation or TX Traffic/Rate shaping

**NOTE:** IOV shall operate in a distinct and a static chip-mode. This mode is called the IOV Mode and the chip would need to be configured during boot-up. Once configured, the mode is irreversible unless a hard-reset is asserted to the chip. During boot-up, if the IOV-Mode is not chosen, the chip will operate in the Legacy Mode which is akin to the operation of previous NetXtreme devices.

### 12.1 Data Structure and Register Changes for IOV

The following changes have been made to support IOV:

#### 12.1.1 Mail Box Register Changes

The following mailbox register changes have been made:

- 16 more Standard RBD Producer Index Mail Boxes have been added.
- 16 more Jumbo RBD Producer Index Mail Boxes have been added.
- 13 more Receive Return Ring Consumer Index Mail Boxes have been added.
- 15 more Host Send Producer Index Mail Boxes have been added.

#### 12.1.2 Receive Mail Box Register Changes

16 Standard RBD Producers, 16 Jumbo RBD Producers, and 13 Receive Return Ring Consumer mail boxes have been added to the High Priority Mail Box region (see "RX Mail Box Registers for VRQ" on page 408).

#### 12.1.3 Send Mail Box Register Changes

15 Host Send Producer Index registers have been added to the High Priority Mail Box region (see "Send Mail Box Registers" on page 313).

#### 12.1.4 Ring Control Block Changes

The following ring control block changes have been made:

- 16 more Standard Producer RCBs added
- 16 more Jumbo Producer RCBs added
- 13 more Return Ring RCBs added
- 15 more Send RCBs added

Receive Ring Control Blocks (see "Receive Ring Control Blocks" on page 51).

Send Ring Control Blocks (see "Send Ring Control Blocks" on page 50).

#### 12.1.5 VRQ Statistics

- VRQ Receive Statistics
- VRQ Transmit Statistics

EMAC collects basic statistics on an individual generic VRQ basis. Though the accumulation mechanism remains the same, i.e., these registers are Clear-On-Read, these statistic registers are independent of the aggregated EMAC statistics registers for LAN and APE (see "VRQ Statistics" on page 404).

### 12.1.6 MSI-X Vectors Changes

The NetXtreme® I offers two vector modes within the MSI-X mode for IOV:

- Single Vector IOV mode (Restrict to Vector#0)
- Multivector IOV mode (17 Vectors Requested)

For more information, see "MSI-X" on page 208.

#### 12.1.7 Register Changes

The following register changes have been made:

- GRC-MODE-REG (Offset 0x6800): Additional bits have been added to this existing register (see "Mode Control Register (offset: 0x6800)" on page 416).
- RDI-MODE-REG (Offset 0x2400): Additional bits have been added to this existing register (see "Receive Data and Receive BD Initiator Mode Register (offset: 0x2400)" on page 320).
- Standard Replenish LWM Register (Offset: 0x2D00): This register is meaningful in both Legacy and IOV Modes (see "Standard Replenish LWM Register (offset 0x2D00)" on page 330).
- Jumbo Replenish LWM Register (Offset 0x2D04): This register is meaningful in both Legacy and IOV Modes (see "Jumbo Replenish LWM Register (offset 0x2D04)" on page 330).
- BD Fetch Limit Register (Offset 0x2D08): This register is meaningful only in the IOV-Mode (see "BD Fetch Limit Register (Offset 0x2D08)" on page 332).
- VRQ Status Register (Offset: 0x240C): Additional bits have been added to this existing register (see "VRQ Status Register (offset: 0x240C)" on page 322).
- VRQ Flush Control Register (Offset: 0x2410): Additional bits have been added to this existing register (see "VRQ Flush Control Register (Offset: 0x2410)" on page 322).
- VRQ Flush Timer Register (Offset: 0x2414): The description has been updated on this existing register (see "VRQ Flush Timer Register (offset: 0x2414)" on page 323).
- HC Parameter Set Reset Register (Offset: 0x3C28): This parameter should be placed in this HC block (see "HC Parameter Set Reset Register (Offset: 0x3C28)" on page 375).
- Perfect Match Destination Address Registers: Twenty additional Perfect Match Destination Address Registers are added in RX-EMAC for VRQ Filtering purposes (see "Perfect Match Destination Address Registers" on page 408).
- VRQ Filter Set Registers: The filter block can be programmed via a new set of registers (see "VRQ Filter Set Registers" on page 405).
- SEND\_BD\_INITIATOR\_MODE\_REG (Offset 0x1800) Additional bits have been added to this existing register (see "Send BD Initiator Mode Register (offset: 0x1800)" on page 311).
- SEND\_BD\_FETCH\_THRESHOLD\_REG (Offset: 0x1850) This is a newly added register (see "Send BD Fetch Threshold Register (offset: 0x1850)" on page 313).

#### 12.2 IOV - Receive Side

The chosen Receive-Side solution to IOV acceleration is to scale into multiple Receive Indication Queues. These queues are called Virtual Receive Queues or VRQ as defined for NetXtreme internal use. VRQ generally refers to an implementation of both VMQ as well as NetQueue. Each VRQ is provided with dedicated host buffer memory resources. The reason behind this requirement involves memory protection issues with the host platform and OS. Each such queue is also provided with programmable RX traffic filter resources called VRQ Filters. The task of RX-EMAC is to sort the RX traffic designated for multiple VRQs based on VRQ Filter settings. RX-EMAC marks each RX packet with a VRQ number after placing it into the RX-MBUF. Before initiating a RX packet DMA To the host memory, the DMA engine shall inspect each packet's Frame-Header to determine which VRQ it belongs to. It then draws Receive Buffers only from the respective VRQ's host buffer resources and subsequently proceeds to DMA the packet to those buffers. After placing the frame in a VRQ designated host buffer, the controller designates the RX packet selectively to the respective owner (a child/guest OS) of the VRQ and not to any other OS images. Therefore, it implies that each VRQ shall also be associated with an independent receive indication queue, which is nothing but an independent Receive Return Ring (refer to Figure 53 on page 231 for additional information.

Figure 53: IOV Receive Flow



#### 12.3 IOV - Transmit Side

Transmit enhancement for IOV involves adding multiple Host Send Rings or effectively adding multiple transmit queues. At present, Feb 2009, only Netqueue is capable of utilizing multiple TX queues whilst VMQ is not. Although, the Transmit Side Scaling (TSS) feature of NDIS 6.x is capable of using multiple transmit queues. This is the reason this feature, namely 16 Send Rings, could be enabled in BCM5718/19/20 irrespective of the IOV-Mode settings.

BCM5718/19/20 shall implement a limited set of capabilities in this regard:

- A maximum of 16 Send Rings (SBD Rings)
  - Multiple Send Rings could be enumerated only in conjunction to either IOV-Mode or RSS Mode
  - All 16 Send Rings may be enabled in conjunction with IOV Mode
  - Up to 4 Send Rings may be enabled in conjunction with RSS Mode
- Only Host based Rings supported (NIC based Rings defeatured early on)
- Maximum Ring size of 512 each
- 16 High Priority Send Producer Index Mailboxes one per ring

- 16 Send Ring Control Blocks (RCB)
- 1KB of private on-chip SBD cache per Ring Total 16KB
- Introduction of a SBD Fetch Threshold
- Send BD Format unchanged in Multi Ring mode.
- No Rate / Traffic Shaping algorithm offered
- Very basic round-robin packet by packet arbitration among 16 Send Rings
- All Send Offload features, namely LSO & Checksum-Offload shall continue to function in all rings without any behavior change.
- Minimal set of per Send Queue EMAC Statistics

The basic Send interface with the Device Driver remains unchanged, only the number of Send Rings are scaled up to 16 from 1. Thus there shall be 16x Send Producer BD Index Mailboxes and 16x Ring Control Block Registers in controller.

SBDs are fetched from the Host memory and are stored in SBD-cache memory internal to the chip. Though such a cache memory could be shared by all 16 Rings, for the sake of simplicity we chose to assign each Send Ring a private partition of the SBD cache – physically it is a single SRAM, but is divided into 16 equal address regions. Each such address range shall serve as a private SBD cache to a Send Ring. The total size of the SBD cache is thus 16 KB.

## **Chapter 13: Ethernet Controller Register Definitions**

## 13.1 BCM571X/BCM5720 Family Register MAP

The BCM571X/BCM5720 family's internal register map is shown in Table 103.

Table 103: BCM571X/BCM5720 Family Register Map

| Block Name | Block Range   | Subblock Range | Description                        |
|------------|---------------|----------------|------------------------------------|
| PCIe CFG   | 0x0000-0x03FF | 0x0000-0x03FF  | PCle Configuration Register Shadow |
| EMAC       | 0x0400-0x07FF | 0x0400-0x06FF  | EMAC                               |
|            |               | 0x0700-0x7FF   | Unused                             |
| EMAC STAT  | 0x0800-0x0BFF | 0x0800-0x08FF  | EMAC Statistics                    |
|            |               | 0x0900-0x0BFF  | Unused                             |
| SDI        | 0x0C00-0x0FFF | 0x0C00-0x0CF7  | Send Data Initiator                |
|            |               | 0x0CF8-0x0FFF  | Unused                             |
| SDC        | 0x1000-0x13FF | 0x1000-0x100B  | Send data Completion               |
|            |               | 0x100C-0x13FF  | Unused                             |
| SBDS       | 0x1400-0x17FF | 0x1400-0x147F  | SBDS Registers                     |
|            |               | 0x1480-0x17FF  | Unused                             |
| SBDI       | 0x1800-0x1BFF | 0x1800-0x1847  | Send BD Initiator                  |
|            |               | 0x1848-0x1BFF  | Unused                             |
| SBDC       | 0x1C00-0x1FFF | 0x1C00-0x1C03  | Send BD Completion                 |
|            |               | 0x1C04-0x1FFF  | Unused                             |
| RQP        | 0x2000-0x23FF | 0x2000-0x2258  | Receive List Placement             |
|            |               | 0x2259-0x23FF  | Unused                             |
| RDI        | 0x2400-0x27FF | 0x2400-0x24C3  | Receive Data Initiator             |
|            |               | 0x24C0-0x27FF  | Unused                             |
| RDC        | 0x2800-0x2BFF | 0x2800-0x2803  | Receive Data Completion            |
|            |               | 0x2804-0x2BFF  | Unused                             |
| RBDI       | 0x2C00-0x2FFF | 0x2C00-0x2C1B  | Receive BD Initiator               |
|            |               | 0x2C1C-0x2FFF  | Unused                             |
| RBDC       | 0x3000-0x33FF | 0x3000-0x300F  | Receive BD Completion              |
|            |               | 0x3010-0x33FF  | Unused                             |
| CMPU       | 0x3400-0x37FF | 0x3400-0x35FF  | Central Power Management Unit      |
|            |               | 0x3600-0x3687  | Unused                             |
| DBU        | 0x3800-0x3BFF | 0x3800-0x3817  | Debug Unit (UART)                  |
|            |               | 0x3900-0x3907  | Chip Debug                         |
|            |               | 0x3908-0x3BFF  | Unused                             |
| HC         | 0x3C00-0x3FFF | 0x3C00-0x3CC3  | Host Coalescing                    |
|            |               | 0x3CC4-0x3FFF  | Unused                             |
| MA         | 0x4000-0x43FF | 0x4000-0x400F  | Memory Arbiter                     |
|            |               | 0x4010-0x43FF  | Unused                             |
| ВМ         | 0x4400-0x47FF | 0x4400-0x445B  | Buffer manager                     |
|            |               | 0x445C-0x47FF  | Unused                             |

Table 103: BCM571X/BCM5720 Family Register Map (Cont.)

| Block Name    | Block Range     | Subblock Range | Description                                               |
|---------------|-----------------|----------------|-----------------------------------------------------------|
| DMAR          | 0x4800-0x4BFF   | 0x4800-0x4A13  | DMA Read                                                  |
|               |                 | 0x4A14-0x4BFF  | Unused                                                    |
| DMAW          | 0x4C00-0x4FFF   | 0x4C00-0x4C07  | DMA Write                                                 |
|               |                 | 0x4C08-0x4FFF  | Unused                                                    |
| RX-CPU        | 0x5000-0x53FF   | 0x5000-0x5037  | RX CPU                                                    |
|               |                 | 0x5038-0x53FF  | Unused                                                    |
| Open Block    | 0x5400-0x57FF   | _              | -                                                         |
| MB            | 0x5800-0x5BFF   | 0x5800-0x5903  | Low Priority Mail Box                                     |
|               |                 | 0x5903-0x5BFF  | Unused                                                    |
| FTQ           | 0x5C00-0x5FFF   | 0x5C00-0x5CFF  | Flow Through Queue                                        |
|               |                 | 0x5D00-0x5FFF  | Unused                                                    |
| MSI           | 0x6000-0x63FF   | 0x6000-0x6007  | Message Signaled Interrupt                                |
|               |                 | 0x6008-0x63FF  | Unused                                                    |
| CFG Port      | 0x6400-0x67FF   | 0x6400-0x67FF  | PCIe Core Private Registers Access to Configuration Space |
| GRC           | 0x6800-0x6BFF   | 0x6800-0x681B  | Misc Host Control                                         |
|               |                 | 0x6834-0x6843  | SEEPROM                                                   |
|               |                 | 0x6890-0x68A8  | Misc Control                                              |
|               |                 | 0x68B4-0x68DF  | Unused                                                    |
| Rserved       | 0x6C00-0x6FFF   | 0x6C00-6C37    | Unused                                                    |
|               |                 | 0x6C38-0x6FFF  | Unused                                                    |
| NVM           | 0x7000-0x73FF   | 0x7000-0x703B  | Non Volatile memory (Flash Controller)                    |
|               |                 | 0x703C-0x73FF  | Unused                                                    |
| UART          | 0x7800-0x7BFF   | 0x7800-0x781F  | Debug UART Modem                                          |
|               |                 | 0x7820-0x7BFF  | Unused                                                    |
| TL-DL-PL Port | 0x7C00-0x7FFF   | 0x7C00-0x7FFF  | PCIe Core Private Register Access to TL, DL & PL          |
|               |                 | ****           |                                                           |
| APE           | 0x10000-0x18FFF |                | APE Access                                                |
| MF            | 0x19000-0x193FF |                | Management Filters                                        |

## 13.2 PCI Configuration Registers

## 13.2.1 Device ID and Vendor ID Register (offset: 0x00)

This register is reset by hard Reset.

| Name      | Bits  | Access | Default Value | Description                                          |
|-----------|-------|--------|---------------|------------------------------------------------------|
| Device ID | 31:16 | RO     | _             | Default for BCM5717 (LAN Function 0): 0x1655         |
|           |       |        |               | Default for BCM571X/BCM5720 (LAN Function 0): 0x1656 |
| Vendor ID | 15:0  | RO     | 0x14E4        | _                                                    |

### 13.2.2 Status and Command Register (offset: 0x04)

This register is reset by PCIE Reset.

| Name                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Detected Parity Error        | 31    | RW2C   | 0x0              | When this bit is set, it indicates that the function has received a poisoned TLP                                                                                                                                                                                                                                                                                |
| Signaled System Error        | 30    | RW2C   | 0x0              | This bit is set when a function sends an ERR_FATAL or ERR_NONFATAL message and the SERR enable bit in the command register is set                                                                                                                                                                                                                               |
| Received Primary<br>Abort    | 29    | RW2C   | 0x0              | This bit is set when a requester receives a completion with UR completion status                                                                                                                                                                                                                                                                                |
| Received Target Abort        | 28    | RW2C   | 0x0              | This bit is set when a requester receives a completion with completer abort completion status.                                                                                                                                                                                                                                                                  |
| Signaled Target Abort        | 27    | RW2C   | 0x0              | This bit is set when a function acting as a completer terminates a request by issuing Completer abort completion status to the requester                                                                                                                                                                                                                        |
| DEVSEL Timing                | 26:25 | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                                                                                                          |
| Primary Data Parity<br>Error | 24    | RW2C   | 0x0              | The Primary data parity error bit is set by a requester if the parity error enable bit is set in its command register and either of the following 2 conditions occur. If the requester receives a poisoned completion if the requester poisons a write request If the parity Error enable bit is cleared, the Primary data parity error status bit is never set |
| Fast Back-to-back capable    | 23    | RO     | 0x0              | Does not apply to PCIE.                                                                                                                                                                                                                                                                                                                                         |
| Reserved                     | 22    | RO     | 0x0              | These bits are reserved and tied low per the PCI specification.                                                                                                                                                                                                                                                                                                 |
| 66 MHz Capable               | 21    | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                                                                                                          |
| Capabilities List            | 20    | RO     | 0x1              | This bit is tied high to indicate that the device supports a capability list. The list starts at address 0x40.                                                                                                                                                                                                                                                  |
| Interrupt Status             | 19    | RO     | 0x0              | Indicates this device generated an interrupt                                                                                                                                                                                                                                                                                                                    |
| Reserved                     | 18:16 | RO     | 0x0              | These bits are reserved and tied low per the PCIE specification.                                                                                                                                                                                                                                                                                                |
| Reserved                     | 15:11 | RO     | 0x00             | These bits are reserved and tied low per the PCIE specification.                                                                                                                                                                                                                                                                                                |
| Interrupt Disable            | 10    | RW     | 0x0              | When this bit is set, function is not permitted to generate IntX interrupt messages (deasserted) regardless of any internal chip logic. Setting this bit has no effect on the INT_STATUS bit below. Writing this bit to 0 will un-mask the interrupt and let it run normally.                                                                                   |
| Fast Back-to-back<br>Enable  | 9     | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                                                                                                          |

| Name                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                              |
|-----------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| System Error Enable         | 8    | RW     | 0x0              | When set, this bit enables the non fatal and fatal errors detected by the function to be reported to the Root Complex. The function reports such errors to the Root Complex if it is enabled to do so either through this bit or though PCI express specific bits in DCR |
| Stepping Control            | 7    | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                   |
| Parity Error Enable         | 6    | RW     | 0x0              | This bit enables the write to the Primary data parity error status bit. If this bit is cleared, the Primary data parity error status bit will never be set.                                                                                                              |
| VGA Palette Snoop           | 5    | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                   |
| Memory Write and Invalidate | 4    | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                   |
| Special Cycles              | 3    | RO     | 0x0              | Does not apply to PCIE                                                                                                                                                                                                                                                   |
| Bus Master                  | 2    | RW     | 0x0              | This bit controls the enabling of the bus master activity by this device. When low, it disables an Endpoint function from issuing memory or IO requests. Also disables the ability to issue MSI messages.                                                                |
| Memory Space                | 1    | RW     | 0x0              | This bit controls the enabling of the memory space. When disabled, memory transactions targeting this device return completion with UR status                                                                                                                            |
| I/O Space                   | 0    | RO     | 0x0              | This bit indicates that the device does not support I/O space access because it is zero and can not be modified. IO transactions targeting this device return completion with UR status.                                                                                 |

## 13.2.3 PCI Classcode and Revision ID Register (offset: 0x08)

This register is reset by Hard Reset.

| Name                                 | Bits | Access           | Default Value     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------|------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI Classcode                        | 31:8 | RO               | 0x020000          | Default for (LAN Function 0): 0x020000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Revision ID—All-layer<br>Revision ID | 7:4  | RO               | ASIC Rev<br>Input | This field will be updated automatically by hardware based on the External All Layer Revision ID. For example, this field will contain a value of 0x0 after hard reset for BCM571X/BCM5720 A0 silicon. Software shall use this field only to display the Device Silicon Revision ID for application where the user/customer needs to know the Device Silicon Revision ID. One such application is the B57DIAG Device Banner. Furthermore, Software (Boot Code/Driver/B57DIAG) shall NOT use this field in determining Bug Fixes. It should only use the Internal Revision ID, bits 31:24 and bits 19:16 from Register 68, for that purpose.  Ox0 for A steps Ox1 for B steps Ox2 for C steps |
| Revision ID — Metal<br>Revision ID   | 3:0  | FW-RW<br>Host-RO | ASIC Rev<br>Input | This field will be updated automatically by hardware based on the Metal Revision ID.  0x0 for metal 0 step 0x1 for metal 1 step 0x2 for metal 2 step                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## 13.2.4 BIST, Header Type, Latency Timer, Cache Line Size Register (offset: 0x0C)

| Name            | Bits  | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-------|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIST            | 31:24 | RO     | 0x0           | The 8-bit BIST register is used to initiate and report the results of any Built-In-Self-Test. This value can be written by firmware through the PCI register space BIST register to modify the read value to the host.                                                                                                                                     |
| Header Type     | 23:16 | RO     | 0x80          | The 8-bit Header Type register identifies both the layout of bytes 10h through 3Fh of the Configuration space, as well as whether this adapter contains multiple functions. A value of 0x80 indicates a multifunction device (Type 0) using the format specified in the PCI specification, while a value of 0x0 indicates a single function Type 0 device. |
| Latency Timer   | 15:8  | RO     | 0x0           | This register does not apply to PCI express and must be hardwired to zero                                                                                                                                                                                                                                                                                  |
| Cache Line Size | 7:0   | RO     | 0x0           | This field is implemented by PCIE device as a read/write field for legacy compatibility purposes.                                                                                                                                                                                                                                                          |

## 13.2.5 Base Address Register 1 (offset: 0x10)

| Name    | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|---------|------|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address | 31:4 | RW     |               | These bits set the address within a 32-bit address space that will be card will respond in. These bits may be combined with the bits in BAR_2 to create a full 64 bit address decode. Only the bits that address blocks bigger than the setting in the BAR1_SIZE value are RW. All lower bits are RO with a value of zero. This value is sticky and only reset by HARD Reset. |

| Name     | Bits | Access | Default Value | Description                                                                                                                                                                                    |
|----------|------|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prefetch | 3    | RO     | 0x1           | This bit indicates that the area mapped by BAR_1 may be pre-fetched or cached by the system without side effects. Bit can be programmed from shadow register. Path = i_cfg_func.i_cfg_private. |
| Туре     | 2:1  | RO     | 0x2           | These bits indicate that BAR_1 may be programmed to map this adapter to anywhere in the 64-bit address space. Path = i_cfg_func.i_cfg_private.                                                 |
| Space    | 0    | RO     | 0             | This bit indicates that BAR_1 maps a memory space and is always read as 0. Path = i_cfg_func.i_cfg_private.                                                                                    |

#### 13.2.6 Base Address Register 2 (offset: 0x14)

| Name    | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                  |
|---------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address | 31:0 | RW     | 0                | These bits set the address upper 32-bit address space. These bits may be combined with the bits in BAR_1 to create a full 64 bit address decode. These bits must be set to zero for the card to respond to single address cycle requests. This value is sticky and only reset by HARD Reset. |

#### 13.2.7 Base Address Register 3 (offset: 0x18)

| Name     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|----------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address  | 31:4 | RW     | 0                | These bits set the address within a 32-bit address space that will be card will respond in. These bits may be combined with the bits in BAR_4 to create a full 64 bit address decode. Only the bits that address blocks bigger than the setting in the BAR2_SIZE value are RW. All lower bits are RO with a value of zero. This value is sticky and only reset by HARD Reset. |
| Prefetch | 3    | RO     | 0x1              | This bit indicates that the area mapped by BAR_2 may be pre-fetched or cached by the system without side effects. Path = i_cfg_func.i_cfg_private.                                                                                                                                                                                                                            |
| Туре     | 2:1  | RO     | 0x2              | These bits indicate that BAR_2 may be programmed to map this adapter to anywhere in the 64-bit address space. Path = i_cfg_func.i_cfg_private.                                                                                                                                                                                                                                |
| Space    | 0    | RO     | 0                | This bit indicates that BAR_2 maps a memory space and is always read as 0. Path = i_cfg_func.i_cfg_private.                                                                                                                                                                                                                                                                   |

### 13.2.8 Base Address Register 4 (offset: 0x1c)

| Name    | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                  |
|---------|------|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address | 31:0 | RW     |               | These bits set the address upper 32-bit address space. These bits may be combined with the bits in BAR_2 to create a full 64 bit address decode. These bits must be set to zero for the card to respond to single address cycle requests. This value is sticky and only reset by HARD Reset. |

### 13.2.9 Base Address Register 5 (offset: 0x20)

The 32-bit BAR\_5 register programs the 3rd base address for the memory space mapped by the card onto the PCI bus. This register can be combined with BAR\_4 to make a 64-bit address for supporting Dual Address cycles systems. This register is not needed by Xinan and is expected to be disabled. The register is used by Everest which requires a 2nd BAR. Path = i\_cfg\_func.i\_cfg\_public.i\_cfg\_dec.

| Name     | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|----------|------|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address  | 31:4 | RW     | 0             | These bits set the address within a 32-bit address space that will be card will respond in. These bits may be combined with the bits in BAR_6 to create a full 64 bit address decode. Only the bits that address blocks bigger than the setting in the BAR3_SIZE value are RW. All lower bits are RO with a value of zero. This value is sticky and only reset by HARD Reset. |
| Prefetch | 3    | RO     | 0x1           | This bit indicates that the area mapped by BAR_3 may be pre-fetched or cached by the system without side effects. Path = i_cfg_func.i_cfg_private.                                                                                                                                                                                                                            |
| Туре     | 2:1  | RO     | 0x2           | These bits indicate that BAR_3 may be programmed to map this adapter to anywhere in the 64-bit address space. Path = i_cfg_func.i_cfg_private.                                                                                                                                                                                                                                |
| Space    | 0    | RO     | 0             | This bit indicates that BAR_3 maps a memory space and is always read as 0. Path = i_cfg_func.i_cfg_private                                                                                                                                                                                                                                                                    |

## 13.2.10 Base Address Register 6 (offset: 0x24)

The 32-bit BAR\_4 register programs the upper half of the 3nd base address for the memory space mapped by the card onto the PCI bus.

| Name    | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                                                                                           |
|---------|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address | 31:0 | RW     |               | These bits set the address upper 32-bit address space These bits may be combined with the bits in BAR_5 to create a full 64 bit address decode. These bits must be set to zero for the card to respond to single address cycle requests. This value is sticky and only reset by HARD Reset. Path = i_cfg_func.i_cfg_public.i_cfg_dec. |

## 13.2.11 Cardbus CIS Pointer Register (offset: 0x28)

This register is reset by Hard Reset.

| Name                | Bits | Access | Default Value | Description         |
|---------------------|------|--------|---------------|---------------------|
| Cardbus CIS Pointer | 31:0 | RO     | 0x0           | N/A for PCIE Device |

#### 13.2.12 Subsystem ID/Vendor ID Register (offset: 0x2C)

This register is reset by Hard Reset.

| Name                | Bits  | Access | Default Value | Description                                          |
|---------------------|-------|--------|---------------|------------------------------------------------------|
| Subsystem Device ID | 31:16 | RO     | _             | Default for BCM5717 (LAN Function 0): 0x1655         |
|                     |       |        |               | Default for BCM5719 (LAN Function 0): 0x1657         |
|                     |       |        |               | Default for BCM571X/BCM5720 (LAN Function 0): 0x1656 |
|                     |       |        |               | Default for BCM5720 (LAN Function 0): 0x165F         |
| Subsystem Vendor ID | 15:0  | RO     | 0x14E4        | Identifies board manufacturer                        |

### 13.2.13 Expansion ROM Base Address Register (offset: 0x30)

This register is reset by PCIE Reset. It becomes aN RW register if bit 5 of PCI State Register is set.

| Name                    | Bits  | Access | Default Value | Description                                                                                                                                                                                                                      |
|-------------------------|-------|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ROM Base Address        | 31:24 | RW     | 0xXXXX        | These bits indicate the address of the Expansion ROM area.                                                                                                                                                                       |
| ROM Size indication     | 23:11 | RW     | 0x00          | These bits indicate the size of the Expansion ROM area or the address of it. The boundary from RO bits to RW bits is controlled by the EXP_ROM_SIZE bits.                                                                        |
| Reserved                | 10:1  | RO     | 0x000         | These bits indicate that the Expansion ROM area is at least 2k bytes. They always read as zero. P                                                                                                                                |
| Expansion ROM<br>Enable | 0     | RW     | 0x0           | This bit indicates that the Expansion ROM BAR is valid when set to one. If it is zero, the expansion BAR should not be programmed or used. This bit will only be RW if it is enabled by the EXP_ROM_ENA bit which defaults to 0. |

### 13.2.14 Capabilities Pointer Register (offset: 0x34)

| Name                 | Bits | Access | Default Value | Description                                                                                                                                                                                                                                                 |
|----------------------|------|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved             | 31:8 | RO     | 0x0           | Unused                                                                                                                                                                                                                                                      |
| Capabilities pointer | 7:0  | RO     |               | The 8-bit Capabilities Pointer register specifies an offset in the PCI address space of a linked list of new capabilities. The capabilities are PCI-X, PCI Power Management, Vital Product Data (VPD), and Message Signaled Interrupts (MSI) are supported. |

### 13.2.15 Interrupt Register (offset: 0x3C)

| Name            | Bits  | Access | Default Value | Description                                     |  |
|-----------------|-------|--------|---------------|-------------------------------------------------|--|
| MAXIMUM_LATENCY | 31:24 | RO     | 0x00          | Hardwired to zero                               |  |
| MIN_GRANT       | 23:16 | RO     | 0x00          | Hardwired to zero                               |  |
| Interrupt Pin   | 15:8  | RO     | 0x01          | Indicates which interrupt pin this device uses: |  |
|                 |       |        |               | 0: no Interrupt                                 |  |
|                 |       |        |               | 1: Use Interrupt A                              |  |
|                 |       |        |               | 2: Use Interrupt B                              |  |
|                 |       |        |               | 3: Use Interrupt C                              |  |
|                 |       |        |               | 4: Use Interrupt D                              |  |

| Name           | Bits | Access | Default Value | Description                              |
|----------------|------|--------|---------------|------------------------------------------|
| Interrupt Line | 7:0  | RW     | 0x00          | Identifies interrupt routing information |

## 13.2.16 INT Mailbox Register (offset: 0x40-0x44)

| Name                       | Bits | Access | Default<br>Value | Description       |
|----------------------------|------|--------|------------------|-------------------|
| Indirect Interrupt mailbox | 63:0 | RW     | 0                | Interrupt Mailbox |

## 13.2.17 Power Management Capability Register (offset: 0x48)

This register is reset by hard Reset.

| Name                    | Bits  | Access      | Default Value                 | Description                                                                                                                                                                                                                            |
|-------------------------|-------|-------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PME Support             | 31:27 | RO          | 0x08 if no aux<br>0x18 if aux | Indicates the power states in which the device may assert PME. A 0 for any bit indicates that the device is not capable of asserting the PME pin signal while in that power state.                                                     |
|                         |       |             |                               | Bit 27: PME can be asserted from D0                                                                                                                                                                                                    |
|                         |       |             |                               | Bit 28: PME can be asserted from D1                                                                                                                                                                                                    |
|                         |       |             |                               | Bit 29: PME can be asserted from D2                                                                                                                                                                                                    |
|                         |       |             |                               | Bit 30: PME can be asserted from D3H                                                                                                                                                                                                   |
|                         |       |             |                               | Bit 31: PME can be asserted from D3C (default depends on the presence of Aux power)                                                                                                                                                    |
| D2 Support              | 26    | RO          | 0x0                           | Indicates whether the device supports the D2 PM state. This device does not support D2; hardwired to 0                                                                                                                                 |
| D1 Support              | 25    | RO<br>FW-RW | 0x0                           | Indicates whether the device supports the D1 PM state. This device does not support D1                                                                                                                                                 |
| Aux Current             | 24:22 | RO<br>FW-RW | 0x0                           | This device supports the data register for reporting Aux Current requirements so this field is N/A.                                                                                                                                    |
| DSI                     | 21    | RO          | 0x0                           | Indicates that the device requires device specific initialization (beyond PCI configuration header) before the generic class device driver is able to use it. This device hardwires this bit to 0 indicating that DSI is not necessary |
| Reserved                | 20    | RO          | 0x0                           | _                                                                                                                                                                                                                                      |
| PME Clock               | 19    | RO          | 0x0                           | Indicates that the device relies on the presence of the PCI clock for PME operation. This device does not require the PCI clock to generate PME. Therefore, the bit is hardwired to 0                                                  |
| Version                 | 18:16 | RO          | 0x3                           | A value of 011b indicates that this function complies with revision 1.2 of the PCI PM specification.                                                                                                                                   |
| PM Next<br>Capabilities | 15:8  | RO          | 0x58                          | Points to the next capabilities block which is Broadcom Vendor Specific Capability Header                                                                                                                                              |
| PM Capability ID        | 7:0   | RO          | 0x01                          | Identifies this item as Power management capabilities                                                                                                                                                                                  |

## 13.2.18 Power Management Control/Status Register (offset: 0x4C)

This register is reset by Hard Reset.

| Name       | Bits  | Access      | Default<br>Value | Description                                                                                                                                                                                  |
|------------|-------|-------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PM Data    | 31:24 | RO<br>FW-RW | 0x00             | Contains the power management data indicated by the Data Select field in PMCSR                                                                                                               |
| Reserved   | 23:16 | RO          | 0x00             | -                                                                                                                                                                                            |
| PME Status | 15    | RW2C        | 0x0              | This bit is set when the device asserts the WAKE signal independent of the PME enable bit. Writing 1 this bit will clear it and cause the device to stop asserting WAKE                      |
| Data Scale | 14:13 | RO          | 0x1              | Indicates the scaling factor that is used when interpreting the value of the data register (offset 7 in PM capability space). The device hardwires this value to 1 to indicate a scale of 1x |

| Name          | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Select   | 12:9 | RW     | 0x0              | Indicates which data is to be reported via the Data register (offset 7 in PM capability space)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PME Enable    | 8    | RW     | 0x1              | Enables the device to generate PME when this bit is set to 1. When 0, PME generation is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Reserved      | 7:4  | RO     | 0x00             | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| No Soft Reset | 3    | RO     | 0x1              | No_Soft_Reset When set (1), this bit indicates that devices transitioning from D3hot to D0 because of PowerState commands do not perform an internal reset. Configuration Context is preserved. Upon transition from the D3hot to the D0 Initialized state, no additional operating system intervention is required to preserve Configuration Context beyond writing the PowerState bits. When clear (0), devices do perform an internal reset upon transitioning from D3hot to D0 via software control of the PowerState bits. Configuration Context is lost when performing the soft reset. Upon transition from the D3hot to the D0 state, full reinitialization sequence is needed to return the device to D0 Initialized. Regardless of this bit, devices that transition from D3hot to D0 by a system or bus segment reset will return to the device state D0 Uninitialized with only PME context preserved if PME is supported and enabled. |
| Reserved      | 2    | RO     | 0x0              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Power State   | 1:0  | RW     | 0x0              | Indicates the current power state of the device when read.  When written, it sets the device into the specified power state  00: D0 – Select D0  01: D1 – Select D1  10: D2 – Select D2  11: D3-Hot – Select D3  These bits may be used by the system to set the power state. The register is implemented as two banks of two bits each. Can be written from both configuration space and from the PCI register space as the PM_STATE bits. When written from the PCI bus, only values of 0 and 3 are accepted. This is the register returned on reads of this register from configuration space. The second bank catches all writes values. The value of the second register is returned when the PM_STATE bits are read from register space. The idea of these registers is to a) Provide compatible operation to 5701 b) Allow implementation of other power states through firmware.                                                           |

## 13.2.19 MSI Capability Header (offset: 0x58)

The device driver is prohibited from writing to this register.

| Name                        | Bits  | Access | Default Value | Description                                                                                                                                                                                                                         |  |  |
|-----------------------------|-------|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MSI Control                 | 31:25 | RO     | 0x00          | Reserved                                                                                                                                                                                                                            |  |  |
| MSI_PVMASK_<br>CAPABLE      | 24    | RO     | 0             | This bit indicates if the function supports per vector masking. This value comes from the MSI_PV_MASK_CAP bit in the register space.                                                                                                |  |  |
| 64-bit Address<br>Capable   | 23    | RO     | 1             | Hardwired Advertise 64-bit address capable This bit indicates that the chip is capable of generating 64 bit MSI                                                                                                                     |  |  |
|                             |       |        |               | messages.                                                                                                                                                                                                                           |  |  |
| Multiple Message<br>Enable  | 22:20 | RW     | 0x0           | These bits indicate the number of message that the chip is configured (allowed) to generate. Number of allocated message:  0 1 Chip is set to generate 1 message                                                                    |  |  |
|                             |       |        |               | 1 2 Chip is set to generate 2 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 2 4 Chip is set to generate 4 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 3 8 Chip is set to generate 8 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 4 16 Chip is set to generate 16 messages                                                                                                                                                                                            |  |  |
|                             |       |        |               | 5 32 Chip is set to generate 32 messages                                                                                                                                                                                            |  |  |
| Multiple Message<br>Capable | 1 9   |        | 0x3           | These bits indicate the number of messages that the chip is capable of generating. This value comes from the bit in the register space. Number of requested message:                                                                |  |  |
|                             |       |        |               | 0 1 Chip is set to generate 1 message                                                                                                                                                                                               |  |  |
|                             |       |        |               | 1 2 Chip is set to generate 2 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 2 4 Chip is set to generate 4 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 3 8 Chip is set to generate 8 messages                                                                                                                                                                                              |  |  |
|                             |       |        |               | 4 16 Chip is set to generate 16 messages                                                                                                                                                                                            |  |  |
|                             |       |        |               | 5 32 Chip is set to generate 32 messages                                                                                                                                                                                            |  |  |
| MSI Enable                  | 16    | RW     | 0             | When this bit is set, the chip will generate MSI cycles to indicate interrupts instead of asserting the INTA# pin. When this bit is zero, the INTA# pin will be used.                                                               |  |  |
| Next Capability Pointer     | 15:8  | RO     | A0            | This value continues the PCI capability chain. Its value specified an offset in the PCI address space of the next capability. The read-only value of this register is controlled by the CAP_ENA register in the PCI register space. |  |  |
| MSI capability ID           | 7:0   | RO     | 0x5           | The 8-bit MSI Capability ID is set to 5 to indicate that the next 8 bytes are a Message Signaled Interrupt capability block.                                                                                                        |  |  |

## 13.2.20 MSI Lower Address Register (offset: 0x5C)

| Name              | Bits |    | Default<br>Value | Description       |
|-------------------|------|----|------------------|-------------------|
| MSI Lower Address | 31:2 | RW | Unknown          | MSI Lower Address |
| Reserved          | 1:0  | RO | 0                | -                 |

## 13.2.21 MSI Upper Address Register (offset: 0x60)

| Nan | ne            | Bits |    | Default<br>Value | Description       |
|-----|---------------|------|----|------------------|-------------------|
| MSI | Upper Address | 31:0 | RW | Unknown          | MSI Upper Address |

## 13.2.22 MSI Data Register (offset: 0x64)

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| MSI Data | 15:0 | RW     | Unknown          | MSI Data    |

## 13.2.23 Miscellaneous Host Control Register (offset: 0x68)

| Name                                                    | Bits  | Access | Default<br>Value | Description                                                                                                          |
|---------------------------------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------|
| ASIC Rev ID                                             | 31:28 | R      | Product ID input | 0xF: Indication that BCM571X/BCM5720 family follows new PRODUCT/REV ID mapping                                       |
|                                                         | 27:24 | R      | ASIC Rev         | External All Layer Revision ID.                                                                                      |
|                                                         |       |        | Input            | These bits will reflect in offset 8-bit mapping description:                                                         |
|                                                         |       |        |                  | 0x0: A                                                                                                               |
|                                                         |       |        |                  | 0x1: B                                                                                                               |
|                                                         |       |        |                  | 0x2: C                                                                                                               |
|                                                         | 23:16 | R      | ASIC Rev         | Metal Rev Number                                                                                                     |
|                                                         |       |        | Input            | 0x0: 0                                                                                                               |
|                                                         |       |        |                  | 0x1: 1                                                                                                               |
|                                                         |       |        |                  | 0x2: 2                                                                                                               |
| Enable TLP Minor Error Tolerance                        | 15    | RW     | 0                | Set this bit to enable TLP minor error tolerance (ATTR/TC/LOCK command)                                              |
| Log Header Overflow                                     | 14    | RW     | 0                | Set this bit to enable log header due to overflow                                                                    |
| Boundary check                                          | 13    | RW     | 0                | Set this bit to enable crossing 4 KB boundary check                                                                  |
| Byte enable Rule Check                                  | 12    | RW     | 0                | Set this bit to enable the byte enable rule check                                                                    |
| Interrupt Check                                         | 11    | RW     | 0                | Set this bit to enable the interrupt check                                                                           |
| RCB Check                                               | 10    | RW     | 0                | Set this bit to enable RCB check                                                                                     |
| Enable Tagged Status Mode                               | 9     | RW     | 0                | When set, a unique 8-bit tag value will be inserted into the Status block status tag                                 |
| Mask Interrupt Mode                                     | 8     | RW     | 0                | When set, the interrupt is masked. However, the internal interrupt state (host coalescing event) will not be cleared |
| Enable indirect access                                  | 7     | RW     | 0                | Set this bit to enable indirect addressing mode                                                                      |
| Enable Register Word Swap                               | 6     | RW     | 0                | Set this bit to enable word swapping when accessing registers through the PCI target device                          |
| Enable Clock Control register read/<br>write capability | 5     | RW     | 0                | Set this bit enable clock control register read/write capability, otherwise, the clock control register is read only |
| Enable PCI State register read/write capability         | 4     | RW     | 0                | Set this bit to enable PCI state register read/write capability, otherwise the register is read only                 |
| Enable Endian Word Swap                                 | 3     | RW     | 0                | Set this bit to enable endian word swapping when accessing through PCIE target interface                             |

| Name                    | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable Endian Byte Swap | 2    | 2 RW   | 0                | Set this bit to enable endian byte swapping when accessing through PCIE target interface.                                                                                                                                                                                                                                                         |
|                         |      |        |                  | NOTE: Setting register 0x68 bit 2 (Enable Endian Byte Swap) causes PCI configuration reads to the following registers to become swapped:  ■ 0x40  ■ 0x68 − 0x9C  ■ 0xF4 − 0xFF  This is different behavior from previous NetXtreme controllers. Reference BCM571X/BCM5720 Family errata relating to byte swap control for additional information. |
| Mask Interrupt          | 1    | RW     | 0                | Setting this bit will mask future interrupt events from being generated. Setting this bit will not clear or deassert the internal interrupt state, nor will it deassert the external interrupt state.                                                                                                                                             |
| Clear Interrupt         | 0    | WO     | 0                | Setting this bit will clear interrupt as long as the mask interrupt bit is not set. If mask interrupt bit is set, then writing 1 to this bit will not deassert interrupt, however, it will clear the internal unmasked interrupt state, so if the interrupt is later unmasked, the interrupt will deassert.                                       |

## 13.2.24 DMA Read/Write Control Register (Offset: 0x6C)

| Name                | Bits  | Access | Default<br>Value | Description                 |
|---------------------|-------|--------|------------------|-----------------------------|
| Reserved            | 31:29 | RW     | 0x0              | -                           |
| Reserved            | 28:2  | RO     | 0x00             | -                           |
| DMA write watermark | 21:19 | RW     | 7                | Watermark for DMA write.    |
|                     |       |        |                  | 0: 32B                      |
|                     |       |        |                  | 1: 64B                      |
|                     |       |        |                  | 2: 96B                      |
|                     |       |        |                  | 3:128B                      |
|                     |       |        |                  | 4:160B                      |
|                     |       |        |                  | 5:192B                      |
|                     |       |        |                  | 6:224B                      |
|                     |       |        |                  | 7:256B                      |
| Reserved            | 18:8  | RW     | 0                | _                           |
| Enable MSIX fix     | 7     | RW     | 0                | Enable msi/msix legacy fix. |

| Name                         | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                     |
|------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA read MRRS for slow speed | 6:4  | RW     | 0                | This setting is for 10/100M Ethernet DMA read MRRS. The pcie_core will accord to this value to be max DMA read length. This configuration has no effect for GIGA mode.  0: 1024B 1: 128B 2: 256B 3: 512B 4:512+256B 5:1024+512B 6:2048B 7:4096B |
| Reserved                     | 3:2  | RW     | 0                | _                                                                                                                                                                                                                                               |
| Disable_64B_cache_alignment  | 1    | RW     | 0                | Disable 64B cache alignment for DMA write to Host memory                                                                                                                                                                                        |
| Disable_32B_cache_alignment  | 0    | RW     | 0                | Disable 32B cache alignment for DMA write to Host memory                                                                                                                                                                                        |

## 13.2.25 PCI State Register (offset: 0x70)

This register is reset by PCIE Reset.

| Name                              | Bits  | Access       | Default<br>Value | Description                                                                                                                                     |
|-----------------------------------|-------|--------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                          | 31:20 | RO           | 0x0000           | -                                                                                                                                               |
| Generate reset plus               | 19    | W1<br>Read 0 | 0                | For func 1 write 1 generates 10 clock wide reset pulse reads always 0 for func 0 reserved                                                       |
| APE Program Space Write Enable    | 18    | RW           | 0                | When this bit is set the APE program space may be written.                                                                                      |
| APE Shared Memory Write Enable    | 17    | RW           | 0                | When this bit is set the APE shared memory region may be written.                                                                               |
| APE Control Register Write Enable | 16    | RW           | 0                | When this bit is set the APE control registers may be written.                                                                                  |
| Config Retry                      | 15    | RO           | 0x1              | When asserted, forces all config access to be retried.                                                                                          |
|                                   |       |              | On Hard reset    |                                                                                                                                                 |
| Reserved                          | 14:12 | RO           | 0x0              | -                                                                                                                                               |
| Max PCI Target Retry              | 11:9  | RW           | 0x1              | Indicates the number of PCI clock cycles before Retry occurs, in multiple of 8. At reset, this field is set to 001 N/A in PCIE                  |
| Flat View                         | 8     | RW           | 0x0              | Asserted if the Base Address register presents a 32 MB PCI Address map flat view, otherwise, indicates a 64 KB PCI Address map in standard view |
| VPD Available                     | 7     | RO           | 0x0              | This bit reads as 1 if the VPD region of the NVRAM can be accessed by the host                                                                  |
|                                   |       |              |                  | Comes from GRC 6808                                                                                                                             |
| PCI Expansion ROM Retry           | 6     | RW           | 0x0              | Force PCI Retry for accesses to Expansion ROM region if enabled                                                                                 |
| PCI Expansion ROM Desired         | 5     | RW           | 0x0              | Enable PCI ROM base address register to be visible to the PCI host                                                                              |
| Reserved                          | 4:0   | RO           | XXX              | -                                                                                                                                               |

## 13.2.26 Reset Counters Initial Values Register (offset: 0x74)

| Name                                                 | Bits  | Access  | Default<br>Value | Description                                                                               |
|------------------------------------------------------|-------|---------|------------------|-------------------------------------------------------------------------------------------|
| Reset Counter 5 Register<br>(PCI CLK Core Syn Reset) | 31:28 | Host RW | Any              | Keeps track of the number of Core Syn Reset that are synchronized in the PCI Clock Domain |
| Reset Counter 4 Register<br>(Hot Reset)              | 27:24 | Host RW | Any              | Keeps track of the number of Hot Reset events.                                            |
| Reset Counter 3 Register (GRC Reset)                 | 23:16 | Host RW | Any              | Keeps track of the number of GRC Reset.                                                   |
| Reset Counter 2 Register<br>(Perst Reset)            | 15:8  | Host RW | Any              | Keeps track of the number of Perst events.                                                |
| Reset Counter 1 Register (LinkDown Reset)            | 7:0   | Host RW | Any              | Keeps track of the number of LinkDown Reset events.                                       |

## 13.2.27 Register Base Register (offset: 0x78)

| Name                   | Bits  | Access | Default<br>Value | Description                                                                                                        |
|------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------|
| Reserved               | 31:18 | RO     | 0                | _                                                                                                                  |
| Register Base Register | 17:2  | RW     | X                | Local controller memory address of a register than can be written or read by writing to the register data register |
| Reserved               | 1:0   | RO     | 0                | _                                                                                                                  |

### 13.2.28 Memory Base Register (offset: 0x7C)

| Name                 | Bits  | Access | Default<br>Value | Description                                                                                                   |
|----------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------|
| Reserved             | 31:24 | RO     | 0                | _                                                                                                             |
| Memory Base Register | 23:2  | RW     | X                | Local controller memory address of the NIC memory region that can be accessed via Memory Window data register |
| Reserved             | 1:0   | RO     | 0                | _                                                                                                             |

## 13.2.29 Register Data Register (offset: 0x80)

| Name                   | Bits |    | Default<br>Value | Description                                                         |
|------------------------|------|----|------------------|---------------------------------------------------------------------|
| Register Data Register | 31:0 | RW | Х                | Register Data at the location pointed by the Register Base Register |

## 13.2.30 Memory Data Register (offset: 0x84)

| Name                 | Bits |    | Default<br>Value | Description                                                      |
|----------------------|------|----|------------------|------------------------------------------------------------------|
| Memory Base Register | 31:0 | RW | Х                | Memory value at the location pointed by the Memory Base Register |

### 13.2.31 UNDI Receive Return Ring Consumer Index Register (offset: 0x88-0x8C)

| Name                      | Bits | Access | Default<br>Value | Description                                     |
|---------------------------|------|--------|------------------|-------------------------------------------------|
| UNDI Receive Return C_Idx | 63:0 | RW     | 0                | UNDI Receive Return Ring Consumer Index Mailbox |

### 13.2.32 UNDI Send BD Producer Index Mailbox Register (offset: 0x90-0x94)

| Name                   | Bits |    | Default<br>Value | Description                             |
|------------------------|------|----|------------------|-----------------------------------------|
| UNDI Send BD NIC P_ldx | 63:0 | RW | 0                | UNDI Send BD NIC Producer Index Mailbox |

# 13.2.33 UNDI Receive BD Standard Producer Ring Producer Index Mailbox Register (offset: 0x98–0x9C)

| Name                                         | Bits |    | Default<br>Value | Description                                      |
|----------------------------------------------|------|----|------------------|--------------------------------------------------|
| UNDI Receive BD Standard Ring Producer Index | 63:0 | RW | 0                | UNDI Receive BD Std. Ring Producer Index Mailbox |

## 13.2.34 MSI-X Capabilities Registers

### 13.2.34.1 MSI-X Capability Header Register (offset: 0xA0)

| Name              | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                      |
|-------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSIX_ENABLE       | 31    | RW     | 0                | If 1 and the MSI enable bit in the MSI message control register is 0, the function is permitted to use MSIX request service and profited from using INTx# messages.  Path = i_cfg_func.i_cfg_public.i_cfg_msi_cap                                                                |
| FUNC_MASK         | 30    | RW     | 0                | If 1, all of the vectors associated with the function are masked regardless of their per vector Mask bit.  Path = i_cfg_func.i_cfg_public.i_cfg_msi_cap                                                                                                                          |
| RESERVED          | 29:27 | RO     | 0                | Reserved                                                                                                                                                                                                                                                                         |
| TABLE_SIZE        | 26:16 | RO     | 0                | System sw reads this field to determine the MSI-X table size N, which is encoded as N-1 Path = i_cfg_func.i_cfg_private                                                                                                                                                          |
| MSIX_NEXT_CAP_PTR | 15:8  | RO     | 0xac             | This value continues the PCI capability chain. Its value specified as offset in the PCI address space of the next capability. The read-only value of this register is controlled by the CAP_ENA register in the PCI register space.  Path = i_cfg_func.i_cfg_public.i_cfg_ep_reg |
| MSIX_CAP_ID       | 7:0   | RO     | 0x11             | Capability ID for MSIX Path = cfg_defs                                                                                                                                                                                                                                           |

### 13.2.34.2 MSIX\_TBL\_OFF\_BIR - 0xa4

| Name         | Bits |    | Default<br>Value | Description                                                                                                         |
|--------------|------|----|------------------|---------------------------------------------------------------------------------------------------------------------|
| TABLE_OFFSET | 31:3 | RO | 0                | Path = i_cfg_func.i_cfg_private                                                                                     |
| TABLE_BIR    | 2:0  | RO |                  | Indicates which one of functions BAR is used to map MSI-X table into memory space.  Path = i_cfg_func.i_cfg_private |

#### 13.2.34.3 MSIX\_PBA\_BIR\_OFF - 0xa8

| Name         | Bits |    | Default<br>Value | Description                                                                                                         |
|--------------|------|----|------------------|---------------------------------------------------------------------------------------------------------------------|
| TABLE_OFFSET | 31:3 | RO | 0                | Path = i_cfg_func.i_cfg_private                                                                                     |
| TABLE_BIR    | 2:0  | RO |                  | Indicates which one of functions BAR is used to map MSI-X table into memory space.  Path = i_cfg_func.i_cfg_private |

## 13.2.35 PCIe Capabilities Registers

## 13.2.35.1 PCIE\_CAPABILITY - 0xac

| Name              | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| unused0           | 31:30 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MSG_NUM           | 29:25 | RO     | 0                | Interrupt Message Number: Indicate which MSI/MSI-X vector is used for the interrupt message generated in association with any of the status bits of this capability structure. For MSI, the value in this register indicates the offset between the base Message Data and the interrupt message that is generated. For MSI-X, the value in this register indicates which MSI-X Table entry is used to generate the interrupt message. The entry must be one of the first 32 entries even if the function implements more than 32 entries.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |
| SLOT_IMPLEMENTED  | 24    | RO     | 0                | Slot Implemented. This register is not supported. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TYPE              | 23:20 | RO     | 0                | Slot Implemented. This register is not supported. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| VER               | 19:16 | RO     | 0x2              | Capability Version. PCI Express Capability structure version number. These bits are hardwired to 2h. Path= cfg_defs                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PCIE_NEXT_CAP_PTR | 15:8  | RO     | 0                | This registers contains the pointer to the next PCI capability structure.  Path= i_cfg_func.i_cfg_public.i_cfg_rd_mux                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PCIE_CAP_ID       | 7:0   | RO     | 0x10             | This register contains the PCIExpress Capability ID. Path= i_cfg_func.i_cfg_public.i_cfg_rd_mux                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 13.2.35.2 DEVICE\_CAPABILITY - 0xb0

| Name                    | Bits  | Access | Default<br>Value | Description                                                                                                                                                                               |
|-------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| unused3                 | 31:29 | RO     | 0                | -                                                                                                                                                                                         |
| FLR_CAP_SUPPORTED       | 28    | RO     | 0                | FLR capability is advertised when flr_supported bit in private device_capability register space is set.                                                                                   |
| CAPTURED_SLOT_PWR_SCALE | 27:26 | RO     | 0                | Specifies the scale used for the Slot Power Limit Value. It is set by the Set_Slot_Power_Limit Message. This field is not set for Root ports  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |
| CAPTURED_SLOT_PWR_VAL   | 25:18 | RO     | 0                | Specifies the upper limit on power supplied by slot. It is set by the Set_Slot_Power_Limit Message. This field is not set for Root ports.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap    |
| unused2                 | 17:16 | RO     | 0                | -                                                                                                                                                                                         |
| ROLE_BASED_ERR_RPT      | 15    | RO     | 0x1              | Indicate device is conforming to the ECN, PCI Express Base Specification, Revision 1.1., or subsequent PCI Express Base Specification revisions. Path= i_cfg_func.i_cfg_private           |
| unused1                 | 14:12 | RO     | 0                | _                                                                                                                                                                                         |
| L1_ACCEPTABLE_LATENCY   | 11:9  | RO     | 0x6              | Endpoint L1 Acceptable Latency. These bits are programmable through register space. The bits should be 0 for Root ports.  Path= i_cfg_func.i_cfg_private                                  |
| L0S_ACCEPTABLE_LATENCY  | 8:6   | RO     | 0x6              | Endpoint L0s Acceptable Latency. These bits are programmable through register space. The value should be 0 for root ports.  Path= i_cfg_func.i_cfg_private                                |
| EXTENDED_TAG_SUPPORT    | 5     | RO     | 0                | Extended Tag Field Support. This bit is programmable through register space. This capability is not currently supported.  Path= i_cfg_func.i_cfg_private                                  |
| unused0                 | 4:3   | RO     | 0                |                                                                                                                                                                                           |
| MAX_PL_SIZE_SUPPORTED   | 2:0   | RO     | 0x1              | Max Payload Size Supported. These bits are programmable from the register space and default value is based on define in version.v file. Path= i_cfg_func.i_cfg_private                    |

## 13.2.35.3 DEVICE\_STATUS\_CONTROL - 0xb4

| Name                  | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                            |
|-----------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Unused1               | 31:22 | RO     | 0                | -                                                                                                                                                                                                                                      |
| NP_TRANSACTION_PEND   | 21    | RO     | 0                | This is bit is read back a 1, whenever a non-posted request initiated by PCIE core is pending to be completed. Path= i_tl_top                                                                                                          |
| AUX_PWR_DET           | 20    | RO     | 0x1              | This bit is the current state of the VAUX_PRSNT pin of the device. When it is '1', it is indicating that part needs VAUX and detects the VAUX is present. Path= input to pcie_vaux_pipe                                                |
| UNSUP_REQ_DET         | 19    | WC     | 0                | UnSupported Request Detected. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                             |
| FATAL_ERR_DET         | 18    | WC     | 0                | Fatal Error Detected. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                                     |
| NON_FATAL_ERR_DET     | 17    | WC     | 0                | Non-Fatal Error Detected. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                                 |
| CORR_ERR_DET          | 16    | WC     | 0                | Correctable Error Detected. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                               |
| FLR_INITIATED         | 15    | RW     | 0                | Initiate Function Level reset. This bit is writeable only if flr_supported bit in private device_capability register is set. A write of 1 to this bit initiates Function Level Reset. The value read by s/w from this bit is always 0. |
| MAX_READ_REQ_SIZ      | 14:12 | RW     | 0                | Maximum Read Request Size. Depending on the spec, internal logic uses either the min or the max of the value of the two functions.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                       |
| NO_SNOOP_ENABLE       | 11    | RW     | 0x1              | Enable No Snoop. When this bit is set to 1, PCIE initiates a read request with the No Snoop bit in the attribute field set for the transactions that request the No Snoop attribute. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.      |
| AUX_PWR_PM_ENA        | 10    | RW     | 0x1              | This bit when set enables device to draw aux power independent of PME AUX power Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                           |
| Unused0               | 9     | RO     | 0                | -                                                                                                                                                                                                                                      |
| EXTENDED_TAG_EN       | 8     | RO     | 0                | Extended Tag Field Enable. This capability is not supported. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                              |
| MAX_PAYLOAD_SIZE      | 7:5   | RW     | 0                | Max Payload Size. Depending on the spec, internal logic uses either the min or the max of the value of the two functions. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                 |
| RELAX_ORDERING_ENABLE | 4     | RW     | 0x1              | Relax Ordering Enable. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                                    |
| U_REQ_REPORT_EN       | 3     | RW     | 0:pr             | Unsupported Request Reporting Enable. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                     |
| FATAL_ERR_REPORT_EN   | 2     | RW     | 0:pr             | Fatal Error Reporting Enable. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                             |
| NFATAL_ERR_REPORT_EN  | 1     | RW     | 0:pr             | Non-Fatal Error Reporting Enable. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                         |
| CORR_ERR_REPORT_EN    | 0     | RW     | 0:pr             | Correctable Error Reporting Enable. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap.                                                                                                                                                       |

#### 13.2.35.4 LINK\_CAPABILITY - 0xb8

| Name            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PORT_NUMBER     | 31:24 | RO     | 0                | PCIE Port Number. These bits are programmable through register. Path= i_cfg_func.i_cfg_private                                                                                                                                                                                                                                                                                                      |
| Unused0         | 23:22 | RO     | 0                | _                                                                                                                                                                                                                                                                                                                                                                                                   |
| LINK_BW_NOTIFY  | 21    | RO     | 0                | Link Bandwidth Notification Capability: RC: A value of 1b indicates support for the Link Bandwidth Notification status and interrupt mechanisms. This capability is required for all Root Ports and Switch Downstream Ports supporting Links wider than x1 and/or multiple Link speeds. RC: Field is implemented. EP: Not supported and hardwired to 0. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |
| DL_ACTIVE_REP   | 20    | RO     | 0                | Data Link Layer Link Active Reporting Capable: RC: this bit must be hardwired to 1b if the component supports the optional capability of reporting the DL_Active state of the Data Link Control and Management State Machine. RC: Implemented (RW) for RC. Default to 0. EP: Not supported and hardwired to 0.  Path= i_cfg_func.i_cfg_private                                                      |
| SUR_DWN_ERR_REP | 19    | RO     | 0                | Surprise Down Error Reporting Capable: RC: this bit must be set if the component supports the optional capability of detecting and reporting a Surprise Down error condition. RC: Not supported and hardwired to 0.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                    |
| CLK_PWR_MGMT    | 18    | RO     | 0x1              | Clock Power Management. These bits are programmable through register. The feature itself has to be enabled in version.v  Path= i_cfg_func.i_cfg_private                                                                                                                                                                                                                                             |

| Name        | Bits             | Access   | Default<br>Value  | Description                                                                                                                                                                                                                              |                                                                                                                     |                                                                                 |  |  |
|-------------|------------------|----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|--|
| L1_EXIT_LAT | 17:15            | 5 RO 0x2 |                   | L1 Exit Latency. These bits are programmable through register space.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap Depending on whether device is in common clock mode or not, the value reflected by these bits is one of the following. |                                                                                                                     |                                                                                 |  |  |
|             |                  |          |                   | Value                                                                                                                                                                                                                                    | Name                                                                                                                | Description                                                                     |  |  |
|             |                  |          |                   | 1                                                                                                                                                                                                                                        | 1_2                                                                                                                 | L1 exit latency of 1 us to 2 us.                                                |  |  |
|             |                  |          |                   | 2                                                                                                                                                                                                                                        | 2_4                                                                                                                 | L1 exit latency of 2 us to 4 us.                                                |  |  |
|             |                  |          |                   | 255                                                                                                                                                                                                                                      | _                                                                                                                   | end_of_table                                                                    |  |  |
|             |                  |          | whether reflected | device is in<br>by these bi                                                                                                                                                                                                              | efg_public.i_cfg_exp_cap Depending on common clock mode or not, the value its is one of the following.  Description |                                                                                 |  |  |
|             |                  |          |                   | 4                                                                                                                                                                                                                                        | 0_1                                                                                                                 | L0s exit latency of 512 ns to 1 us.                                             |  |  |
|             |                  |          |                   | 5                                                                                                                                                                                                                                        | 1_2                                                                                                                 | L0s exit latency of 1 us to 2 us.                                               |  |  |
|             |                  |          |                   | 255                                                                                                                                                                                                                                      | _                                                                                                                   | end_of_table                                                                    |  |  |
| ASPM SUPT   | // SUPT 11:10 RO | 0x3      | space.            | upport. The                                                                                                                                                                                                                              | se bits are programmable through reg                                                                                |                                                                                 |  |  |
| _           |                  |          |                   | Value                                                                                                                                                                                                                                    | Name                                                                                                                | Description                                                                     |  |  |
|             |                  |          |                   | 0                                                                                                                                                                                                                                        | RES_0                                                                                                               | Reserved                                                                        |  |  |
|             |                  |          |                   | 1                                                                                                                                                                                                                                        | LOS                                                                                                                 | L0s entry supported                                                             |  |  |
|             |                  |          |                   | 2                                                                                                                                                                                                                                        | RES_2                                                                                                               |                                                                                 |  |  |
|             |                  |          |                   | 3                                                                                                                                                                                                                                        | L0S_L1                                                                                                              | L0s and L1 supported                                                            |  |  |
|             |                  |          |                   | 255                                                                                                                                                                                                                                      | _                                                                                                                   | end_of_table                                                                    |  |  |
|             |                  |          |                   |                                                                                                                                                                                                                                          |                                                                                                                     | fg_private Value used by internal logic is<br>llue programmed for each function |  |  |

| Name           | Bits | Access | Value | Description | on   |              |
|----------------|------|--------|-------|-------------|------|--------------|
| MAX_LINK_SPEED | 3:0  | RO     | 0x1   |             |      |              |
|                |      |        |       | Value       | Name | Description  |
|                |      |        |       | 0           | 64   | 64 Bytes     |
|                |      |        |       | 1           | 128  | 128 Bytes    |
|                |      |        |       | 255         | _    | end_of_table |

# 13.2.35.5 LINK\_STATUS\_CONTROL - 0xbc

| Name                | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Unused3             | 31:30 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                |
| DL_ACTIVE           | 29    | RO     | 0                | Data Link Layer Link Active: returns a 1b to indicate the DL_Active state, 0b otherwise. Not implemented and hardwire to 0.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                         |
| SLOT_CLK_CONFIG     | 28    | RO     | 0x1              | Slot Clock configuration. This bit is read-only by host, but read/write via backdoor CS bus. Path= i_cfg_func.i_cfg_private                                                                                                                                                                                                                                                                      |
| LINK_TRAINING       | 27    | RO     | 0                | EP: This bit is N/A and is hardwired to 0. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                                                                                                           |
| Unused2             | 26    | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                |
| NEG_LINK_WIDTH      | 25:20 | RO     | 0                | Negotiated Link Width. These bits indicate the negotiated link width of the PCI Express link. Path= i_pl_top.i_pl_ltssm                                                                                                                                                                                                                                                                          |
| NEG_LINK_SPEED      | 19:16 | RO     | 0                | Link Speed. These bits indicate the negotiated link speed of the PCI Express link.  Path= i_pl_top.i_pl_ltssm                                                                                                                                                                                                                                                                                    |
| Unused1             | 15:12 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                |
| LINK_BW_INT_EN      | 11    | RO     | 0                | Link Autonomous Bandwidth Interrupt Enable: When Set, this bit enables the generation of an interrupt to indicate that the Link Autonomous Bandwidth Status bit has been Set. RC: Not implemented and hardwired to 0. EP: N/A and hardwired to 0 Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                     |
| LINK_BW_MGMT_INT_EN | 10    | RO     | 0                | Link Bandwidth Management Interrupt Enable: when Set, this bit enables the generation of an interrupt to indicate that the Link Bandwidth Management Status bit has been Set. RC: N/A and hardwired to 0. EP: Not implemented and hardwired to 0. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                    |
| HW_AUTO_WIDTH_DIS   | 9     | RO     | 0                | Hardware Autonomous Width Disable: When Set, this bit disables hardware from changing the Link width for reasons other than attempting to correct unreliable Link operation by reducing Link width. Other functions are reserved. RC: Not applicable and hardwire to 0 EP: If supported, only apply to function0. Not implemented and hardwire to 0. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |

| Name                 | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                        |                              |                                                                                                                                    |  |  |  |
|----------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| EN_CLK_PW_MGMT       | 8    | RW     | 0                | Enable Clock Power Management: RC: N/A and hardwire 0. EP: When this bit is set, the device is permitted to use CLKREQ# signal to power management. Feature is enable through version.v define Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                         |                              |                                                                                                                                    |  |  |  |
| LINK_CR_EXT_SYNC     | 7    | RW     | 0                | Extended Synch. This bit when set forces the transmission of 4096 FTS ordered sets in the L0s state followed by a single SKP ordered set prior to entering the L0 state, and the transmission of 1024 TS1 ordered sets in the L1 state prior to entering the Recovery state. Value used by logic is resolved to 1 if either function has this bit set. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |                              |                                                                                                                                    |  |  |  |
| LINK_CR_COMMON_CLK   | 6    | RW     | 0                | Common Clock Configuration. Value used by logic is resolved to 1 only if both functions (when enabled) have this bit set. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                              |                              |                                                                                                                                    |  |  |  |
| CFG_PSM_RETRAIN_LINK | 5    | RO     | 0                | Requesting PHY to retrain the link. This bit is only applicable to RC. So for EP it is read only bit. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                                                  |                              |                                                                                                                                    |  |  |  |
| CFG_PSM_LINK_DISABLE | 4    | RO     | 0                | Requesting PHY to disable the link. This bit is only applicable to RC. So for EP it is read only bit.  Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                                                                                                                 |                              |                                                                                                                                    |  |  |  |
| RCB                  | 3    | RW     | 0                |                                                                                                                                                                                                                                                                                                                                                                                                    | ompletion Bo<br>cfg_func.i_c | oundary.<br>fg_public.i_cfg_exp_cap                                                                                                |  |  |  |
|                      |      |        |                  | Value                                                                                                                                                                                                                                                                                                                                                                                              | Name                         | Description                                                                                                                        |  |  |  |
|                      |      |        |                  | 0                                                                                                                                                                                                                                                                                                                                                                                                  | 64                           | 64 Bytes                                                                                                                           |  |  |  |
|                      |      |        |                  | 1                                                                                                                                                                                                                                                                                                                                                                                                  | 128                          | 128 Bytes                                                                                                                          |  |  |  |
|                      |      |        |                  | 255                                                                                                                                                                                                                                                                                                                                                                                                | _                            | end_of_table                                                                                                                       |  |  |  |
| Unused0              | 2    | RO     | 0                | _                                                                                                                                                                                                                                                                                                                                                                                                  |                              |                                                                                                                                    |  |  |  |
| ASPM_CTRL            | 1:0  | RW     | 0                | of this bi                                                                                                                                                                                                                                                                                                                                                                                         | t for each er<br>med powers  | e used by logic is dependent on the value<br>habled function and also on the<br>state of each function.<br>fg_public.i_cfg_exp_cap |  |  |  |

# 13.2.35.6 SLOT\_CAPABILITY - 0xc0

| Name                   | Bits  |    | Default<br>Value | Description     |
|------------------------|-------|----|------------------|-----------------|
| PHYSICAL_SLOT_NUMBER   | 31:19 | RO | 0                | Not implemented |
| UNUSED                 | 18:17 | RO | 0                | Not implemented |
| SLOT_POWER_LIMIT_SCALE | 16:15 | RO | 0                | Not implemented |
| SLOT_POWER_LIMIT_VALUE | 14:7  | RO | 0                | Not implemented |
| UNUSED_2               | 6:0   | RO | 0                | Not implemented |

#### 13.2.35.7 SLOT\_CONTROL\_STATUS - 0xc4

| Name            | Bits  | Access | Default<br>Value | Description     |
|-----------------|-------|--------|------------------|-----------------|
| SLOT_STATUS     | 31:23 | RO     | 0                | Not implemented |
| PRESENCE_DETECT | 22    | RO     | 0                | Not implemented |
| UNUSED_1        | 21:16 | RO     | 0                | Not implemented |
| SLOT_CONTROL    | 15:0  | RO     | 0                | Not implemented |

#### 13.2.35.8 ROOT\_CAP\_CONTROL - 0xc8

This register is not applicable for EP and hardwired to 0.

| Name   | Bits |    | Default<br>Value | Description |
|--------|------|----|------------------|-------------|
| Unused | 31:0 | RO | 0                | _           |

#### 13.2.35.9 ROOT\_STATUS - 0xcc

This register is not applicable for EP and hardwired to 0.

| Name   | Bits |    | Default<br>Value | Description |
|--------|------|----|------------------|-------------|
| Unused | 31:0 | RO | 0                | _           |

#### 13.2.35.10 DEVICE\_CAPABILITY\_2 - 0xd0

| Name                              | Bits  | Access | Default<br>Value | Description                                                                                                                                                                     | ı    |                       |  |  |  |  |
|-----------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|--|--|--|--|
| Unused1                           | 31:12 | RO     | 0                | _                                                                                                                                                                               | _    |                       |  |  |  |  |
| LTR_MECHANISM_SUPPORTED           | 11    | RO     | 0                | Latency Tolerance Reporting Mechanism Supported, Programmable through register space. This field will read 1, when bit 5 of ext_cap_ena field in private register space is set. |      |                       |  |  |  |  |
| Unused0                           | 10:5  | RO     | 0                | _                                                                                                                                                                               |      |                       |  |  |  |  |
| CMPL_TIMEOUT_DISABL_<br>SUPPORTED | 4     | RO     | 0x1              | Completion Timeout Disable Supported, Programmable through register space Path= i cfg func.i cfg private                                                                        |      |                       |  |  |  |  |
| CMPL_TIMEOUT_RANGES_<br>SUPPORTED | 3:0   | RO     | 0xf              | Completion Timeout Ranges Supported. Programmable through register space Path= i_cfg_func.i_cfg_private                                                                         |      |                       |  |  |  |  |
|                                   |       |        |                  | Value                                                                                                                                                                           | Name | Description           |  |  |  |  |
|                                   |       |        |                  | 15                                                                                                                                                                              | ABCD | Ranges A, B, C, and D |  |  |  |  |
|                                   |       |        |                  | 255                                                                                                                                                                             | _    | end_of_table          |  |  |  |  |
|                                   |       |        |                  |                                                                                                                                                                                 |      |                       |  |  |  |  |

## 13.2.35.11 DEVICE\_STATUS\_CONTROL2 - 0xd4

| Name                 | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                          |
|----------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DEVICE_STATUS_2      | 31:16 | RO     | 0                | Placeholder for Gen2                                                                                                                                                                                                                 |
|                      |       |        |                  | Path= i_cfg_func.i_cfg_public.i_cfg_rd_mux                                                                                                                                                                                           |
| Unused               | 15:11 | RO     | 0                | _                                                                                                                                                                                                                                    |
| LTR_MECHANISM_ENABLE | 10    | RW     | 0                | Latency Tolerance Reporting Mechanism Enable, This field is writeable, when bit 5 of ext_cap_ena field in private register space is set. This bit is RW only in function 0 and is RsvdP for all other functions.                     |
| IDO_CPL_ENABLE       | 9     | RW     | 0                | IDO Completion Enable, This field is writeable, when bit ido_supported bit of private device_capability_2 register is set. When this bit is set, function is permitted to set ID based Ordering Attribute of Completions it returns. |
| IDO_REQ_ENABLE       | 8     | RW     | 0                | IDO Request Enable, This field is writeable, when bit ido_supported bit of private device_capability_2 register is set. When this bit is set, function is permitted to set ID based Ordering Attribute of Requests it initiates.     |
| Unused0              | 7:5   | RO     | 0                | -                                                                                                                                                                                                                                    |
| CMPL_TIMEOUT_DISABLE | 4     | RW     | 0                | Completion Timeout Disable Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap                                                                                                                                                               |

| Name               | Bits | Access | Default<br>Value | Descripti | on    |              |
|--------------------|------|--------|------------------|-----------|-------|--------------|
| CMPL_TIMEOUT_VALUE | 3:0  | RW     | 0                |           |       |              |
|                    |      |        |                  | Value     | Name  | Description  |
|                    |      |        |                  | 0         | 50MS  | 50ms         |
|                    |      |        |                  | 1         | 100US | 100us        |
|                    |      |        |                  | 2         | 10MS  | 10ms         |
|                    |      |        |                  | 3         | 55MS  | 55ms         |
|                    |      |        |                  |           | 4     | 210MS        |
|                    |      |        |                  | 5         | 900MS | 900ms        |
|                    |      |        |                  | 6         | 3_5S  | 3.5s         |
|                    |      |        |                  |           | 13S   | 13s          |
|                    |      |        |                  | 8 64S 64s | 64s   |              |
|                    |      |        |                  | 255       | _     | end_of_table |

#### 13.2.35.12 LINK\_CAPABILITY\_2 - 0xd8

| Name              | Bits |    | Default<br>Value | Description                                         |
|-------------------|------|----|------------------|-----------------------------------------------------|
| LINK_CAPABILITY_2 | 31:0 | RO | 0                | Placeholder for Gen2 Path= i_cfg_func.i_cfg_private |

#### 13.2.35.13 LINK\_STATUS\_CONTROL\_2 - 0xdc

This register will be Read only by default, and will read all 0's to allow compliance with PCIE spec 1.1. To enable this register, reset comply\_pcie\_1\_1 bit in the register space to 0.

| Name                         | Bits  | Access | Default<br>Value | Description                                                            |
|------------------------------|-------|--------|------------------|------------------------------------------------------------------------|
| LINK_STATUS_2                | 31:17 | RO     | 0                | Placeholder for Gen2                                                   |
| CURR_DEEMPH_LEVEL            | 16    | RO     | 0                | curr_deemph_level Path = pl_top                                        |
| Unused0                      | 15:13 | RO     | 0                | -                                                                      |
| CFG_COMPLIANCE_DEEMPH        | 12    | RW     | 0                | Compliance De-emphasis. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap    |
| CFG_COMPLIANCE_SOS           | 11    | RW     | 0                | Compliance SOS. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap            |
| CFG_ENTER_MOD_<br>COMPLIANCE | 10    | RW     | 0                | Enter Modified Compliance. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap |

| Name                  | Bits | Access | Default<br>Value | Descript                                                                                                                                                                                                               | ion          |                                                                                                                                  |             |  |
|-----------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------|-------------|--|
| CFG_TX_MARGIN         | 9:7  | RW     | 0                | Controls the value of non de-emphasized voltage level at the TX pins. Path= i_cfg_func.i_cfg_public.i_cfg_exp_cap Value used by logic is resolved to the smaller binary value, if two functions have different values. |              |                                                                                                                                  |             |  |
|                       |      |        |                  | Value                                                                                                                                                                                                                  | Name         | Description                                                                                                                      |             |  |
|                       |      |        |                  | 0                                                                                                                                                                                                                      | 000          | 800 – 1200 mV for full swing and<br>400 – 600 mV for half swing.                                                                 |             |  |
|                       |      |        |                  | 1                                                                                                                                                                                                                      | 001          | Values will be monotonic with non zero Slope                                                                                     |             |  |
|                       |      |        |                  | 2                                                                                                                                                                                                                      | 010          | Values will be monotonic with non zero Slope                                                                                     |             |  |
|                       |      |        |                  | 3                                                                                                                                                                                                                      | 011          | 200 – 400 mV for full swing and<br>100 – 200 mV for half swing                                                                   |             |  |
|                       |      |        |                  | 4                                                                                                                                                                                                                      | 100          | Reserved                                                                                                                         |             |  |
|                       |      |        |                  | 5                                                                                                                                                                                                                      | 101          | Reserved                                                                                                                         |             |  |
|                       |      |        |                  | 6                                                                                                                                                                                                                      | 110          | Reserved                                                                                                                         |             |  |
|                       |      |        |                  | 7                                                                                                                                                                                                                      | 111          | Reserved                                                                                                                         |             |  |
|                       |      |        | 255              | _                                                                                                                                                                                                                      | end_of_table |                                                                                                                                  |             |  |
| SEL_DEEMPHASIS        | 6    | RW     | 0                | emphasis                                                                                                                                                                                                               | s. Path= i_c | ng at Gen2 rates, this bit selects the le<br>ofg_func.i_cfg_public.i_cfg_exp_cap Va<br>to 1 if either function has this bit set. |             |  |
|                       |      |        |                  | Value                                                                                                                                                                                                                  | Name         | Description                                                                                                                      |             |  |
|                       |      |        |                  | 0                                                                                                                                                                                                                      | 0            | _                                                                                                                                |             |  |
|                       |      |        |                  | 1                                                                                                                                                                                                                      | 1            | _                                                                                                                                |             |  |
|                       |      |        |                  | 255                                                                                                                                                                                                                    | _            | _                                                                                                                                |             |  |
|                       |      |        |                  |                                                                                                                                                                                                                        |              |                                                                                                                                  |             |  |
| HW_AUTO_SPEED_DISABLE | 5    | RO     | 0                |                                                                                                                                                                                                                        |              | nardwired to 0.<br>fg_public.i_cfg_exp_cap                                                                                       |             |  |
| ENTER_COMPLIANCE      | 4    | RW     | 0                | logic is s                                                                                                                                                                                                             | et when eitl | enter compliance mode. Value used b<br>ner function has this bit enabled.<br>sfg_public.i_cfg_exp_cap                            | oy internal |  |

| Name              | Bits | Access | Default<br>Value | Description | on                             |                             |
|-------------------|------|--------|------------------|-------------|--------------------------------|-----------------------------|
| TARGET_LINK_SPEED | 3:0  | RW     | 0x1              |             | t of link spee<br>g_func.i_cfg | ed<br>_public.i_cfg_exp_cap |
|                   |      |        |                  | Value       | Name                           | Description                 |
|                   |      |        |                  | 0           | 2_5                            | 2.5 Gbps                    |
|                   |      |        |                  | 1           | 5_0                            | 5.0 Gbps                    |
|                   |      |        |                  | 255         | _                              | end of table                |

#### 13.2.35.14 SLOT\_CAPABILITY\_2 - 0xe0

| Name              | Bits | Access | Default<br>Value | Description     |
|-------------------|------|--------|------------------|-----------------|
| SLOT_CAPABILITY_2 | 31:0 | RO     | 0                | Not implemented |

#### 13.2.35.15 SLOT\_STATUS\_CONTROL\_2 - 0xe4

| Name           | Bits  | Access | Default<br>Value | Description     |
|----------------|-------|--------|------------------|-----------------|
| SLOT_STATUS_2  | 31:16 | RO     | 0                | Not implemented |
| SLOT_CONTROL_2 | 15:0  | RO     | 0                | Not implemented |

# 13.2.36 Product ASIC ID (offset: 0xF4)

| Name            | Bits | Access | Default<br>Value | Description                       |
|-----------------|------|--------|------------------|-----------------------------------|
| Product ASIC ID | 31:0 | RO     |                  | For 5717 B0, value is 0x05717100: |
|                 |      |        |                  | ■ 5718 A0, value is 0x05717000    |
|                 |      |        |                  | ■ 5718 B0, value is 0x05717100    |
|                 |      |        |                  | ■ 5719 A0, value is 0x05719000    |
|                 |      |        |                  | ■ 5719 A1, value is 0x05719100    |
|                 |      |        |                  | ■ 5720 AO, value is 0x05720000    |

# 13.2.37 Advanced Error Reporting Enhanced Capability Header (offset: 0x100)

| Name                               | Bits  | Access | Default<br>Value | Description                                                                 |
|------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------|
| PCI Express Extended Capability ID | 15:0  | RO     | 0x0001           | Extended Capability ID for the Advanced Error Reporting Capability is 0001h |
| Capability Version                 | 19:16 | RO     | 0x1              | -                                                                           |
| Next Capability Offset             | 31:20 | RO     | 0x13C            | Pointer to the Virtual Channel Capability Structure                         |

## 13.2.38 Uncorrectable Error Status Register (offset: 0x104)

This register is reset by Hard Reset.

| Name                               | Bits  | Access | Default<br>Value | Description                                                 |
|------------------------------------|-------|--------|------------------|-------------------------------------------------------------|
| Reserved                           | 31:21 | RO     | 0                | -                                                           |
| Unsupported Request Error Status   | 20    | RW1CS  | 0                | This bit is set when an unsupported request error occurs.   |
| ECRC Error Status                  | 19    | RW1CS  | 0                | This bit is set when an ECRC error occurs                   |
| Malformed TLP Status               | 18    | RW1CS  | 0                | This bit is set when a Malformed TLP error occurs.          |
| Receiver Overflow Status           | 17    | RW1CS  | 0                | This bit is set when a Receiver Overflow error occurs.      |
| Unexpected Completion Status       | 16    | RW1CS  | 0                | This bit is set when an Unexpected Completion error occurs. |
| Completer Abort Status             | 15    | RW1CS  | 0                | This bit is set when a completer Abort error occurs.        |
| Completion Timeout Status          | 14    | RW1CS  | 0                | This bit is set when completion timeout error occurs.       |
| Flow control Protocol Error Status | 13    | RW1CS  | 0                | This bit is set when a Flow control protocol error occurs.  |
| Poisoned TLP Status                | 12    | RW1CS  | 0                | This bit is set when a Poisoned TLP error occurs            |
| Reserved                           | 11:5  | RO     | 0                | -                                                           |
| Data Link Protocol Error Status    | 4     | RW1CS  | 0                | This bit is set when a Data Link Protocol error occurs.     |
| Reserved                           | 3:0   | RO     | 0                | -                                                           |
| Training Error Status              | 0     | RW1CS  | 0                | This bit is set when a training error occurs.               |

# 13.2.39 Uncorrectable Error Mask Register (offset: 0x108)

This register is reset by Hard Reset.

| Name                             | Bits  | Access | Default<br>Value | Description                                             |
|----------------------------------|-------|--------|------------------|---------------------------------------------------------|
| Reserved                         | 31:21 | RO     | 0                | -                                                       |
| Unsupported Request Error Mask   | 20    | RWS    | 0                | Setting this bit will mask Unsupported Request Error.   |
| ECRC Error Mask                  | 19    | RWS    | 0                | Setting this bit will mask ECRC error.                  |
| Malformed TLP Mask               | 18    | RWS    | 0                | Setting this bit will mask Malformed TLP error.         |
| Receiver Overflow Mask           | 17    | RWS    | 0                | Setting this bit will mask Receiver overflow error.     |
| Unexpected Completion Mask       | 16    | RWS    | 0                | Setting this bit will mask unexpected completion error. |
| Completer Abort Mask             | 15    | RWS    | 0                | Setting this bit will mask completer abort error        |
| Completion Timeout Mask          | 14    | RWS    | 0                | Setting this bit will mask completion timeout error.    |
| Flow Control Protocol Error Mask | 13    | RWS    | 0                | Setting this bit will mask flow control protocol error. |
| Poisoned TLP Mask                | 12    | RWS    | 0                | Setting this bit will mask poisoned TLP error.          |
| Reserved                         | 11:5  | RO     | 0                | -                                                       |
| Data Link Protocol Error Mask    | 4     | RWS    | 0                | Setting this bit will mask data link protocol error.    |
| Reserved                         | 3:1   | RO     | 0                | -                                                       |
| Training Error Mask              | 0     | RWS    | 0                | Setting this bit will mask training error.              |

# 13.2.40 Uncorrectable Error Severity Register (offset: 0x10C)

This register is reset by Hard Reset.

| Name                                    | Bits  | Access | Default<br>Value | Description                                           |
|-----------------------------------------|-------|--------|------------------|-------------------------------------------------------|
| Reserved                                | 31:21 | RO     | 0                | -                                                     |
| Unsupported Request Error<br>Severity   | 20    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| ECRC Error Severity                     | 19    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Malformed TLP Severity                  | 18    | RWS    | 1                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Receiver Overflow Error Severity        | 17    | RWS    | 1                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Unexpected completion Error<br>Severity | 16    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Completer Abort Error Severity          | 15    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Completion Timeout Error<br>Severity    | 14    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Flow control Protocol Error<br>Severity | 13    | RWS    | 1                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Poisoned TLP Severity                   | 12    | RWS    | 0                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Reserved                                | 11:4  | RO     | 0                | -                                                     |
| Surprise down error severity            | 5     | RO     | 1                | Pcie 1.1 spec page 409                                |
| Data Link Protocol Error Severity       | 4     | RWS    | 1                | This bit controls the severity 0 = nonfatal 1 = fatal |
| Reserved                                | 3:1   | RO     | 0                | -                                                     |
| Training Error Severity                 | 0     | RWS    | 1                | This bit controls the severity 0 = nonfatal 1 = fatal |

# 13.2.41 Correctable Error Status Register (offset: 0x110)

| Name                           | Bits  | Access | Default<br>Value | Description                                               |
|--------------------------------|-------|--------|------------------|-----------------------------------------------------------|
| Reserved                       | 31:14 | RO     | 0                | -                                                         |
| Advisory Nonfatal Error Status | 13    | RO     | 0                | This bit is set when an Advisory Nonfatal error occurs.   |
| Replay Timer Timeout Status    | 12    | RW1CS  | 0                | This bit is set when a Replay Timer Timeout error occurs. |
| Reserved                       | 11:9  | RO     | 0                | -                                                         |
| REPLAY_NUM Rollover Status     | 8     | RW1CS  | 0                | This bit is set when a REPLAY_NUM Rollover error occurs.  |
| Bad DLLP Status                | 7     | RW1CS  | 0                | This bit is set when a Bad DLLP error occurs.             |
| Bad TLP Status                 | 6     | RW1CS  | 0                | This bit is set when a Bad TLP error occurs.              |
| Reserved                       | 5:1   | RO     | 0                | _                                                         |
| Receiver Error Status          | 0     | RW1CS  | 0                | This bit is set when a Receiver error occurs.             |

# 13.2.42 Correctable Error Mask Register (offset: 0x114)

| Name                         | Bits  | Access | Default<br>Value | Description                                         |
|------------------------------|-------|--------|------------------|-----------------------------------------------------|
| Reserved                     | 31:14 | RO     | 0                | -                                                   |
| Advisory Nonfatal Error Mask | 13    | RWS    | 1                | Setting this bit masks Advisory Nonfatal errors.    |
| Replay Timer Timeout Mask    | 12    | RWS    | 0                | Setting this bit masks Replay Timer Timeout errors. |
| Reserved                     | 11:9  | RO     | 0                | -                                                   |
| REPLAY_NUM Rollover Mask     | 8     | RWS    | 0                | Setting this bit masks REPLAY_NUM Rollover errors.  |
| Bad DLLP Mask                | 7     | RWS    | 0                | Setting this bit masks Bad DLLP errors.             |
| Bad TLP Mask                 | 6     | RWS    | 0                | Setting this bit masks Bad TLP errors.              |
| Reserved                     | 5:1   | RO     | 0                | -                                                   |
| Receiver Error Mask          | 0     | RWS    | 0                | Setting this bit masks Receiver errors.             |

# 13.2.43 Advanced Error Capabilities and Control Register (offset: 0x118)

| Name                    | Bits | Access | Default<br>Value | Description                                                                                   |
|-------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------|
| Reserved                | 31:9 | RO     | 0                | -                                                                                             |
| ECRC Check Enable       | 8    | RWS    | 0                | Setting this bit will enable ECRC checking.                                                   |
| ECRC Check Capable      | 7    | RO     | 1                | When this bit is set, it indicates that this device supports ECRC checking.                   |
| ECRC Generation Enable  | 6    | RWS    | 0                | Setting this bit will enable ECRC generation.                                                 |
| ECRC Generation Capable | 5    | RO     | 1                | When this bit is set, it indicates that this device supports ECRC generation.                 |
| First Error Pointer     | 4:0  | ROS    | 0                | This value indicates the bit position within the "Uncorrectable Error Status Register" 0x104. |

# 13.2.44 Header Log Register (offset: 0x11C)

| Name          | Bits  | Access | Default<br>Value | Description                                                    |
|---------------|-------|--------|------------------|----------------------------------------------------------------|
| Header Byte 0 | 31:24 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 1 | 23:16 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 2 | 15:8  | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 3 | 7:0   | ROS    | _                | The TLP header of the transaction that has incurred a failure. |

## 13.2.45 Header Log Register (offset: 0x120)

| Name          | Bits  | Access | Default<br>Value | Description                                                    |
|---------------|-------|--------|------------------|----------------------------------------------------------------|
| Header Byte 4 | 31:24 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 5 | 23:16 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 6 | 15:8  | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 7 | 7:0   | ROS    | _                | The TLP header of the transaction that has incurred a failure. |

## 13.2.46 Header Log Register (offset: 0x124)

| Name           | Bits  | Access | Default<br>Value | Description                                                    |
|----------------|-------|--------|------------------|----------------------------------------------------------------|
| Header Byte 8  | 31:24 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 9  | 23:16 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 10 | 15:8  | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 11 | 7:0   | ROS    | _                | The TLP header of the transaction that has incurred a failure. |

#### 13.2.47 Header Log Register (offset: 0x128)

| Name           | Bits  | Access | Default<br>Value | Description                                                    |
|----------------|-------|--------|------------------|----------------------------------------------------------------|
| Header Byte 12 | 31:24 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 13 | 23:16 | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 14 | 15:8  | ROS    | _                | The TLP header of the transaction that has incurred a failure. |
| Header Byte 15 | 7:0   | ROS    | _                | The TLP header of the transaction that has incurred a failure. |

# 13.2.48 Interrupt mail box (High Priority Mailbox) Register (offset: 0x200 – 0x21c)

This mailbox serves two functions. When the host writes it, the interrupt (IntA) is cleared. It is also used by the Host Coalescing engine to determine if the host is in the interrupt handler. If it is non-zero this indicates the host is in the interrupt handler. The Host Coalescing engine uses this information to determine which set of coalescing parameters it should use.

# 13.2.49 General mail box (High Priority Mailbox) Register (offset: 0x220-0x25c)

#### 13.2.50 Reload Statistics mail box (High Priority Mailbox)

Register (offset: 0x260-0x264)

### 13.3 High Priority Mailbox Registers

All registers reset are core reset unless specified.

NOTE: When performing a 32 bit access the higher addresses should be accessed last.

# 13.3.1 Receive BD Standard Producer Ring Index Register (offset: 0x268-0x26F)

| Name                                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                           |
|------------------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Received BD standard Producer Ring Index | 7:0  | RW     |                  | The Receive BD standard Producer Ring Index register contains the index of the next buffer descriptor for the standard producer ring that will be produced in the host for the NIC to DMA into NIC memory. Host software writes this register whenever it updates the standard producer ring. This register must be initialized to 0. |

#### 13.3.1.1 Receive BD Jumbo Producer Ring Index Register (offset: 0x270)

| Name                                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Received BD jumbo<br>Producer Ring Index |      | RW     | 0                | The Receive BD Extended Producer Ring Index register contains the index of the next buffer descriptor for the extended producer ring that will be produced in the host for the controller to DMA into controller memory. Host software writes this register whenever it updates the extended producer ring. This register must be initialized to 0. |

# 13.3.2 Receive BD Return Ring 0 Consumer Index Register (offset: 0x280-0x287)

The Receive BD Return Ring 0 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 0 that has been consumed. Host software writes this register whenever it updates the return ring 1. This register must be initialized to 0.

# 13.3.3 Receive BD Return Ring 1 Consumer Index Register (offset: 0x288–0x28F)

The Receive BD Return Ring 1 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 1 that has been consumed. Host software writes this register whenever it updates the return ring 1. This register must be initialized to 0.

# 13.3.4 Receive BD Return Ring 2 Consumer Index Register (offset: 0x290-0x297)

The Receive BD Return Ring 2 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 2 that has been consumed. Host software writes this register whenever it updates the return ring 2. This register must be initialized to 0.

# 13.3.5 Receive BD Return Ring 3 Consumer Index Register (offset: 0x298–0x29F)

The Receive BD Return Ring 3 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 3 that has been consumed. Host software writes this register whenever it updates the return ring 3. This register must be initialized to 0.

#### 13.3.6 Send BD Ring Host Producer Index Register (offset: 0x300–0x307)

The Send BD Ring Host Producer Index Register contains the index of the next buffer descriptor for a given standard (non-jumbo) send ring that will be produced in the host for the NIC to DMA into NIC memory. Host software writes this register whenever it updates the given send ring. This register must be initialized to 0.

### 13.4 RX Mail Box Registers for VRQ

A set of new High Priority Mail Box Registers have been introduced. The register addresses are as shown in the table below:

| VRQ# | RX Jumbo Ring<br>Producer Index | RX Standard Ring<br>Producer Index | RX Return Ring<br>Consumer Index | Comments                     | NIC Diagnostic<br>RX Return Ring<br>Producer Index |
|------|---------------------------------|------------------------------------|----------------------------------|------------------------------|----------------------------------------------------|
| 0    | 0x270                           | UNDI – 0x98<br>HP – 0x268          | UNDI – 0x88<br>HP – 0x280        | 64-bit Registers             | 0x3C80                                             |
| 1    | 0x2D4                           | 0x354                              |                                  | The new Pogisters are 22 hit | 0x3C84                                             |
| 0    |                                 |                                    | 0x288 (64-bit Regs)              | The new Registers are 32-bit |                                                    |
| 2    | 0x2D8                           | 0x358                              | 0x290 (64-bit Regs)              |                              | 0x3C88                                             |
| 3    | 0x2DC                           | 0x35C                              | 0x298 (64-bit Regs)              |                              | 0x3C8C                                             |
| 4    | 0x2E0                           | 0x360                              | 0x2A0                            | The new Registers are 32-bit | 0x3C90                                             |
| 5    | 0x2E4                           | 0x364                              | 0x2A4                            |                              | 0x3C94                                             |
| 6    | 0x2E8                           | 0x368                              | 0x2A8                            |                              | 0x3C98                                             |
| 7    | 0x2EC                           | 0x36C                              | 0x2AC                            |                              | 0x3C9C                                             |
| 8    | 0x2F0                           | 0x370                              | 0x2B0                            |                              | 0x3CA0                                             |
| 9    | 0x2F4                           | 0x374                              | 0x2B4                            |                              | 0x3CA4                                             |
| 10   | 0x2F8                           | 0x378                              | 0x2B8                            |                              | 0x3CA8                                             |
| 11   | 0x2FC                           | 0x37C                              | 0x2BC                            |                              | 0x3CAC                                             |
| 12   | 0x340                           | 0x380                              | 0x2C0                            |                              | 0x3CB0                                             |
| 13   | 0x344                           | 0x384                              | 0x2C4                            |                              | 0x3CB4                                             |
| 14   | 0x348                           | 0x388                              | 0x2C8                            |                              | 0x3CB8                                             |
| 15   | 0x34C                           | 0x38C                              | 0x2CC                            |                              | 0x3CBC                                             |
| 16   | 0x350                           | 0x390                              | 0x2D0                            |                              | 0x3CC4                                             |

#### **Additional Notes:**

- 0x268 0x298, 0x88, 0x98 are legacy registers
- NIC Diagnostic Standard RBD Consumer Index [1 16] == 0x3F40–0x3F7C
- NIC Diagnostic Jumbo RBD Consumer Index [1 16] == 0x3F80-0x3FFC

# 13.5 Ethernet MAC (EMAC) Registers

All registers reset are core reset unless specified.

## 13.5.1 EMAC Mode Register (offset: 0x400)

| Name                          | Bits  | Access | Default<br>Value | Description                                                                                                                                                               |
|-------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                      | 31:30 | RO     | 0                | -                                                                                                                                                                         |
| Mac loop back mode control    | 29    | RW     | 1                | gate off outgoing TX data path when EMAC loopback mode is enabled.      TX data will show up in normal functional path as well as MAC loopback path.                      |
| Enable APE TX path            | 28    | RW     | 0                | This bit must be written a 1 for the EMAC to transmit APE packets.                                                                                                        |
| Enable APE RX path            | 27    | RW     | 0                | This bit must be written a 1 for APE subsystem to receive packets from the EMAC                                                                                           |
| Free Running ACPI             | 26    | RW     | 0                | When this bit is set, the ACPI state machine will continue running when a match is found. When this bit is clear, the ACPI state machine will halt when a match is found. |
| Halt Interesting packet PME   | 25    | RW     | 0                | When this bit is set, the WOL signal will not be asserted on an interesting packet match.                                                                                 |
| Keep Frame in WOL             | 24    | RW     | 0                | -                                                                                                                                                                         |
| Enable FHDE                   | 23    | RW     | 0                | Enable receive Frame Header DMA engine. Must be set for normal operation.                                                                                                 |
| Enable RDE                    | 22    | RW     | 0                | Enable RDMA engine.  Must be set for normal operation.                                                                                                                    |
| Enable TCE                    | 21    | RW     | 0                | Enable Transmit DMA engine.                                                                                                                                               |
| Reserved                      | 20    | RO     | 0                | -                                                                                                                                                                         |
| ACPI Power-on Enable          | 19    | RW     | 0                | Enable Wake on LAN filters when in power-down mode                                                                                                                        |
| Magic Packet Detection Enable | 18    | RW     | 0                | Enable Magic Packet detection                                                                                                                                             |
| Send Config Command           | 17    | RW     | 0                | Send config commands when in TBI mode                                                                                                                                     |
| Flush TX statistics           | 16    | RW     | 0                | Write transmit statistics to external memory. This bit is self-clearing.                                                                                                  |
| Clear TX statistics           | 15    | RW     | 0                | Clear transmit statistics internal RAM. This bit is self-clearing.                                                                                                        |
| Enable TX Statistics          | 14    | RW     | 0                | Enable transmit statistics external updates                                                                                                                               |
| Flush RX Statistics           | 13    | RW     | 0                | Write receive statistics to external memory. This bit is self-clearing.                                                                                                   |
| Clear RX Statistics           | 12    | RW     | 0                | Clear receive statistics internal RAM. This bit is self-clearing.                                                                                                         |
| Enable RX Statistics          | 11    | RW     | 0                | Enable receive statistics external updates.                                                                                                                               |
| Reserved                      | 10    | RO     | 0                | _                                                                                                                                                                         |
| Max Defer                     | 9     | RW     | 0                | Enable Max Deferral checking statistic.                                                                                                                                   |
| Enable TX Bursting            | 8     | RW     | 0                | Enable transmit bursting in Gigabit half-duplex mode.                                                                                                                     |
| Tagged MAC Control            | 7     | RW     | 0                | Allow the MAC to receive tagged MAC control packets.                                                                                                                      |
| Reserved                      | 6:5   | RO     | 0                | -                                                                                                                                                                         |

| Name          | Bits | Access | Default<br>Value | Description                                                                                                                                                    |
|---------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Loopback mode | 4    | RW     | 0                | When set, an internal loopback path is enabled from the transmit MAC to the receive MAC. This bit is provided for diagnostic purposes only.                    |
| Port Mode     | 3:2  | RW     | 01               | 11: Obsolete (Was TBI) 10: 1000BT(Copper) GMII or SerDes 1000 mode 01: 10/100BT(Copper) MII or SerDes 10/100 mode                                              |
| Half-duplex   | 1    | RW     | 0                | 00: None  When set, the MII/GMII interface is configured to operate in half-duplex mode and the CSMA/CD state machines in the MAC are set to half-duplex mode. |
| Global Reset  | 0    | RW     | 0                | When this bit is set to 1, the MAC state machine is reset. This is a self-clearing bit.                                                                        |

# 13.5.2 EMAC Status Register (offset: 0x404)

| Name                             | Bits  | Access | Default<br>Value                                                                   | Description                                                                                      |
|----------------------------------|-------|--------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| Reserved                         | 31:30 | RO     | 0                                                                                  | -                                                                                                |
| Reserved.                        | 29    | RO     | 0                                                                                  | -                                                                                                |
| Interesting packet PME Attention | 28    | W2C    | 0 When this bit is set, the WOL signal is asserted when an int packet is detected. |                                                                                                  |
| TX Statistic Overrun             | 27    | W2C    | 0                                                                                  | Transmit Statistics block has overrun.                                                           |
|                                  |       |        |                                                                                    | Generates an attention when enabled.                                                             |
| RX Statistic Overrun             | 26    | W2C    | 0                                                                                  | Receive Statistics block has overrun.                                                            |
|                                  |       |        |                                                                                    | Generates an attention when enabled.                                                             |
| ODI Error                        | 25    | RO     | 0                                                                                  | Output Data Interface block has an overrun or underrun.                                          |
|                                  |       |        |                                                                                    | Will generate attention when enabled.                                                            |
|                                  |       |        |                                                                                    | Clear this attention using the Transmit Status register.                                         |
| AP Error                         | 24    | RO     | 0                                                                                  | Auto-polling interface needs service.                                                            |
|                                  |       |        |                                                                                    | Generates an attention when enabled. Clear this attention using the Auto-polling Status register |
| MII Interrupt                    | 23    | RO     | 0                                                                                  | Management interface is signaling an interrupt                                                   |
|                                  |       |        |                                                                                    | Generates an attention when enabled.                                                             |
| MII Completion                   | 22    | W2C    | 0                                                                                  | Management interface transaction has completed.                                                  |
|                                  |       |        |                                                                                    | Generates an attention when enabled.                                                             |
| Reserved                         | 21:13 | RO     | 0                                                                                  | -                                                                                                |
| Link State Changed               | 12    | RO     | 0                                                                                  | Set when the link state has changed                                                              |
|                                  |       |        |                                                                                    | Generates an attention when enabled by bit 12 of the EMAC Event Enable register.                 |
|                                  |       |        |                                                                                    | Clear this attention by writing 1 to Sync Changed (bit 4) and Config changed (bit 3).            |
| Reserved                         | 11:0  | RO     | 0                                                                                  | -                                                                                                |

# 13.5.3 EMAC Event Enable Register (offset: 0x408)

| Name                                    | Bits  | Access | Default<br>Value | Description                                                                         |
|-----------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------|
| Reserved                                | 31:30 | RO     | 0                | -                                                                                   |
| Enable TX Offload Error Interrupt       | 29    | RW     | 0                | Enables or unmasks the interrupt associated with Reg 0x404[29].                     |
| Interesting packet PME Attention Enable | 28    | RW     | 0                | When this bit is set, an attention will be asserted on an interesting packet match. |
| TX Statistics Overrun                   | 27    | RW     | 0                | Enable attention when transmit statistics block has overrun.                        |
| RX Statistics Overrun                   | 26    | RW     | 0                | Enable attention when receive statistics block has overrun.                         |
| ODI Error                               | 25    | RW     | 0                | Enable attention when an output data interface block has an overrun or underrun.    |
| AP Error                                | 24    | RW     | 0                | Enable attention when the auto-polling interface has an error.                      |
| MII Interrupt                           | 23    | RW     | 0                | Enable attention when the Management Interface is signaling an interrupt.           |
| MII Completion                          | 22    | RW     | 0                | Enable attention when the Management Interface transaction has completed.           |
| Reserved                                | 21:13 | RO     | 0                | -                                                                                   |
| Link State Changed                      | 12    | RW     | 0                | Enable attention when the link has changed state.                                   |
| Reserved                                | 11:0  | RO     | 0                | -                                                                                   |

# 13.5.4 LED Control Register (offset: 0x40C)

| Name                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                 |
|------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Override Blink Rate          | 31    | RW     | 1                | If set, the blink rate for the Traffic LED is determined by the Blink Period field (bit 30 to bit 9). This bit is rest to 1.                                |
|                              |       |        |                  | If not set, the blink rate assumes a Blink Period of 0x040, corresponding to approximately 15.9Hz.                                                          |
| Blink Period                 | 30:19 | RW     | 000001<br>000000 | Specifies the period of each blink cycle (on+off) for Traffic LED in milliseconds. Must be a nonzero value.                                                 |
|                              |       |        |                  | This 12-bit field is reset to 0x040, giving a default blink period of approximately 15.9Hz.                                                                 |
| Reserved                     | 18:16 | RO     | 0                | -                                                                                                                                                           |
| Reserved                     | 15    | RO     | 0                | -                                                                                                                                                           |
| Shared Traffic/Link LED mode | 14    | RW     | 1                | When this bit is set, the Link LED is solid green when there is a link and blinks when there is traffic.                                                    |
|                              |       |        |                  | (The LED_MODE field must be set to 00 before enabling this bit).                                                                                            |
| MAC Mode                     | 13    | RW     | 0                | When this bit is set, the traffic LED blinks only when traffic is addressed for the device (The LED_MODE field must be set to 00 before enabling this bit). |

| Name                 | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LED Mod              | 12:11 | RW     | 01               | 00: MAC mode–LED signal is in active low (on) when link is established and is in high (off) when link is not established. 01: PHY mode 1–LED signal is in active low (on) when link is established and is in tristate (off) when link is not established LINKLEDB = Link 10 (open drain) SPD100LEDB = Link 100 (open drain) SPD1000LEDB = Link10000 (open drain) TRAFFICLEDB = PHY RCVLED or PHY XMTLED 10: PHY mode 2–LED signal is in active low (on) when link is established and is in high (off) when link is not established. |
|                      |       |        |                  | LINKLEDB = Link 10  SPD100LEDB = Link 100 and valid data or idle  SPD1000LEDB = Link10000 and valid data or idle  TRAFFICLEDB = PHY RCVLED or PHY XMTLED  11: Same as PHY mode 1                                                                                                                                                                                                                                                                                                                                                    |
| Traffic LED Status   | 10    | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10 Mbps LED Status   | 9     | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 100 Mbps LED Status  | 8     | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1000 Mbps LED Status | 7     | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Traffic LED          | 6     | RW     | 0                | If set along with the Override Traffic bit, the Traffic LED is turned on. If the Blink Traffic LED bit is also set, the LED will blink with blink rate specified in Override Blink Rate (bit 31) and Blink Period (bits 30–19) fields.                                                                                                                                                                                                                                                                                              |
| Blink Traffic LED    | 5     | RW     | 0                | If set along with the Override Traffic bit and Traffic LED bit, the Traffic LED will blink with the blink rate specified in Override Blink Rate (bit 31) and Blink Period (bits 30–19) fields.                                                                                                                                                                                                                                                                                                                                      |
| Override Traffic LED | 4     | RW     | 0                | If set, overrides hardware control of the Traffic LED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      |       |        |                  | The Traffic LED will then be controlled via bit 6 and bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10 Mbps LED          | 3     | RW     | 0                | If set along with the LED Override bit, turns on the 10 Mbps LED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 100 Mbps LED         | 2     | RW     | 0                | If set along with the LED Override bit, turns on the 100 Mbps LED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1000 Mbps LED        | 1     | RW     | 0                | If set along with the LED Override bit, turns on the 1000 Mbps LED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Override Link LEDs   | 0     | RW     | 0                | If set, overrides hardware control of the three link LEDs. The LEDs will be controlled via bits 3–1.                                                                                                                                                                                                                                                                                                                                                                                                                                |

# 13.5.5 EMAC MAC Addresses 0 High Register (offset: 0x410)

| Name             | Bits  |    | Default<br>Value | Description                               |
|------------------|-------|----|------------------|-------------------------------------------|
| Reserved         | 31:16 | RO | 0                | -                                         |
| MAC Address High | 15:0  | RW | 0                | Upper 2-bytes of this node's MAC address. |

#### 13.5.6 EMAC MAC Addresses 0 Low Register (offset: 0x414)

| Name            | Bits |    | Default<br>Value | Description                              |
|-----------------|------|----|------------------|------------------------------------------|
| MAC Address Low | 31:0 | RW | 0                | Lower 4-byte of this node's MAC address. |

#### 13.5.7 EMAC MAC Addresses 1 High Register (offset: 0x418)

| Name             | Bits  | Access | Default<br>Value | Description                               |
|------------------|-------|--------|------------------|-------------------------------------------|
| Reserved         | 31:16 | RO     | 0                | _                                         |
| MAC Address High | 15:0  | RW     | 0                | Upper 2-bytes of this node's MAC address. |

#### 13.5.8 EMAC MAC Addresses 1 Low Register (offset: 0x41C)

| Name            | Bits | Access | Default<br>Value | Description                              |
|-----------------|------|--------|------------------|------------------------------------------|
| MAC Address Low | 31:0 | RW     | 0                | Lower 4-byte of this node's MAC address. |

#### 13.5.9 EMAC MAC Addresses 2 High Register (offset: 0x420)

| Name             | Bits  | Access | Default<br>Value | Description                               |
|------------------|-------|--------|------------------|-------------------------------------------|
| Reserved         | 31:16 | RO     | 0                | -                                         |
| MAC Address High | 15:0  | RW     | 0                | Upper 2-bytes of this node's MAC address. |

### 13.5.10 EMAC MAC Addresses 2 Low Register (offset: 0x424)

| Name            | Bits | Access | Default<br>Value | Description                              |
|-----------------|------|--------|------------------|------------------------------------------|
| MAC Address Low | 31:0 | RW     | 0                | Lower 4-byte of this node's MAC address. |

### 13.5.11 EMAC MAC Addresses 3 High Register (offset: 0x428)

| Name             | Bits  | Access | Default<br>Value | Description                               |
|------------------|-------|--------|------------------|-------------------------------------------|
| Reserved         | 31:16 | RO     | 0                | _                                         |
| MAC Address High | 15:0  | RW     | 0                | Upper 2-bytes of this node's MAC address. |

### 13.5.12 EMAC MAC Addresses 3 Low Register (offset: 0x42C)

| Name            | Bits | Access | Default<br>Value | Description                              |
|-----------------|------|--------|------------------|------------------------------------------|
| MAC Address Low | 31:0 | RW     | 0                | Lower 4-byte of this node's MAC address. |

#### 13.5.13 WOL Pattern Pointer Register (offset: 0x430)

| Name         | Bits | Access | Default<br>Value | Description                                                                                                                                          |
|--------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved     | 31:9 | RO     | 0                | _                                                                                                                                                    |
| ACPI Pointer | 8:0  | RW     | 0                | Specifies the offset into the 6 KB BD memory for frame comparison. (Bits 3:0 are ignored to align the memory address to a natural 128-bit boundary). |

#### 13.5.14 WOL Pattern Configuration Register (offset: 0x434)

| Name        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                   |
|-------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved    | 31:28 | RO     | 0                | -                                                                                                                                                                                             |
| ACPI Offset | 27:16 | RW     | 0                | Offset of a frame where the pattern comparison starts.                                                                                                                                        |
| Reserved    | 15:10 | RO     | 0                | -                                                                                                                                                                                             |
| ACPI Length | 9:0   | RW     | 0                | Specifies the total number of 64-bit double words inside the MISC_BD memory that are valid for ACPI. For GMII, it should have a value of 2, 4, 6, For MII, it should have a value of 3, 6, 9, |

### 13.5.15 Ethernet Transmit Random Backoff Register (offset: 0x438)

| Name                | Bits  | Access | Default<br>Value | Description                                        |
|---------------------|-------|--------|------------------|----------------------------------------------------|
| Reserved            | 31:10 | RO     | 0                | -                                                  |
| Random Backoff Seed | 9:0   | RW     | 0                | For half-duplex, initialize with any nonzero seed. |

### 13.5.16 Receive MTU Size Register (offset: 0x43C)

| Name     | Bits  | Access | Default<br>Value | Description                                                                                          |
|----------|-------|--------|------------------|------------------------------------------------------------------------------------------------------|
| Reserved | 31:16 | RO     | 0                | -                                                                                                    |
| MTU      | 15:0  | RW     | 05F2h            | 2-byte field which is the largest size frame that will be accepted without being marked as oversize. |

**NOTE:** If the MTU value in register 0x43C[15:0] is greater than the value in 0x2458[15:2], then the driver MUST configure jumbo frame support and fill the jumbo receive producer rings.

### 13.5.17 Gigabit PCS Test Register (offset: 0x440)

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 31:0 | RO     | 0                | _           |

# 13.5.18 Transmit 1000BASE-X Auto-Negotiation Register (offset: 0x444)

| Name     | Bits |    | Default<br>Value | Description |
|----------|------|----|------------------|-------------|
| Reserved | 31:0 | RO | 0                | -           |

### 13.5.19 Receive 1000BASE-X Auto-Negotiation Register (offset: 0x448)

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 31:0 | RO     | 0                | -           |

## 13.5.20 MII Communication Register (offset: 0x44C)

| Name             | Bits  | Access | Default<br>Value | Description                                                                                                                            |
|------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Reserved         | 31:30 | RO     | 0                | _                                                                                                                                      |
| Start/Busy       | 29    | RW     | 0                | Set this bit to start a transaction.                                                                                                   |
|                  |       |        |                  | While it is high, it indicates that the current transaction is still ongoing.                                                          |
|                  |       |        |                  | If enabled, generates an attention via EMAC Status Register MI Completion bit (bit 22).                                                |
| Read Failed      | 28    | RO     | 0                | When set, the transceiver device did not driver the bus during the attempted read transaction.                                         |
|                  |       |        |                  | Valid after the Start/Busy bit is cleared.                                                                                             |
| Command          | 27:26 | RW     | 0                | These bits specify the transaction type:                                                                                               |
|                  |       |        |                  | 11: Undefined                                                                                                                          |
|                  |       |        |                  | 10: Read command                                                                                                                       |
|                  |       |        |                  | 01: Write command                                                                                                                      |
|                  |       |        |                  | 00: Undefined                                                                                                                          |
| PHY Addr         | 25:21 | RW     | 0                | 0x8: SGMII SerDes Port0.                                                                                                               |
|                  |       |        |                  | 0x9: SGMII SerDes Port1.                                                                                                               |
|                  |       |        |                  | as strapped: External PHY Port0                                                                                                        |
|                  |       |        |                  | as strapped: External PHY Port1                                                                                                        |
| Register Address | 20:16 | RW     | 0                | Address of the register to be read or written.                                                                                         |
| Transaction Data | 15:0  | RW     | 0                | When configured for a write command, the data stored at this location is written to the PHY at the specified PHY and register address. |
|                  |       |        |                  | During a read command, the data returned by the PHY is stored at this location.                                                        |

## 13.5.21 MII Status Register (offset: 0x450)

| Name     | Bits |    | Default<br>Value | Description |
|----------|------|----|------------------|-------------|
| Reserved | 31:2 | RO | 0                | _           |

| Name         | Bits | Access | Default<br>Value | Description                                                                                                                                                        |
|--------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mode 10 Mbps | 1    | RW     | 0                | When read, a value of 1 indicates the transceiver device is operating in 10 Mbps mode                                                                              |
| Link Status  | 0    | RW     | 0                | The bit will generate an attention if enabled. Indicates status of the link on the transceiver device. When read, a value of 1 indicates the transceiver is linked |

## 13.5.22 MII Mode Register (offset: 0x454)

| Name                           | Bits  | Access | Default<br>Value | Description                                                                                                |
|--------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------|
| Reserved                       | 31:21 | RO     | 0                | -                                                                                                          |
| MII Clock Count                | 20:16 | RW     | 0Ch              | Counter to divide CORE_CLK (62.5 MHz) to generate the MI clock.                                            |
|                                |       |        |                  | The formula is:                                                                                            |
|                                |       |        |                  | MI Clock = CORE_CLK/2/(MI Clock Count + 1).                                                                |
| Constant MDIO/MDC clock speed. | 15    | RW     | 0                | Enable ~500Khz constant MII management interface (MDIO/MDC) frequency regardless core clock frequency.     |
|                                |       |        |                  | 1: Enable                                                                                                  |
|                                |       |        |                  | 0: Disable                                                                                                 |
| Reserved                       | 14:10 | RO     | 0                | -                                                                                                          |
| PHY Address                    | 9:5   | RW     | 1                | This field specifies the PHY Address.                                                                      |
| Port polling                   | 4     | RW     | 0                | Set to enable autopolling of the transceiver link information from the MII management interface.           |
|                                |       |        |                  | If cleared, the device will obtain the link status information from the state of the LINKRDY input signal. |
| Reserved                       | 3     | RO     | 0                | -                                                                                                          |
| Auto_control                   | 2     | RW     | 0                | -                                                                                                          |
| Use Short Preamble             | 1     | RW     | 1                | Use short preamble while polling, if set.                                                                  |
| Fast_Clock                     | 0     | RW     | 0                | -                                                                                                          |

# 13.5.23 Autopolling Status Register (offset: 0x458)

| Name               | Bits | Access | Default<br>Value | Description                                      |
|--------------------|------|--------|------------------|--------------------------------------------------|
| Reserved           | 31:1 | RO     | 0                | -                                                |
| Auto-polling Error | 0    | W2C    | 0                | Indicates an autopolling error occurred, if set. |

# 13.5.24 Transmit MAC Mode Register (offset: 0x45C)

| Name      | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                      |
|-----------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RR Weight | 31:27 | RW     |                  | This field may be programmed to assign a weight to the "Weighted Round Robin" arbitration mode. This field is applicable only when the appropriate arbitration mode is chosen, i.e., [19:17] of this register is equal to "001". |

| Name                                                                 | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmit FTQ Arbitration Mode                                        | 26:24 | RW     | 000              | This field determines the arbitration mode of the TCE block among LAN traffic and APE traffic as below:                                                                                                                                                                                                                                         |
|                                                                      |       |        |                  | 000–Simple Round Robin                                                                                                                                                                                                                                                                                                                          |
|                                                                      |       |        |                  | 001–Weighted Round Robin                                                                                                                                                                                                                                                                                                                        |
|                                                                      |       |        |                  | 010–Shut off APE transmit stream                                                                                                                                                                                                                                                                                                                |
|                                                                      |       |        |                  | 011–Shut off LAN transmit stream                                                                                                                                                                                                                                                                                                                |
|                                                                      |       |        |                  | 1xx–Reserved for future use                                                                                                                                                                                                                                                                                                                     |
|                                                                      |       |        |                  | Caution: This field must remain static following boot.                                                                                                                                                                                                                                                                                          |
| HTX2B Count Down Mode                                                | 23    | RW     | 0                | When this bit is 0:                                                                                                                                                                                                                                                                                                                             |
|                                                                      |       |        |                  | If there is an HTX2B packet to be enqueued to the HTX2B, FIFO. However, if the FIFO does not have sufficient space, TCE drops the copy of the HTX2B-bound packet and moves on.  When this bit is 1:  If there is an HTX2B packet to be enqueued to the HTX2B, FIFO.                                                                             |
|                                                                      |       |        |                  | However, if the FIFO does not appear to have sufficient space at the first attempt, TCE counts down a few clocks, then makes a second attempt. If the FIFO still does not have sufficient space, TCE simply drops the copy of the HTX2B-bound packet and moves on. The number of clocks to count-down is programmable at register 0x464[31:24]. |
| HTX2B Programmable Jumbo                                             | 22    | RW     | 0                | When this bit is 0:                                                                                                                                                                                                                                                                                                                             |
| Frame Length                                                         |       |        |                  | Hardware automatically applies preset lengths to detect jumbo frames for HTX2B.                                                                                                                                                                                                                                                                 |
|                                                                      |       |        |                  | When this bit is 1:                                                                                                                                                                                                                                                                                                                             |
|                                                                      |       |        |                  | The jumbo frame length for HTX2B is programmable via 0x464[23:16].                                                                                                                                                                                                                                                                              |
| Reserved                                                             | 21    | _      | _                | -                                                                                                                                                                                                                                                                                                                                               |
| TX-MBUF Burst Size                                                   | 20:17 | RW     | 0000             | This filed determines the size of the MA read performed by TCE.                                                                                                                                                                                                                                                                                 |
|                                                                      |       |        |                  | 0000 => burst-size 16                                                                                                                                                                                                                                                                                                                           |
|                                                                      |       |        |                  | 0001–01111 => reserved                                                                                                                                                                                                                                                                                                                          |
|                                                                      |       |        |                  | 1000 => burst-size 8                                                                                                                                                                                                                                                                                                                            |
|                                                                      |       |        |                  | 1001 => burst-size 9                                                                                                                                                                                                                                                                                                                            |
|                                                                      |       |        |                  |                                                                                                                                                                                                                                                                                                                                                 |
| Do not insert GCM/GMAC IV                                            | 16    | RW     | 0                | If this bit is 0, an IV is generated by the chip and inserted in an offloaded TX ESP or TX AH packet in GCM or GMAC Cipher mode.                                                                                                                                                                                                                |
|                                                                      |       |        |                  | If this bit is 1, an IV is not inserted. Instead, the IV is extracted from the TX frame.                                                                                                                                                                                                                                                        |
| Do not drop if packet found malformed                                | 15    | RW     | 0                | These bit are there for debug purposes. Normally an offloaded TX packet that does not adhere to BCM571X/BCM5720 family                                                                                                                                                                                                                          |
| Do not drop if SA found in RX direction                              | 14    | RW     | 0                | limitations or does not associate with a valid SA, unless the bit corresponding to the error symptom is set to 1 here; in that case the                                                                                                                                                                                                         |
| Do not drop if unsupported IPV6 extension found or IPv4 option found | 13    | RW     | 0                | particular error is overlooked and the packet is transmitted in clear text.  When such a packet is dropped in the chip, an interrupt is                                                                                                                                                                                                         |
| Do not drop if SA invalid                                            | 12    | RW     | 0                | generated.                                                                                                                                                                                                                                                                                                                                      |
| Do not drop if AH/ESP Header not found                               | 11    | RW     | 0                |                                                                                                                                                                                                                                                                                                                                                 |

| Name                                | Bits | Access | Default<br>Value | Description                                                                                                               |
|-------------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------|
| Enable TX AH Offload                | 10   | RW     | 0                | A value 1 enables the TX AH offload feature. When 0, offloaded AH packet gets dropped. This value must be static.         |
| Enable TX ESP Offload               | 9    | RW     | 0                | A value 1 enables the TX ESP offload feature. When 0, offloaded ESP packet gets dropped.  This value must be static.      |
| TxMBUF corruption lockup fix enable | 8    | RW     | 0                | When set, TXMBUF corruption lockup fix is enabled.                                                                        |
| Link Aware Enable                   | 7    | RW     | 0                | When set, transmission of packets by the MAC is enabled only when link is up.                                             |
| Enable Long Pause                   | 6    | RW     | 0                | When set, the Pause time value set in the transmitted PAUSE frames is 0xFFFF.  The default value for PAUSE time is 0x1FFF |
| Enable Big Backoff                  | 5    | RW     | 0                | MAC will use larger than normal back-off algorithm.                                                                       |
| Enable Flow Control                 | 4    | RW     | 0                | MAC will send 802.3x flow control frames.                                                                                 |
| Reserved                            | 3:2  | RO     | 0                | _                                                                                                                         |
| Enable TCE                          | 1    | RW     | 1                | Used to be enable TDE in legacy–same purpose.                                                                             |
| Reset                               | 0    | RW     | 0                | When this bit is set to 1, the Transmit MAC state machine will be reset.  This is a self-clearing bit.                    |

# 13.5.25 Transmit MAC Status Register (offset: 0x460)

| Name                | Bits  | Access | Default<br>Value | Description                                                        |
|---------------------|-------|--------|------------------|--------------------------------------------------------------------|
| Reserved            | 31:6  | RO     | 0                | -                                                                  |
| Consumer Index      | 22:11 | RO     | UUUU             | The Consumer Index of the erring packet is reported by this field. |
| ODI Overrun         | 5     | W2C    | 0                | Output data interface has overrun.                                 |
| ODI Underrun        | 4     | W2C    | 0                | Output data interface has underrun.                                |
| Link Up             | 3     | RO     | 0                | Link is up, if set.                                                |
| Sent XON            | 2     | W2C    | 0                | An XON flow control frame was sent.                                |
| Sent XOFF           | 1     | W2C    | 0                | An XOFF flow control frame was sent.                               |
| RX Currently XOFFed | 0     | RO     | 0                | Received stopped due to flow control.                              |

# 13.5.26 Transmit MAC Lengths Register (offset: 0x464)

| Name                     | Bits  | Access | Default<br>Value | Description                                                                                                                                              |
|--------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| HTX2B Count Down Value   | 31:24 | RW     | 0x1              | HT2XB Count Down Value                                                                                                                                   |
| HTX2B Jumbo Frame Length | 23:16 | RW     | 0x0              | This value + 1500 is used by hardware as the maximum standard frame length for HTX2B. A frame with a length larger than that is a jumbo frame for HTX2B. |
|                          |       |        |                  | The length is the effective length of a composed L2 frame as seen from the wire, including the L2 header, L2 payload, and the FCS (CRC) field.           |
| Reserved                 | 15:14 | RO     | 0                |                                                                                                                                                          |

| Name             | Bits  | Access | Default<br>Value | Description                                                                                                                                              |
|------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| IPG CRS Length   | 13:12 | RW     | 0                | When multiplied by 2, this field indicates the number of bytes from<br>the end of the interpacket gap (IPG) during which incoming carrier<br>is ignored. |
| IPG Length       | 11:8  | RW     | 0                | When multiplied by 2, this field indicates the number of bytes in the entire IPG.                                                                        |
| Slot Time Length | 7:0   | RW     | 0                | When multiplied by 2, this field indicates the number of bytes in the slot time.                                                                         |

# 13.5.27 Receive MAC Mode Register (offset: 0x468)

| Name                                               | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIX EMAC drops first packet on false carrier event | 31    | RW     | 0                | This bit when set disables the fix where EMAC drops first packet on False Carrier Event.  1: Disable Fix  0: Enable Fix                                                                                                                                                                                                                                                                                                                         |
| Reserved                                           | 30    | RO     | 0                | _                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Disable 802.3 length check fix for VLAN Tag frames | 29    | RW     | 0                | If clear, 802.3 length check takes VLAN length into account properly.                                                                                                                                                                                                                                                                                                                                                                           |
| Reset Management Filter Set                        | 28    | WO     | 0                | Writing a 1 to this field generates a pulse to reset all Management Filter registers.                                                                                                                                                                                                                                                                                                                                                           |
| Enable RX AH Offload                               | 27    | RW     | 0                | A value 1 enables the RX AH offload feature. When 0, in coming packets are not CAMed for offload consideration.                                                                                                                                                                                                                                                                                                                                 |
| Enable RX ESP Offload                              | 26    | RW     | 0                | A value 1 enables the RX ESP offload feature. When 0, in coming packets are not CAMed for offload consideration.                                                                                                                                                                                                                                                                                                                                |
| APE promiscuous mode enable                        | 25    | RW     | 0                | When set, no source address or MC hashing checking will be performed on incoming frames on APE filter path.  All frames will be accepted and subject to Management filter actions.                                                                                                                                                                                                                                                              |
| IPV6 Enable                                        | 24    | RW     | 0                | Enable IPv6 RX     O: Disable IPv6 RX which includes IPv6 packet parsing, checksum offload and IPv6 RSS                                                                                                                                                                                                                                                                                                                                         |
| RSS_enable                                         | 23    | RW     | 1                | 1: Enable RSS function. 0: Disable RSS function. FHDE will ignore the RSS_valid from Frame Cracker and set RSS_valid to be 0 in frame descriptor of each packet.                                                                                                                                                                                                                                                                                |
| RSS Hash Mask Bits                                 | 22:20 | RW     | 0x7              | These bits specify the number of hash bits that are used to offset into the indirection table. A value of one specifies that only bit 0 of the hash is used to offset into the indirection table (so only the first two entries of the table are utilized.) A value of seven specifies that bits 6:0 of the hash are used to offset into the indirection table. A value of zero will result in undefined behavior and should not be programmed. |
| RSS TCP/IPV6 Hash Enable                           | 19    | RW     | 0                | When this bit is set, 4-tuple hashes are enabled for TCP over IPV6 packets. This bit should be set to 0 if IPv6 RX is disabled.                                                                                                                                                                                                                                                                                                                 |
| RSS IPV6 Hash Enable                               | 18    | RW     | 0                | When this bit is set, 2-tuple hashes are enabled for IPV6 packets. This bit should be set to 0 if IPv6 RX is disabled.                                                                                                                                                                                                                                                                                                                          |

| Name                                                                                           | Bits  | Access | Default<br>Value | Description                                                                                                                                                         |
|------------------------------------------------------------------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RSS TCP/IPV4 Hash Enable                                                                       | 17    | RW     | 0                | When this bit is set, 4-tuple hashes are enabled for TCP over IPV4 packets.                                                                                         |
| RSS IPV4 Hash Enable                                                                           | 16    | RW     | 0                | When this bit is set, 2-tuple hashes are enabled for IPV4 packets.                                                                                                  |
| Reserved                                                                                       | 15:13 | RO     | 0                | -                                                                                                                                                                   |
| FIX EMAC drops a packets if incoming DA partial match both perfect and Pause Multicast address | 12    | RW     | 0                | This bit disables the fix that EMAC stage fsm drops a packet if incoming packet's DA has a partial match in both perfect match address and Pause Multicast address. |
| Filter Broadcast                                                                               | 11    | RW     | 0                | When set, reception of broadcast frames is disabled                                                                                                                 |
| Keep VLAN Tag Diag mode                                                                        | 10    | RW     | 0                | If set, forces Receive MAC to keep the VLAN tag in the frame.                                                                                                       |
|                                                                                                |       |        |                  | This is for debugging purpose only and should be reset during normal operation                                                                                      |
| No CRC Check                                                                                   | 9     | RW     | 0                | When set, no CRC check by receive MAC on incoming frames.                                                                                                           |
|                                                                                                |       |        |                  | Also, allows the reception of packets received with RXERR on MII/GMII.                                                                                              |
| Promiscuous mode                                                                               | 8     | RW     | 0                | When set, no source address or MC hashing checking will be performed on incoming frames.                                                                            |
|                                                                                                |       |        |                  | All frames will be accepted.                                                                                                                                        |
| Length Check                                                                                   | 7     | RW     | 0                | If set, 802.2 length checking is done on LLC frames.                                                                                                                |
| Accept Runts                                                                                   | 6     | RW     | 0                | If set, MAC accepts packets less than 64 bytes.                                                                                                                     |
| Reserved                                                                                       | 5     | RO     | 0                | _                                                                                                                                                                   |
| Keep Pause                                                                                     | 4     | RW     | 0                | If set, MAC forwards pause frame to host buffer.                                                                                                                    |
| Reserved                                                                                       | 3     | RO     | 0                | -                                                                                                                                                                   |
| Enable Flow Control                                                                            | 2     | RW     | 0                | Enable automatic processing of 802.3x flow control frames.  This bit is orthogonal to the Keep Pause bit.                                                           |
| Enable                                                                                         | 1     | RW     | 0                | This bit controls whether the Receive MAC state machine is active or not.                                                                                           |
|                                                                                                |       |        |                  | When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains 1 when read.                                         |
| Reset                                                                                          | 0     | RW     | 0                | When this bit is set to 1, the Receive MAC state machine will be reset.  This is a self-clearing bit.                                                               |

#### 13.5.28 Receive MAC Status Register (offset: 0x46C)

| Name                      | Bits | Access | Default<br>Value | Description                                                                                                                                 |
|---------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                  | 31:4 | RO     | 0                | -                                                                                                                                           |
| RX FIFO Overrun           | 3    | W2C    | 0                | RX FIFO has encountered an overrun condition.                                                                                               |
| XON received              | 2    | W2C    | 0                | MAC control frame with the PAUSE opcode was received with PAUSE TIME field set to zero.  The bit is sticky and must be written to clear.    |
| XOFF received             | 1    | W2C    | 0                | MAC control frame with the PAUSE opcode was received with PAUSE TIME field set to nonzero.  The bit is sticky and must be written to clear. |
| Remote Transmitter XOFFed | 0    | RO     | 0                | A previously received XOFF timer has not expired yet.                                                                                       |

## 13.5.29 MAC Hash Register 0 (offset: 0x470)

| Name       | Bits | Access | Default<br>Value | Description                                            |
|------------|------|--------|------------------|--------------------------------------------------------|
| Hash value | 31:0 | RW     | 0                | Hash value for multicast destination address matching. |

## 13.5.30 MAC Hash Register 1 (offset: 0x474)

| Name       | Bits | Access | Default<br>Value | Description                                            |
|------------|------|--------|------------------|--------------------------------------------------------|
| Hash value | 31:0 | RW     | 0                | Hash value for multicast destination address matching. |

## 13.5.31 MAC Hash Register 2 (offset: 0x478)

| Name       | Bits | Access | Default<br>Value | Description                                            |
|------------|------|--------|------------------|--------------------------------------------------------|
| Hash value | 31:0 | RW     | 0                | Hash value for multicast destination address matching. |

### 13.5.32 MAC Hash Register 3 (offset: 0x47C)

| Name       | Bits | Access | Default<br>Value | Description                                            |
|------------|------|--------|------------------|--------------------------------------------------------|
| Hash value | 31:0 | RW     | 0                | Hash value for multicast destination address matching. |

# 13.5.33 Receive Rules Control Registers (offset: 0x480 + 8\*N)

The BCM571X/BCM5720 family employs eight receive rules (N = 0 to 7).

| Name   | Bits | Access | Default<br>Value | Description                             |
|--------|------|--------|------------------|-----------------------------------------|
| Enable | 31   | RW     | 0                | Corresponding Rule is enabled when set. |

| Name                    | Bits  | Access | Default<br>Value | Description                                                                                                                                               |
|-------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| And With Next           | 30    | RW     | 0                | This rule and next must both be true to match. The class fields must be the same.  A disabled next rule is considered true. Processor activation bits are |
|                         |       |        |                  | specified in the first rule in series.                                                                                                                    |
| Activate Processor 1    | 29    | RW     | 0                | If the rule matches, the processor is activated in the queue descriptor for the Receive Queue Placement state machine.                                    |
| Activate Processor 2    | 28    | RW     | 0                | If the rule matches, the processor is activated in the queue descriptor for the Receive Queue Placement state machine.                                    |
| Activate Processor 3    | 27    | RW     | 0                | If the rule matches, the processor is activated in the queue descriptor for the Receive Queue Placement state machine.                                    |
| Mask                    | 26    | RW     | 0                | IF set, specifies that the value/mask field is split into a 16-bit mask instead of a 32bit value.                                                         |
| Discard                 | 25    | RW     | 0                | Discard frame if it matches the rule.                                                                                                                     |
| Мар                     | 24    | RW     | 0                | Use the masked value and map it to the class.                                                                                                             |
| Reserved for future use | 23:18 | RW     | 0                | _                                                                                                                                                         |
| Comparison Operator     | 17:16 | RW     | 0                | Specifies how to determine the match:                                                                                                                     |
|                         |       |        |                  | 00: Equal                                                                                                                                                 |
|                         |       |        |                  | 01: Not Equal                                                                                                                                             |
|                         |       |        |                  | 10: Greater Than                                                                                                                                          |
|                         |       |        |                  | 11: Less Than                                                                                                                                             |
| Header Type             | 15:13 | RW     | 0                | Specifies which header the offset is for:                                                                                                                 |
|                         |       |        |                  | 000: Start of Frame (always valid)                                                                                                                        |
|                         |       |        |                  | 001: Start of IP Header (if present)                                                                                                                      |
|                         |       |        |                  | 010: Start of TCP Header (if present)                                                                                                                     |
|                         |       |        |                  | 011: Start of UDP Header (if present)                                                                                                                     |
|                         |       |        |                  | 100: Start of Data (always valid, context sensitive)                                                                                                      |
| Class                   | 12:8  | RW     | 0                | The class this frame is place into if the rule matches. 0-16 where 0 means discard.                                                                       |
|                         |       |        |                  | The number of valid classes is the number of active queues divided by the Number of Interrupt Distribution Groups.                                        |
|                         |       |        |                  | Ring 1 has the highest priority.                                                                                                                          |
| Offset                  | 7:0   | RW     | 0                | Number of bytes offset specified by the header type.                                                                                                      |

# 13.5.34 Receive Rules Value/Mask Registers (offset: 0x484 + 8\*N)

The BCM571X/BCM5720 family employs eight receive rules (N = 0 to 7).

| Name       | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                             |
|------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mask/Value | 31:16 | RW     | 0                | For each bit set, the corresponding bit in the value field is ignored during the rule match process.  If bit 26 of the corresponding rule control register is set, the field is used as an additional 16-bit value for rule comparison. |
| Value      | 15:0  | RW     | 0                | This field specifies a 16-bit value for rule comparison.                                                                                                                                                                                |

# 13.5.35 Receive Rules Configuration Register (offset: 0x500)

| Name                           | Bits | Access | Default<br>Value | Description                                                                                                                                                                 |
|--------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                       | 31:6 | RO     | 0                | -                                                                                                                                                                           |
| No Rules Matches Default Class | 5:3  | RW     | 0                | Specifies the default class of service for the frame if no rules are matched.  A value of 1 is the highest priority.  A value of zero will cause the frame to be discarded. |
| Reserved                       | 2:0  | RO     | 0                | -                                                                                                                                                                           |

#### 13.5.36 Low Watermark Maximum Receive Frame Register (offset: 0x504)

| Name                                | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                     |
|-------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                            | 31:21 | RO     | 0                | -                                                                                                                                                                                                                               |
| TXFIFO Almost Empty Threshold       | 20:16 | RW     | 0xC              | When the remaining entries of TXFIFO are less than this threshold, TXFIFO_almost_empty will be asserted. This value is used in conjunction with Buffer Manager Mode register bit31 to prevent EMAC TXFIFO underrun.             |
| Low Watermark Max Receive<br>Frames | 15:0  | RW     | 0                | Specifies the number of good frames to receive after RX MBUF Low Watermark has been reached. After the RX MAC receives this number of frames, it will drop subsequent incoming frames until the MBUF High Watermark is reached. |
|                                     |       |        |                  | Default to zero (i.e., drop frames ones RX MBUF Low Watermark is reached).                                                                                                                                                      |

# 13.5.37 APE\_PERFECT\_MATCH[1-4]\_HIGH\_REG (Offsets 0x540, 0x548, 0x550, 0x558)

There are total 4 Perfect (Destination Address) Match registers dedicated to APE in RX-MAC. These registers hold the higher 2 octets of the matching address.

| Name             | Bits  | Access | Default<br>Value | Description                                     |
|------------------|-------|--------|------------------|-------------------------------------------------|
| Reserved         | 31:29 | RO     | 000              | -                                               |
| MAC High Address | 15:0  | RW     | 0x0000           | Upper 2-bytes of APE's [1–4]th unicast address. |

# 13.5.38 APE\_PERFECT\_MATCH[1-4]\_LOW\_REG (Offsets 0x544, 0x54C, 0x554, 0x55C)

There are total 4 Perfect (Destination Address) Match registers dedicated to APE in RX-MAC. These registers hold the lower 4 octets of the matching address.

| Name            | Bits | Access | Default<br>Value | Description                                     |
|-----------------|------|--------|------------------|-------------------------------------------------|
| MAC Low Address | 31:0 | RW     | 0x0000           | Lower 4-bytes of APE's [1–4]th unicast address. |

#### 13.5.39 SGMII Control Register (offset: 0x5B0)

| Name     | Bits |   | Default<br>Value | Description |
|----------|------|---|------------------|-------------|
| Reserved | _    | _ | _                | -           |

## 13.5.40 SGMII Status Register (offset: 0x5B4)

This register reflects various status of the respective SGMII port when enabled.

| Name                  | Bits  | Access | Default<br>Value | Description                                              |
|-----------------------|-------|--------|------------------|----------------------------------------------------------|
| LP AutoNeg Capability | 31:16 | RO     | 0                | Link partner advertised auto-negotiation abilities.      |
| Reserved              | 15:11 | RO     | 0                | -                                                        |
| External CRS Detect   | 10    | RO     | 0                | External PHY's CRS output                                |
| PCS CRS Detect        | 9     | RO     | 0                | Internal PCS blocks CRS output                           |
| Media Selection mode  | 8     | RO     | 0                | 1: SGMII/1000BaseX mode selected for this port           |
|                       |       |        |                  | 0: Copper Media Selected for this port                   |
| Pause TX              | 7     | RO     | 0                | 1: enable pause TX                                       |
| Pause RX              | 6     | RO     | 0                | 1: enable pause RX                                       |
| AutoNeg Next Page RX  | 5     | RO     | 0                | 1: next auto-negotiation page received                   |
| Speed_100             | 4     | RO     | 0                | The SGMII Link currently operable at 100mbps data speed. |
| Speed_1000            | 3     | RO     | 0                | The SGMII Link currently operable at 1 Gbps data speed.  |
| Duplex Status         | 2     | RO     | 0                | 1: The Link currently is in Full Duplex mode.            |
|                       |       |        |                  | 0: The Link is currently in Half Duplex mode.            |
| Link Status           | 1     | RO     | 0                | 1: Link is up.                                           |
|                       |       |        |                  | 0: Link is down.                                         |
| AutoNeg Completion    | 0     | RO     | 0                | Auto-negotiation process has completed.                  |

#### 13.5.41 HTX2B Perfect Match[1-4] HI Reg (offset: 0x4880, 0x4888, 0x4890, 0x4898)

There are four Perfect (Destination Address) Match registers in DMAR for HTX2B. These registers hold the higher two octets of the matching address.

| Name             | Bits  |    | Default<br>Value | Description                        |
|------------------|-------|----|------------------|------------------------------------|
| Reserved         | 31:29 | RO | 000              | Reserved.                          |
| MAC High Address | 15:0  | RW | 0x0000           | Upper 2-bytes Destination Address. |

# 13.5.42 HTX2B Perfect Match[1-4] LO Reg (offset: 0x4884, 0x488C, 0x4894, 0x489C)

There are four Perfect (Destination Address) Match registers in DMAR for HTX2B. These registers hold the lower two octets of the matching address.

| Name            | Bits | Access | Default<br>Value | Description                           |
|-----------------|------|--------|------------------|---------------------------------------|
| MAC Low Address | 31:0 | RW     | 0x0000           | Lower 4-bytes of Destination Address. |

#### 13.5.43 HTX2B Protocol Filter Reg (offset: 0x6D0)

This register resides in TCE.

| Name                                           | Bits  | Access | Default<br>Value | Description                                                                             |
|------------------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------|
| Unused                                         | 31:27 | RO     | 0x0              |                                                                                         |
| Duplicate–DHCPv6 Relay and<br>Server multicast | 26    | RW     | 0                | Write a 1 to each bit to enable the respective HTX2B protocol filter duplication.       |
| Duplicate-IPv6 Router<br>Advertisement         | 25    | RW     | 0                | The respective Protocol Filter Enable bit must be 1 for a Duplication to be meaningful. |
| Duplicate–IPv6 Neighbor<br>Advertisement       | 24    | RW     | 0                |                                                                                         |
| Duplicate-NetBios Packet                       | 23    | RW     | 0                |                                                                                         |
| Duplicate-DHCP Server Packet                   | 22    | RW     | 0                |                                                                                         |
| Duplicate-DHCP Client Packet                   | 21    | RW     | 0                |                                                                                         |
| Duplicate-ARP Packet                           | 20    | RW     | 0                |                                                                                         |
| Duplicate-HTX2B Perfect Match Address[3]       | 19    | RW     | 0                |                                                                                         |
| Duplicate-HTX2B Perfect Match Address[2]       | 18    | RW     | 0                |                                                                                         |
| Duplicate-HTX2B Perfect Match Address[1]       | 17    | RW     | 0                |                                                                                         |
| Duplicate-HTX2B Perfect Match Address[0]       | 16    | RW     | 0                |                                                                                         |
| Unused                                         | 15:11 | RO     | 0x0              |                                                                                         |
| Enable–DHCPv6 Relay and<br>Server multicast    | 10    | RW     | 0                | Write a 1 to each bit to enable the respective HTX2B protocol filter.                   |
| Enable-IPv6 Router<br>Advertisement            | 9     | RW     | 0                |                                                                                         |
| Enable–IPv6 Neighbor<br>Advertisement          | 8     | RW     | 0                |                                                                                         |
| Enable-NetBios Packet                          | 7     | RW     | 0                |                                                                                         |
| Enable-DHCP Server Packet                      | 6     | RW     | 0                |                                                                                         |
| Enable-DHCP Client Packet                      | 5     | RW     | 0                |                                                                                         |
| Enable-ARP Packet                              | 4     | RW     | 0                |                                                                                         |
| Enable-HTX2B Perfect Match Address[3]          | 3     | RW     | 0                |                                                                                         |
| Enable-HTX2B Perfect Match Address[2]          | 2     | RW     | 0                |                                                                                         |
| Enable-HTX2B Perfect Match Address[1]          | 1     | RW     | 0                |                                                                                         |
| Enable-HTX2B Perfect Match<br>Address[0]       | 0     | RW     | 0                |                                                                                         |

# 13.5.44 HTX2B Global Filter Reg (address: 0x6D4)

This register resides in TCE.

| Name                          | Bits | Access | Default<br>Value | Description                                                                                                                        |
|-------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Unused                        | 31:2 | RU     | 0xUUUU           | Unused.                                                                                                                            |
| HTX2B Broadcast Filter Enable | 1    | RW     | 0                | Write 1 to replicate and route all Host Send broadcast packets to APE. This bit overrides any conflicting Protocol Filter setting. |
| HTX2B Multicast Filter Enable | 0    | RW     | 0                | Write 1 to replicate and route all Host Send multicast packets to APE. This bit overrides any conflicting Protocol Filter setting. |

# 13.6 RSS Registers

All registers reset are core reset unless specified.

### 13.6.1 Indirection Table Register 0 (offset: 0x630)

| Name         | Bits  | Access | Default<br>Value | Description                     |
|--------------|-------|--------|------------------|---------------------------------|
| table_entry0 | 31:28 | RW     | 0                | The RSS_ring value for entry 0. |
| table_entry1 | 27:24 | RW     | 0                | The RSS_ring value for entry 1. |
| table_entry2 | 23:20 | RW     | 0                | The RSS_ring value for entry 2. |
| table_entry3 | 19:16 | RW     | 0                | The RSS_ring value for entry 3. |
| table_entry4 | 15:12 | RW     | 0                | The RSS_ring value for entry 4. |
| table_entry5 | 11:8  | RW     | 0                | The RSS_ring value for entry 5. |
| table_entry6 | 7:4   | RW     | 0                | The RSS_ring value for entry 6. |
| table_entry7 | 3:0   | RW     | 0                | The RSS_ring value for entry 7. |

# 13.6.2 Indirection Table Register 2 (offset: 0x634)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry8  | 31:28 | RW     | 0                | The RSS_ring value for entry 8.  |
| table_entry9  | 27:24 | RW     | 0                | The RSS_ring value for entry 9.  |
| table_entry10 | 23:20 | RW     | 0                | The RSS_ring value for entry 10. |
| table_entry11 | 19:16 | RW     | 0                | The RSS_ring value for entry 11. |
| table_entry12 | 15:12 | RW     | 0                | The RSS_ring value for entry 12. |
| table_entry13 | 11:8  | RW     | 0                | The RSS_ring value for entry 13. |
| table_entry14 | 7:4   | RW     | 0                | The RSS_ring value for entry 14. |
| table_entry15 | 3:0   | RW     | 0                | The RSS_ring value for entry 15. |

# 13.6.3 Indirection Table Register 3 (offset: 0x638)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry16 | 31:28 | RW     | 0                | The RSS_ring value for entry 16. |
| table_entry17 | 27:24 | RW     | 0                | The RSS_ring value for entry 17. |
| table_entry18 | 23:20 | RW     | 0                | The RSS_ring value for entry 18. |
| table_entry19 | 19:16 | RW     | 0                | The RSS_ring value for entry 19. |
| table_entry20 | 15:12 | RW     | 0                | The RSS_ring value for entry 20. |
| table_entry21 | 11:8  | RW     | 0                | The RSS_ring value for entry 21. |
| table_entry22 | 7:4   | RW     | 0                | The RSS_ring value for entry 22. |
| table_entry23 | 3:0   | RW     | 0                | The RSS_ring value for entry 23. |

# 13.6.4 Indirection Table Register 4 (offset: 0x63C)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry24 | 31:28 | RW     | 0                | The RSS_ring value for entry 24. |
| table_entry25 | 27:24 | RW     | 0                | The RSS_ring value for entry 25. |
| table_entry26 | 23:20 | RW     | 0                | The RSS_ring value for entry 26. |
| table_entry27 | 19:16 | RW     | 0                | The RSS_ring value for entry 27. |
| table_entry28 | 15:12 | RW     | 0                | The RSS_ring value for entry 28. |
| table_entry29 | 11:8  | RW     | 0                | The RSS_ring value for entry 29. |
| table_entry30 | 7:4   | RW     | 0                | The RSS_ring value for entry 30. |
| table_entry31 | 3:0   | RW     | 0                | The RSS_ring value for entry 31. |

# 13.6.5 Indirection Table Register 5 (offset: 0x640)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry32 | 31:28 | RW     | 0                | The RSS_ring value for entry 32. |
| table_entry33 | 27:24 | RW     | 0                | The RSS_ring value for entry 33. |
| table_entry34 | 23:20 | RW     | 0                | The RSS_ring value for entry 34. |
| table_entry35 | 19:16 | RW     | 0                | The RSS_ring value for entry 35. |
| table_entry36 | 15:12 | RW     | 0                | The RSS_ring value for entry 36. |
| table_entry37 | 11:8  | RW     | 0                | The RSS_ring value for entry 37. |
| table_entry38 | 7:4   | RW     | 0                | The RSS_ring value for entry 38. |
| table_entry39 | 3:0   | RW     | 0                | The RSS_ring value for entry 39. |

# 13.6.6 Indirection Table Register 6 (offset: 0x644)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry40 | 31:28 | RW     | 0                | The RSS_ring value for entry 40. |
| table_entry41 | 27:24 | RW     | 0                | The RSS_ring value for entry 41. |
| table_entry42 | 23:20 | RW     | 0                | The RSS_ring value for entry 42. |
| table_entry43 | 19:16 | RW     | 0                | The RSS_ring value for entry 43. |
| table_entry44 | 15:12 | RW     | 0                | The RSS_ring value for entry 44. |
| table_entry45 | 11:8  | RW     | 0                | The RSS_ring value for entry 45. |
| table_entry46 | 7:4   | RW     | 0                | The RSS_ring value for entry 46. |
| table_entry47 | 3:0   | RW     | 0                | The RSS_ring value for entry 47. |

# 13.6.7 Indirection Table Register 8 (offset: 0x648)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry48 | 31:28 | RW     | 0                | The RSS_ring value for entry 48. |
| table_entry49 | 27:24 | RW     | 0                | The RSS_ring value for entry 49. |
| table_entry50 | 23:20 | RW     | 0                | The RSS_ring value for entry 50. |
| table_entry51 | 19:16 | RW     | 0                | The RSS_ring value for entry 51. |
| table_entry52 | 15:12 | RW     | 0                | The RSS_ring value for entry 52. |
| table_entry53 | 11:8  | RW     | 0                | The RSS_ring value for entry 53. |
| table_entry54 | 7:4   | RW     | 0                | The RSS_ring value for entry 54. |
| table_entry55 | 3:0   | RW     | 0                | The RSS_ring value for entry 55. |

### 13.6.8 Indirection Table Register 8 (offset: 0x64C)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry56 | 31:28 | RW     | 0                | The RSS_ring value for entry 56. |
| table_entry57 | 27:24 | RW     | 0                | The RSS_ring value for entry 57. |
| table_entry58 | 23:20 | RW     | 0                | The RSS_ring value for entry 58. |
| table_entry59 | 19:16 | RW     | 0                | The RSS_ring value for entry 59. |
| table_entry60 | 15:12 | RW     | 0                | The RSS_ring value for entry 60. |
| table_entry61 | 11:8  | RW     | 0                | The RSS_ring value for entry 61. |
| table_entry62 | 7:4   | RW     | 0                | The RSS_ring value for entry 62. |
| table_entry63 | 3:0   | RW     | 0                | The RSS_ring value for entry 63. |

# 13.6.9 Indirection Table Register 9 (offset: 0x650)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry64 | 31:28 | RW     | 0                | The RSS_ring value for entry 64. |
| table_entry65 | 27:24 | RW     | 0                | The RSS_ring value for entry 65. |
| table_entry66 | 23:20 | RW     | 0                | The RSS_ring value for entry 66. |
| table_entry67 | 19:16 | RW     | 0                | The RSS_ring value for entry 67. |
| table_entry68 | 15:12 | RW     | 0                | The RSS_ring value for entry 68. |
| table_entry69 | 11:8  | RW     | 0                | The RSS_ring value for entry 69. |
| table_entry70 | 7:4   | RW     | 0                | The RSS_ring value for entry 70. |
| table_entry71 | 3:0   | RW     | 0                | The RSS_ring value for entry 71. |

### 13.6.10 Indirection Table Register 10 (offset: 0x654)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry72 | 31:28 | RW     | 0                | The RSS_ring value for entry 72. |
| table_entry73 | 27:24 | RW     | 0                | The RSS_ring value for entry 73. |
| table_entry74 | 23:20 | RW     | 0                | The RSS_ring value for entry 74. |
| table_entry75 | 19:16 | RW     | 0                | The RSS_ring value for entry 75. |
| table_entry76 | 15:12 | RW     | 0                | The RSS_ring value for entry 76. |
| table_entry77 | 11:8  | RW     | 0                | The RSS_ring value for entry 77. |
| table_entry78 | 7:4   | RW     | 0                | The RSS_ring value for entry 78. |
| table_entry79 | 3:0   | RW     | 0                | The RSS_ring value for entry 79. |

### 13.6.11 Indirection Table Register 11 (offset: 0x658)

| Name          | Bits  |    | Default<br>Value | Description                      |
|---------------|-------|----|------------------|----------------------------------|
| table_entry80 | 31:28 | RW | 0                | The RSS_ring value for entry 80. |
| table_entry81 | 27:24 | RW | 0                | The RSS_ring value for entry 81. |

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry82 | 23:20 | RW     | 0                | The RSS_ring value for entry 82. |
| table_entry83 | 19:16 | RW     | 0                | The RSS_ring value for entry 83. |
| table_entry84 | 15:12 | RW     | 0                | The RSS_ring value for entry 84. |
| table_entry85 | 11:8  | RW     | 0                | The RSS_ring value for entry 85. |
| table_entry86 | 7:4   | RW     | 0                | The RSS_ring value for entry 86. |
| table_entry87 | 3:0   | RW     | 0                | The RSS_ring value for entry 87. |

# 13.6.12 Indirection Table Register 12 (offset: 0x65C)

| Name          | Bits  | Access | Default<br>Value | Description                      |
|---------------|-------|--------|------------------|----------------------------------|
| table_entry88 | 31:28 | RW     | 0                | The RSS_ring value for entry 88. |
| table_entry89 | 27:24 | RW     | 0                | The RSS_ring value for entry 89. |
| table_entry90 | 23:20 | RW     | 0                | The RSS_ring value for entry 90. |
| table_entry91 | 19:16 | RW     | 0                | The RSS_ring value for entry 91. |
| table_entry92 | 15:12 | RW     | 0                | The RSS_ring value for entry 92. |
| table_entry93 | 11:8  | RW     | 0                | The RSS_ring value for entry 93. |
| table_entry94 | 7:4   | RW     | 0                | The RSS_ring value for entry 94. |
| table_entry95 | 3:0   | RW     | 0                | The RSS_ring value for entry 95. |

# 13.6.13 Indirection Table Register 12 (offset: 0x660)

| Name           | Bits  | Access | Default<br>Value | Description                       |
|----------------|-------|--------|------------------|-----------------------------------|
| table_entry96  | 31:28 | RW     | 0                | The RSS_ring value for entry 96.  |
| table_entry97  | 27:24 | RW     | 0                | The RSS_ring value for entry 97.  |
| table_entry98  | 23:20 | RW     | 0                | The RSS_ring value for entry 98.  |
| table_entry99  | 19:16 | RW     | 0                | The RSS_ring value for entry 99.  |
| table_entry100 | 15:12 | RW     | 0                | The RSS_ring value for entry 100. |
| table_entry101 | 11:8  | RW     | 0                | The RSS_ring value for entry 101. |
| table_entry102 | 7:4   | RW     | 0                | The RSS_ring value for entry 102. |
| table_entry103 | 3:0   | RW     | 0                | The RSS_ring value for entry 103. |

# 13.6.14 Indirection Table Register 13 (offset: 0x664)

| Name           | Bits  | Access | Default<br>Value | Description                       |
|----------------|-------|--------|------------------|-----------------------------------|
| table_entry104 | 31:28 | RW     | 0                | The RSS_ring value for entry 104. |
| table_entry105 | 27:24 | RW     | 0                | The RSS_ring value for entry 105. |
| table_entry106 | 23:20 | RW     | 0                | The RSS_ring value for entry 106. |
| table_entry107 | 19:16 | RW     | 0                | The RSS_ring value for entry 99.  |
| table_entry108 | 15:12 | RW     | 0                | The RSS_ring value for entry 100. |

| Name           | Bits |    | Default<br>Value | Description                       |
|----------------|------|----|------------------|-----------------------------------|
| table_entry109 | 11:8 | RW | 0                | The RSS_ring value for entry 101. |
| table_entry110 | 7:4  | RW | 0                | The RSS_ring value for entry 102. |
| table_entry111 | 3:0  | RW | 0                | The RSS_ring value for entry 103. |

#### 13.6.15 Indirection Table Register 14 (offset: 0x668)

| Name           | Bits  | Access | Default<br>Value | Description                       |
|----------------|-------|--------|------------------|-----------------------------------|
| table_entry112 | 31:28 | RW     | 0                | The RSS_ring value for entry 112. |
| table_entry113 | 27:24 | RW     | 0                | The RSS_ring value for entry 113. |
| table_entry114 | 23:20 | RW     | 0                | The RSS_ring value for entry 114. |
| table_entry115 | 19:16 | RW     | 0                | The RSS_ring value for entry 115. |
| table_entry116 | 15:12 | RW     | 0                | The RSS_ring value for entry 116. |
| table_entry117 | 11:8  | RW     | 0                | The RSS_ring value for entry 117. |
| table_entry118 | 7:4   | RW     | 0                | The RSS_ring value for entry 118. |
| table_entry119 | 3:0   | RW     | 0                | The RSS_ring value for entry 119. |

### 13.6.16 Indirection Table Register 15 (offset: 0x66C)

| Name           | Bits  | Access | Default<br>Value | Description                       |
|----------------|-------|--------|------------------|-----------------------------------|
| table_entry120 | 31:28 | RW     | 0                | The RSS_ring value for entry 120. |
| table_entry121 | 27:24 | RW     | 0                | The RSS_ring value for entry 121. |
| table_entry122 | 23:20 | RW     | 0                | The RSS_ring value for entry 122. |
| table_entry123 | 19:16 | RW     | 0                | The RSS_ring value for entry 123. |
| table_entry124 | 15:12 | RW     | 0                | The RSS_ring value for entry 124. |
| table_entry125 | 11:8  | RW     | 0                | The RSS_ring value for entry 125. |
| table_entry126 | 7:4   | RW     | 0                | The RSS_ring value for entry 126. |
| table_entry127 | 3:0   | RW     | 0                | The RSS_ring value for entry 127. |

### 13.6.17 Hash Key Register 0 (offset: 0x670)

| Name            | Bits  | Access | Default<br>Value | Description                                                                                         |
|-----------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------|
| Hash_key[7:0]   | 31:24 | RW     | 0                | The first byte of the hash_key. Bit31 is the first bit of the hash_key. It's the big endian format. |
| Hash_key[15:8]  | 23:16 | RW     | 0                | The 2nd byte of the hash_key. The bits are in the big endian format.                                |
| Hash_key[23:16] | 15:8  | RW     | 0                | The 3rd byte of the hash_key. The bits are in the big endian format.                                |
| Hash_key[31:24] | 7:0   | RW     | 0                | The 4th byte of the hash_key. The bits are in the big endian format.                                |

## 13.6.18 Hash Key Registers 1–8 (offset: 0x674–0x693)

The rest of Hash Keys for 5th through 36th bytes. They follow the same format as above.

# 13.6.19 Hash Key Register 9 (offset: 0x694)

| Name              | Bits  | Access | Default<br>Value | Description                                                           |
|-------------------|-------|--------|------------------|-----------------------------------------------------------------------|
| Hash_key[295:288] | 31:24 | RW     | 0                | The 37th byte of the hash_key. The bits are in the big endian format. |
| Hash_key[303:296] | 23:16 | RW     | 0                | The 38th byte of the hash_key. The bits are in the big endian format. |
| Hash_key[311:304] | 15:8  | RW     | 0                | The 39th byte of the hash_key. The bits are in the big endian format. |
| Hash_key[319:312] | 7:0   | RW     | 0                | The 40th byte of the hash_key. The bits are in the big endian format. |

# 13.6.20 Receive MAC Programmable IPv6 Extension Header Register (offset: 0x6A0)

| Name                                            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                      |
|-------------------------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Programmable Extension Header<br>Type #2 Enable | 31    | RW     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [15:8] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [15:8]. This bit should be set to 0 if IPv6 RX is disabled. |
| Programmable Extension Header<br>Type #1 Enable | 30    | RW     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [7:0] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [7:0]. This bit should be set to 0 if IPv6 RX is disabled.   |
| Reserved                                        | 29:16 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                |
| Programmable Extension Header Type #2           | 15:8  | RW     | 0                | These bits contain the programmable extension header value for programmable header #2.                                                                                                                                                                                                                           |
| Programmable Extension Header Type #1           | 7:0   | RW     | 0                | These bits contain the programmable extension header value for programmable header #1.                                                                                                                                                                                                                           |

# 13.7 Statistics Registers

Note: Access method for these registers (A/C and 32bit).

#### 13.7.1 Transmit MAC Static Counters

#### 13.7.1.1 ifHCOutOctets (offset: 0x800)

The number of octets transmitted out of the interface, including frame characters.

#### 13.7.1.2 etherStatsCollisions (offset: 0x808)

The number of collisions experienced.

#### 13.7.1.3 outXonSent (offset: 0x80C)

Sent Xon.

#### 13.7.1.4 outXoffSent (offset: 0x810)

Sent Xoff.

#### 13.7.1.5 dot3StatsInternalMacTransmitErrors (offset: 0x818)

A count of frames for which transmission on a particular interface fails due to an internal MAC sublayer transmit error.

#### 13.7.1.6 dot3StatsSingleCollisionFrames (offset: 0x81C)

A count of successfully transmitted frames on a particular interface for which transmission is inhibited by exactly one collision.

#### 13.7.1.7 dot3StatsMultipleCollisionFrames (offset: 0x820)

A count of successfully transmitted frames on a particular interface for which transmission is inhibited by more than one collision.

#### 13.7.1.8 dot3StatsDeferredTransmissions (offset: 0x824)

A count of frames for which the first transmission attempt on a particular interface is delayed because of the medium is busy.

#### 13.7.1.9 dot3StatsExcessiveTransmissions (offset: 0x82C)

A count of frames for which transmission on a particular interface fails due to excessive collisions.

#### 13.7.1.10 dot3StatsLateCollisions (offset: 0x830)

The number of times that a collision is detected on a particular interface later than 512 bit-times into the transmission of a packet.

#### 13.7.1.11 iHCOutUcastPkts (offset: 0x86C)

The number of packets that higher-level protocols requested be transmitted, and that were not addressed to a multicast or broadcast address at this sublayer, including those that were discarded or not sent.

#### 13.7.1.12 iHCOutMulticastPkts (offset: 0x870)

The number of packets that higher-level protocols requested be transmitted, and that were addressed to a multicast address at this sublayer, including those that were discarded or not sent.

#### 13.7.1.13 iHCOutBroadcastPkts (offset: 0x874)

The number of packets that higher-level protocols requested be transmitted, and that were addressed to a broadcast address at this sublayer, including those that were discarded or not sent.

#### 13.7.1.14 if CRSERRORS (offset: 0x878)

The number of packets that have CRS errors.

#### 13.7.1.15 iOUTDISCARDS (offset: 0x87C)

The number of packets that are discarded.

#### 13.7.2 H2B Statistics Registers

There are two sets of H2B Statistics registers – though both sets are accessible from Host as well as APE, each side shall own a set. Set1 is owned by Host Driver and Set2 is owned by APE. HTX2B Stats Registers resides in TX-MAC and the B2HRX Stats Registers reside in RDI. A counter is automatically reset to 0 by HW upon a Read Operation by software. All counters roll over.

#### 13.7.2.1 HTX2B Statistics

The HTX2B statistics reside in Transmit MAC. A counter is automatically reset to 0 by hardware upon a Read Operation. All counters roll over.

| Statistics Name   | Set1 Address | Set2 Address | Size | Description                                 |
|-------------------|--------------|--------------|------|---------------------------------------------|
| HTX2B Octets      | 0x700        | 0x720        | 32   | Total number of H2B octets.                 |
| HTX2B UCAST PKTS  | 0x704        | 0x724        | 32   | Number of H2B unicast frames.               |
| HTX2B MCAST PKTS  | 0x708        | 0x728        | 32   | Number of H2B multicast.                    |
| HTX2B BCAST PKTS  | 0x70C        | 0x72C        | 32   | Number of H2B broadcast frames.             |
| HTX2B DROP PKTS   | 0x710        | 0x730        | 32   | Number of H2B frames dropped by EMAC.       |
| HTX2B DROP OCTETS | 0x714        | 0x734        | 32   | Total number of H2B octets dropped by EMAC. |

#### 13.7.2.2 B2HRX Statistics

The B2HRX statistics reside in RDI.

| Statistics Name   | Set1 Address | Set2 Address | Size | Description                                |
|-------------------|--------------|--------------|------|--------------------------------------------|
| B2HRX OCTETS      | 0x24D0       | 0x24E8       | 32   | Total number of H2B octets.                |
| B2HRX UCAST PKTS  | 0x24D4       | 0x24EC       | 32   | Number of B2H unicast frames.              |
| B2HRX MCAST PKTS  | 0x24D8       | 0x24F0       | 32   | Number of B2H multicast frames.            |
| B2HRX BCAST PKT   | 0x24DC       | 0x24F4       | 32   | Number of B2H broadcast frames.            |
| B2HRX DROP PKTS   | 0x24E0       | 0x24F8       | 32   | Number of B2H frames dropped by RDI.       |
| B2HRX DROP OCTETS | 0x24E4       | 0x24FC       | 32   | Total number of B2H octets dropped by RDI. |

#### 13.7.3 Receive MAC Static Counters

#### 13.7.3.1 ifHCInOctets (offset: 0x880)

The number of octets received on the interface, including frame characters.

#### 13.7.3.2 ifHCINOctets\_bad (offset: 0x884)

The number of bad octets received on the interface.

#### 13.7.3.3 etherStatsFragments (offset: 0x888)

A frame size that is less than 64 bytes with a bad FCS.

#### 13.7.3.4 ifHCInUcastPkts (offset: 0x88C)

The number of packets delivered by this sublayer to a higher sublayer, which were not addressed to a multicast or broadcast address at this sublayer.

#### 13.7.3.5 ifHCInMulticastPkts (offset: 0x890)

The number of packets delivered by this sublayer to a higher sublayer, which were addressed to a multicast address at this sublayer.

#### 13.7.3.6 ifHCInBroadcastPkts (offset: 0x894)

The number of packets delivered by this sublayer to a higher sublayer, which were addressed to a broadcast address at this sublayer.

#### 13.7.3.7 dot3StatsFCSErrors (offset: 0x898)

A count of frames received on a particular interface that are an integral number of octets in length and do not pass the FCS check.

#### 13.7.3.8 dot3StatsAlignmentErrors (offset: 0x89C)

A count of frames received on a particular interface that are not an integral number of octets in length and do not pass the FCS check.

#### 13.7.3.9 xonPauseFrameReceived (offset: 0x8A0)

MAC control frames with pause command and length equal to zero.

#### 13.7.3.10 xoffPauseFrameReceived (offset: 0x8A4)

MAC control frames with pause command and length greater than zero.

#### 13.7.3.11 macControlFramesRecevied (offset: 0x8A8)

MAC control frames with no pause command.

#### 13.7.3.12 xoffStateEntered (offset: 0x8AC)

Transmitting is disabled.

#### 13.7.3.13 dot3StatsFramesTooLongs (offset: 0x8B0)

A count of frames received on a particular interface that exceeds the maximum permitted frame size.

#### 13.7.3.14 etherStatsJabbers (offset: 0x8B4)

Frames exceed jabber time.

#### 13.7.3.15 etherStatsUndersizePkts (offset: 0x8B8)

Frames with a size less than 64 bytes.

#### 13.7.3.16 Ifnomorerxbd:0x224C

The number of times the NIC overran the Receive Buffer Descriptors.

#### 13.7.3.17 Ifindiscard:0x2250

The number of inbound packets selected to be discarded (even though an error was not detected) to prevent the packets from being delivered to a higher layer protocol.

#### 13.7.3.18 Ifinerror:0x2254

The number of inbound packets containing errors that prevented the packets from being delivered to a higher-layer protocol.

### 13.7.4 APE\_NETWORK\_STATS\_REGS (Offsets 0x900-0x9BC)

These are duplicate network statistics registers meant for APE's private use. All of these registers accumulate their respective event-counts and the counts self clear to 0 when a GRC read accesses is performed on a register.

| Statistics Name          | Address | Size | Description |
|--------------------------|---------|------|-------------|
| Transmit Statistics      |         |      |             |
| IFHCOUTOCTETS            | 0x900h  | 32   |             |
| ETHERSTATSCOL            | 0x908h  | 16   |             |
| OUTXONSENT               | 0x90Ch  | 16   |             |
| OUTXOFFSENT              | 0x910h  | 16   |             |
| MACXMITERRORS            | 0x0918  | 16   |             |
| SINGLECOL                | 0x091C  | 16   |             |
| MULTICOL                 | 0x0920  | 16   |             |
| DEFERREDXMIT             | 0x0924  | 16   |             |
| EXCESSIVECOL             | 0x092C  | 16   |             |
| LATECOL                  | 0x0930  | 16   |             |
| IFHCOUTUCAST             | 0x096C  | 32   |             |
| IFHCOUTMCAST             | 0x0970  | 32   |             |
| IFHCOUTBCAST             | 0x0974  | 32   |             |
| CRSERRORS                | 0x0978  | 16   |             |
| IFOUTDISCARDS            | 0x097C  | 16   |             |
| Receive Statistics       |         |      |             |
| IFHCINOCTETS_GOOD        | 0x0980  | 32   |             |
| IFHCINOCTETS_BAD         | 0x0984  | 32   |             |
| ETHERSTATSFRAGMENTS      | 0x0988  | 16   |             |
| IFHCINUCASTPKTS          | 0x098C  | 32   |             |
| IFHCINMULTICASTPKTS      | 0x0990  | 32   |             |
| IFHCINBROADCASTPKTS      | 0x0994  | 32   |             |
| DOT3STATSFCSERRORS       | 0x0998  | 16   |             |
| DOT3STATSALIGNMENTERRORS | 0x099C  | 16   |             |
| XONPAUSEFRAMESRECEIVED   | 0x09A0  | 16   |             |
| XOFFPAUSEFRAMESRECEIVED  | 0x09A4  | 16   |             |
| MACCONTROLFRAMESRECEIVED | 0x09A8  | 16   |             |
| XOFFSTATEENTERED         | 0x09AC  | 16   |             |
| DOT3STATSFRAMESTOOLONG   | 0x09B0  | 16   |             |
| ETHERSTATSJABBERS        | 0x09B4  | 16   |             |
| ETHERSTATSUNDERSIZEPKTS  | 0x09B8  | 16   |             |

# 13.8 Send Data Initiator Registers

All registers reset are core reset unless specified.

### 13.8.1 Send Data Initiator Mode Register (offset: 0xC00)

| Name                          | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                     |
|-------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                      | 31:9 | RO     | 0                | -                                                                                                                                                                                                               |
| Incorrect BD flag fix disable | 8    | RW     | 0                | Disable fix for SDI sends incorrect last BD flag to SBDS.                                                                                                                                                       |
| Reserved                      | 7:6  | RO     | 0                | -                                                                                                                                                                                                               |
| Multiple Segment Enable       | 5    | RW     | 0                | Enable RDMA to read multisegment (up to four segments) in one DMA request during TCP segmentation.                                                                                                              |
| Pre-DMA Debug                 | 4    | RW     | 0                | When this bit is set, Send Data Initiator state machine will be halted if the pre-DMA bit of the Send BD is set.                                                                                                |
| Hardware Pre-DMA Enable       | 3    | RW     | 0                | Enable hardware LSO pre-DMA processing.                                                                                                                                                                         |
| Stats Overflow Attn Enable    | 2    | RW     | 0                | Enable attention for statistics overflow.                                                                                                                                                                       |
| Enable                        | 1    | RW     | 1                | This bit controls whether the Send Data Initiator state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                         | 0    | RW     | 0                | When this bit is set to 1, Send Data Initiator state machine is reset.                                                                                                                                          |
|                               |      |        |                  | This is a self-clearing bit.                                                                                                                                                                                    |

# 13.8.2 Send Data Initiator Status Register (offset: 0xC04)

| Name                     | Bits | Access | Default<br>Value | Description                                                 |
|--------------------------|------|--------|------------------|-------------------------------------------------------------|
| Reserved                 | 31:3 | RO     | 0                | _                                                           |
| Stats Overflow Attention | 2    | RO     | 0                | A statistics managed by Send Data Initiator has overflowed. |
| Reserved                 | 1:0  | RO     | 0                | _                                                           |

# 13.8.3 Send Data Initiator Statistics Control Register (offset: 0xC08)

| Name              | Bits | Access | Default<br>Value | Description                                                                                                                                                          |
|-------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved          | 31:5 | RO     | 0                | -                                                                                                                                                                    |
| Zap Statistic     | 4    | RW     | 0                | -                                                                                                                                                                    |
| Flush Statistic   | 3    | RW     | 0                | -                                                                                                                                                                    |
| Statistics Clear  | 2    | RW     | 0                | If set, resets local statistics counters to zero.                                                                                                                    |
|                   |      |        |                  | Clears only masked statistics.                                                                                                                                       |
|                   |      |        |                  | Self-clearing when done.                                                                                                                                             |
| Faster Update     | 1    | RW     | 0                | -                                                                                                                                                                    |
| Statistics Enable | 0    | RW     | 0                | When set, allows the local statistics counters to increment. When reset, counters hold their values until next update to NIC memory. Enables only masked statistics. |

#### 13.8.4 Send Data Initiator Statistics Mask Register (offset: 0xC0C)

| Name                 | Bits | Access | Default<br>Value | Description                                                                         |
|----------------------|------|--------|------------------|-------------------------------------------------------------------------------------|
| Reserved             | 31:1 | RO     | 0                | -                                                                                   |
| Counters Enable Mask | 0    | RW     | 0                | Controls whether Class of Service 0 statistics can be updated, cleared, or flushed. |

# 13.8.5 Send Data Initiator Statistics Increment Mask Register (offset: 0xC10)

| Name                    | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                              |
|-------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                | 31:24 | RO     | 0                | -                                                                                                                                                                                                                                                                        |
| Counters Increment Mask | 23:19 | WO     | 0                | Writing 1 to the bit position forces the corresponding statistics counters to increment by 1. Not affected by Statistics Enable Mask. Bits 16:23 correspond to Set Send Producer Index, Status Updated, Interrupts, Avoided Interrupts, Send Threshold Hit respectively. |
| Reserved                | 18:16 | RO     | 0                | -                                                                                                                                                                                                                                                                        |
| Counters Increment Mask | 15:0  | WO     | 0                | Writing 1 to the bit position forces the corresponding statistics counters to increment by 1. Not affected by Statistics Enable Mask. Bits 15:0 correspond to statistics for Class of Service 16:1                                                                       |

### 13.8.6 Local Statistics Register (offset: 0xC80-0xCDF)

| Name          | Bits  | Access | Default<br>Value | Description                                                               |
|---------------|-------|--------|------------------|---------------------------------------------------------------------------|
| Reserved      | 31:10 | RO     | 0                | _                                                                         |
| Counter Value | 9:0   | RO     | 0                | The current counter value for statistics kept by the Send Data Initiator. |

## 13.9 TCP Segmentation Control Registers

All registers reset are core reset unless specified.

### 13.9.1 Lower Host Address Register for TCP Segmentation (offset: 0xCE0)

| Name               | Bits | Access | Default<br>Value | Description                                                                                               |
|--------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------|
| Lower Host Address | 31:0 | RW     |                  | Specifies the lower 32bits of the starting address in host memory where the transmit data buffer resides. |

# 13.9.2 Upper Host Address Register for TCP Segmentation (offset: 0xCE4)

| Name               | Bits | Access | Default<br>Value | Description                                                                                               |
|--------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------|
| Upper Host Address | 31:0 | RW     |                  | Specifies the upper 32bits of the starting address in host memory where the transmit data buffer resides. |

### 13.9.3 Length/Offset Register for TCP Segmentation (offset: 0xCE8)

| Name        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                            |
|-------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved    | 31:23 | RO     | 0                | _                                                                                                                                                                                      |
| MBUF Offset | 22:16 | RW     | 0                | MBUF offset.                                                                                                                                                                           |
|             |       |        |                  | It specifies the offset of the first TXMBUF at where DMA starts putting data. The valid value is between 48 and 128.                                                                   |
| Length      | 15:0  | RW     | 0                | Specifies the length of data to be transmitted. Although firmware can specify up to 64 KB, it should not attempt to program more than 8 KB because it would exceed the size of TXMBUF. |

# 13.9.4 DMA Flag Register for TCP Segmentation (offset: 0xCEC)

| Name                         | Bits  | Access | Default<br>Value | Description                                                                                                                            |
|------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                     | 31:26 | RO     | _                | -                                                                                                                                      |
| Reserved                     | 25:20 | RW     | _                | -                                                                                                                                      |
| MBUF offset valid            | 19    | RW     | _                | MBUF offset valid.                                                                                                                     |
|                              |       |        |                  | When this bit is set, the RDMA engine will DMA the data into the TXMBUF starting at an offset specified in the Length/Offset register. |
| Last Fragment                | 18    | RW     | _                | Last fragment. This bit is passed transparently to the SDC.                                                                            |
|                              |       |        |                  | When this bit is set, the SDC will inform the HC to increment the Send Ring Consumer Index.                                            |
|                              |       |        |                  | The bit is always set by hardware if no firmware assisted TCP segmentation occurs.                                                     |
|                              |       |        |                  | Otherwise, firmware sets it at the end of fragmentation.                                                                               |
| No Word Swap                 | 17    | RW     | _                | No Word Swap.                                                                                                                          |
|                              |       |        |                  | Set to disable endian word swap on data from PCIE bus.                                                                                 |
| Status_dma                   | 16    | RW     | _                | -                                                                                                                                      |
| MAC source address Select    | 15:14 | RW     | _                | This 2-bit field determines which of the four MAC addresses should be inserted into the frame.                                         |
| MAC source address insertion | 13    | RW     | _                | Indicates that the predetermined source address is inserted into the Ethernet header of the frame.                                     |
| TCP/UDP checksum enable      | 12    | RW     | _                | TCP/UDP Checksum enable.                                                                                                               |
| IP Checksum enable           | 11    | RW     | _                | IP checksum enable.                                                                                                                    |
| Force RAW checksum enable    | 10    | RW     | _                | Force RAW checksum enable.                                                                                                             |
| Data_only                    | 9     | RO     | _                | -                                                                                                                                      |
| Header                       | 8     | RW     | _                | -                                                                                                                                      |

| Name               | Bits | Access | Default<br>Value | Description                                                                                            |
|--------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------|
| VLAN Tag Present   | 7    | RW     | _                | VLAN Tag present.                                                                                      |
|                    |      |        |                  | Indicates that the VLAN tag should be copied to the Frame Header by the DMA engine.                    |
| Force Interrupt    | 6    | RW     | _                | Following the completion of this DMA, a host interrupt is generated.                                   |
| Last BD in Frame   | 5    | RW     | _                | Last BD in frame.                                                                                      |
| Coalesce Now       | 4    | RW     | _                | Pass through Send Buffer Descriptor flag.                                                              |
| mbuf               | 3    | RW     | _                | -                                                                                                      |
| Invoke Processor   | 2    | RW     | _                | Clears the Pass bit of the entry queued to the SDCQ, so that SDC will invoke CPU.                      |
|                    |      |        |                  | If the packet is created by hardware, this bit will be the same as bit 9 of the flag field in Send BD. |
|                    |      |        |                  | If the packet is created by firmware, it will be up to CPU whether it needs to post-process the data.  |
| Don't Generate CRC | 1    | RW     | _                | Do not generate CRC.                                                                                   |
|                    |      |        |                  | Pass through Send Buffer Descriptor flag.                                                              |
| No Byte Swap       | 0    | RW     | _                | Set to disable endian byte swap on data from PCIE bus.                                                 |

# 13.9.5 VLAN Tag Register for TCP Segmentation (offset: 0xCF0)

| Name     | Bits  | Access | Default<br>Value | Description                                                                          |
|----------|-------|--------|------------------|--------------------------------------------------------------------------------------|
| Reserved | 31:16 | RO     | 0                | _                                                                                    |
| VLAN Tag | 15:0  | RW     | 0                | VLAN Tag to be inserted into the Frame Header if bit 7 of DMA Flags register is set. |

# 13.9.6 Pre-DMA Command Exchange Register for TCP Segmentation (offset: 0xCF4)

| Name                   | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                  |
|------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| READY                  | 31   | RW     | 0                | The CPU sets this bit to tell SDI that DMA address, length, flags, and VLAN tag are valid and request is read to go.  The CPU polls this bit to be clear for the completion of request.  0xCF4.31 is writable only if 0xCE8.15:0 is nonzero. |
| PASS Status            | 30   | RO     | 1                | If this bit is set to 0, the CPU will be responsible for processing the buffer descriptor                                                                                                                                                    |
| SKIP Status            | 29   | RW     | 0                | The CPU sets this bit to 1 to inform the SDI that the TCP Segmentation is completed, and the BD_Index can be incremented.                                                                                                                    |
| Unsupported_Mss Status | 28   | RO     | 0                | -                                                                                                                                                                                                                                            |
| Reserved               | 27:7 | RO     | 0                | -                                                                                                                                                                                                                                            |
| BD Index               | 6:0  | RO     | 0                | The internal current buffer descriptor pointer that the hardware/ firmware is servicing.                                                                                                                                                     |

# 13.10 Send Data Completion Control Registers

All registers reset are core reset unless specified.

### 13.10.1 Send Data Completion Mode Register (offset: 0x1000)

| Name                            | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                  |
|---------------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                        | 31:5 | RO     | 0                | -                                                                                                                                                                                                            |
| Disable Delayed Host Coalescing | 4    | RW     | 0                | A value 1 disables the Delayed HC feature introduced in BCM571X/BCM5720 family.                                                                                                                              |
| Reserved                        | 3:2  | RO     | 0                | -                                                                                                                                                                                                            |
| Enable                          | 1    | RW     | 1                | This bit controls whether Send Data Completion state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                           | 0    | RW     | 0                | When this is set to 1, the Send Data Completion state machine is reset. This is a self-clearing bit.                                                                                                         |

# 13.10.2 Pre-DMA Command Exchange Register for TCP Segmentation (offset: 0x1008)

| Name                 | Bits  | Access | Default<br>Value | Description                                                                                                        |
|----------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------|
| PASS                 | 31    | RW     | 1                | If this bit is set to 0, the CPU will be invoked to process TXMBUF data.                                           |
|                      |       |        |                  | It is same as SDCQ bit 143.                                                                                        |
| SKIP                 | 30    | RW     | 0                | CPU Sets this bit to 1 to inform the SDC that the post-processing is completed and hardware can resume operation.  |
| End of Fragmentation | 29    | RW     | 1                | If this bit is set to 1, SDC will request the HC to increment Send Ring Consumer Index when CPU sets the SKIP bit. |
|                      |       |        |                  | It is same as SDCQ bit 12.                                                                                         |
| Reserved             | 28:12 | RO     | 0                | -                                                                                                                  |
| Head TXMBUF pointer  | 11:6  | RW     | 0                | Head TXMBUF Pointer.                                                                                               |
|                      |       |        |                  | They are same as SDCQ bits 11:6.                                                                                   |
| Tail TXMBUF pointer  | 5:0   | RW     | 0                | Tail TXMBUF Pointer.                                                                                               |
|                      |       |        |                  | They are same as SDCQ bits 5:0                                                                                     |

# 13.11 Send BD Selector Control Registers

All registers reset are core reset unless specified.

#### 13.11.1 Send BD Ring Selector Mode Register (offset: 0x1400)

| Name                           | Bits | Access | Default<br>Value | Description                                                                                                                 |
|--------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Reserved                       | 31:4 | RO     | 0                | -                                                                                                                           |
| SBD consumer index fix disable | 3    | RW     | 0                | Disable for sbd consumer index does not rollover for ring sizes 32,64,128, 256.                                             |
| Attention Enable               | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                         |
| Enable                         | 1    | RW     | 0                | This bit controls whether Send BD Ring Selector state machine is active or not.                                             |
|                                |      |        |                  | When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains 1 when read. |
| Reset                          | 0    | RW     | 0                | When this is set to 1, the Send BD Ring Selector State machine is reset.                                                    |
|                                |      |        |                  | This is a self clearing bit.                                                                                                |

#### 13.11.2 Send BD Ring Selector Status Register (offset: 0x1404)

| Name     | Bits |    | Default<br>Value | Description                         |
|----------|------|----|------------------|-------------------------------------|
| Reserved | 31:3 | RO | 0                | -                                   |
| Error    | 2    | RO | 0                | Send BD Ring Selector error status. |
| Reserved | 1:0  | RO | 0                | -                                   |

#### 13.11.3 Send BD Ring Selector Hardware Diagnostics Register (offset: 0x1408)

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 31:0 | RO     | 0                | _           |

# 13.11.4 Send BD Ring Selector Local NIC Send BD Consumer Index Register (offset: 0x1440–0x147C)

| Name     | Bits | Access | Default<br>Value | Description                                       |
|----------|------|--------|------------------|---------------------------------------------------|
| Reserved | 31:9 | RO     | 0                | _                                                 |
| Index    | 8:0  | RO     |                  | These bits contain the current NIC send BD index. |

Each register applies to:

| Name                                          | Description                   |
|-----------------------------------------------|-------------------------------|
| 0x1440-0x1443 Send BD Ring Selector Local NIC | Send BD 1 Consumer Index RO.  |
| 0x1444-0x1447 Send BD Ring Selector Local NIC | Send BD 2 Consumer Index RO.  |
| 0x1448-0x144b Send BD Ring Selector Local NIC | Send BD 3 Consumer Index RO.  |
| 0x144c-0x144f Send BD Ring Selector Local NIC | Send BD 4 Consumer Index RO.  |
| 0x1450-0x1453 Send BD Ring Selector Local NIC | Send BD 5 Consumer Index RO.  |
| 0x1454-0x1457 Send BD Ring Selector Local NIC | Send BD 6 Consumer Index RO.  |
| 0x1458-0x145b Send BD Ring Selector Local NIC | Send BD 7 Consumer Index RO.  |
| 0x145c-0x145f Send BD Ring Selector Local NIC | Send BD 8 Consumer Index RO.  |
| 0x1460-0x1463 Send BD Ring Selector Local NIC | Send BD 9 Consumer Index RO.  |
| 0x1464-0x1467 Send BD Ring Selector Local NIC | Send BD 10 Consumer Index RO. |
| 0x1468-0x146b Send BD Ring Selector Local NIC | Send BD 11 Consumer Index RO. |
| 0x146c-0x146f Send BD Ring Selector Local NIC | Send BD 12 Consumer Index RO. |
| 0x1470-0x1473 Send BD Ring Selector Local NIC | Send BD 13 Consumer Index RO. |
| 0x1474-0x1477 Send BD Ring Selector Local NIC | Send BD 14 Consumer Index RO. |
| 0x1478-0x147b Send BD Ring Selector Local NIC | Send BD 15 Consumer Index RO. |
| 0x147c-0x147f Send BD Ring Selector Local NIC | Send BD 16 Consumer Index RO. |

# 13.12 Send BD Initiator Control Registers

All registers reset are core reset unless specified.

### 13.12.1 Send BD Initiator Mode Register (offset: 0x1800)

| Name                    | Bits | Access | Default<br>Value | Description                                                                                                                                          |
|-------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | 31.6 |        |                  | Unchanged                                                                                                                                            |
| Reserved                | 31:5 | RO     | 0                | -                                                                                                                                                    |
| Multiple Send Ring mode | 5    | RW     | 0                | Write a 1 to enable 16 Send Rings.                                                                                                                   |
|                         |      |        |                  | Write a 0 to limit to a Single Send Ring.                                                                                                            |
|                         | 4:0  |        |                  | Unchanged                                                                                                                                            |
| Pass_bit status         | 4    | RW     | 0                | Always return 1 when read.                                                                                                                           |
| Sbdi_rupd_enable        | 3    | RW     | 0                | -                                                                                                                                                    |
| Attention Enable        | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                  |
| Enable                  | 1    | RW     | 1                | This bit controls whether the Send BD Initiator state machine is active or not. When set to 0, it completes the current operation and cleanly halts. |
|                         |      |        |                  | Until it is completely halted, it remains 1 when read.                                                                                               |
| Reset                   | 0    | RW     | 0                | When this is set to 1, the Send BD Initiator State machine is reset.                                                                                 |
|                         |      |        |                  | This is a self clearing bit.                                                                                                                         |

### 13.12.2 Send BD Initiator Status Register (offset: 0x1804)

| Name     | Bits |    | Default<br>Value | Description              |
|----------|------|----|------------------|--------------------------|
| Reserved | 31:3 | RO | 0                | -                        |
| Error    | 2    | RO | 0                | Send BD Initiator Error. |
| Reserved | 1:0  | RO | 0                | -                        |

# 13.12.3 Send BD Diagnostic Initiator Local NIC BD N Producer Index Registers (offset: 0x1808–0x1844)

This set of registers is used to keep track of the current DMAs queued to move send BDs from the host to the NIC.

Each register applies to:

| Send BD Initiator Local NIC | Send BD Producer Index        |
|-----------------------------|-------------------------------|
| 0x1808-0x180b               | Send BD 1 Producer Index RO.  |
| 0x180c-0x180f               | Send BD 2 Producer Index RO.  |
| 0x1810-0x1813               | Send BD 3 Producer Index RO.  |
| 0x1814-0x1817               | Send BD 4 Producer Index RO.  |
| 0x1818-0x181b               | Send BD 5 Producer Index RO.  |
| 0x181c-0x181f               | Send BD 6 Producer Index RO.  |
| 0x1820-0x1823               | Send BD 7 Producer Index RO.  |
| 0x1824-0x1827               | Send BD 8 Producer Index RO.  |
| 0x1828-0x182b               | Send BD 9 Producer Index RO.  |
| 0x182c-0x182f               | Send BD 10 Producer Index RO. |
| 0x1830-0x1833               | Send BD 11 Producer Index RO. |
| 0x1834-0x1837               | Send BD 12 Producer Index RO. |
| 0x1838-0x183b               | Send BD 13 Producer Index RO. |
| 0x183c-0x183f               | Send BD 14 Producer Index RO. |
| 0x1840-0x1843               | Send BD 15 Producer Index RO. |
| 0x1844-0x1847               | Send BD 16 Producer Index RO. |

# 13.12.4 Send BD Fetch Threshold Register (offset: 0x1850)

| Name                    | Bits | Access | Default<br>Value | Description                                                                                                                                                                                      |
|-------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                | 31:6 | RO     | 0x00             | Unused                                                                                                                                                                                           |
| Send BD Fetch Threshold | 5:0  | RW     | 0x1F             | The value programmed in this field sets a cap to the number of SBDs that would be fetched by a single DMA transaction (although there are other factors which might further limit the DMA size). |
|                         |      |        |                  | This parameter uniformly applies to all 16 Send Rings.                                                                                                                                           |
|                         |      |        |                  | This parameter is meaningful only in the Multiple Send Ring mode. 0x1800[5] == 1                                                                                                                 |

### 13.12.5 Send Mail Box Registers

15 more Host Send Producer Index registers are added to the High Priority Mail Box region as shown in the Table below. Similarly, 15 more NIC Send Producer Index registers are also added in the GRC space.

| Send Ring # | Host Send Ring Producer Index (High Priority Mail Box) | NIC Send Ring<br>Producer Index | NIC Diagnostic<br>Send Ring<br>Consumer Index | Usable in                                |
|-------------|--------------------------------------------------------|---------------------------------|-----------------------------------------------|------------------------------------------|
| Legacy /1   | 0x304                                                  | 0x5980                          | 0x3CC0                                        | Legacy Mode,<br>RSS Mode and<br>IOV Mode |
| 2           | 0x300                                                  | 0x5984                          | 0x3F04                                        |                                          |
| 3           | 0x30C                                                  | 0x5988                          | 0x3F08                                        | RSS Mode and                             |
| 4           | 0x308                                                  | 0x598C                          | 0x3F0C                                        | IOV Mode                                 |
| 5           | 0x314                                                  | 0x5990                          | 0x3F10                                        |                                          |
| 6           | 0x310                                                  | 0x5994                          | 0x3F14                                        |                                          |
| 7           | 0x31C                                                  | 0x5998                          | 0x3F18                                        | IOV Mode Only                            |
| 8           | 0x318                                                  | 0x599C                          | 0x3F1C                                        |                                          |
| 9           | 0x324                                                  | 0x59A0                          | 0x3F20                                        |                                          |
| 10          | 0x320                                                  | 0x59A4                          | 0x3F24                                        |                                          |
| 11          | 0x32C                                                  | 0x59A8                          | 0x3F28                                        |                                          |
| 12          | 0x328                                                  | 0x59AC                          | 0x3F2C                                        |                                          |
| 13          | 0x334                                                  | 0x59B0                          | 0x3F30                                        |                                          |
| 14          | 0x330                                                  | 0x59B4                          | 0x3F34                                        |                                          |
| 15          | 0x33C                                                  | 0x59B8                          | 0x3F38                                        |                                          |
| 16          | 0x338                                                  | 0x59BC                          | 0x3F3C                                        |                                          |

# 13.13 Send BD Completion Control Registers

All registers reset are core reset unless specified.

# 13.13.1 Send BD Completion Mode Register (offset: 0x1C00)

| Name                                                  | Bits | Access | Default<br>Value | Description                                                                                                                                           |
|-------------------------------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                              | 31:3 | RO     | 0                | -                                                                                                                                                     |
| Attention Enable                                      | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                   |
| Enable                                                | 1    | RW     | 1                | This bit controls whether the Send BD Completion state machine is active or not. When set to 0, it completes the current operation and cleanly halts. |
| Until it is completely halted, it remains 1 when read |      |        |                  | _                                                                                                                                                     |
| Reset                                                 | 0    | RW     | 0                | When this is set to 1, the Send BD Completion State machine is reset.                                                                                 |
| This is a self clearing bit                           |      |        |                  | -                                                                                                                                                     |

# 13.14 Receive List Placement Registers

All registers reset are core reset unless specified.

### 13.14.1 Receive List Placement Mode Register (offset: 0x2000)

| Name                                  | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                        |
|---------------------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                              | 31:5 | RO     | 0                | -                                                                                                                                                                                                                  |
| Stats Overflow Attention Enable       | 4    | RW     | _                | Enable attention for statistics overflow.                                                                                                                                                                          |
| Mapping out of Range Attention Enable | 3    | RW     | _                | Enable attention for mapping out of range error.                                                                                                                                                                   |
| Class Zero Attention Enable           | 2    | RW     | _                | Enable attention for zero class field.                                                                                                                                                                             |
| Enable                                | 1    | RW     | 1                | This bit controls whether the Receive List Placement state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                                 | 0    | RW     | 0                | When this bit is set to 1, the Receive List Placement state machine is reset.  This is a self clearing bit.                                                                                                        |

### 13.14.2 Receive List Placement Status Register (offset: 0x2004)

| Name                           | Bits | Access | Default<br>Value | Description                                                              |
|--------------------------------|------|--------|------------------|--------------------------------------------------------------------------|
| Reserved                       | 31:5 | RO     | 0                | -                                                                        |
| Stats Overflow Attention       | 4    | RO     | _                | A statistics managed by Receive List Placement has overflowed.           |
| Mapping out of Range Attention | 3    | RO     | _                | Class of service mapping is out of the range of the active queue number. |
| Class Zero Attention           | 2    | RO     | _                | Class field extracted from frame descriptor is zero.                     |
| Reserved                       | 1:0  | RO     | 0                | -                                                                        |

#### 13.14.3 Receive Selector Non-Empty Bits Register (offset: 0x200C)

This 32-bit register is used by the RISCs to quickly determine the status of the receive selector. Bit 0 refers to receive selector list 1. Bit 15 refers to receive selector list 16. If this register is nonzero the receive selector non-empty bit is set in the RXCPU event register.

| Name                | Bits  | Access | Default<br>Value | Description                                                                                       |
|---------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------|
| Reserved            | 31:16 | RO     | 0                | _                                                                                                 |
| List non-empty bits | 15:0  | RO     | _                | If set, the bit indicates that the associated list is not empty (that is the counter is nonzero). |

#### 13.14.4 Receive List Placement Configuration Register (offset: 0x2010)

| Name                                      | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                  | 31:15 | RO     | 0                | -                                                                                                                                                                                                                                                                                                            |
| Default Interrupt Distribution<br>Queue   | 14:13 | RW     | 0                | Default interrupt distribution queue. Number within a class of service group when the frame has errors, is truncated, or is a non-IP frame.                                                                                                                                                                  |
| Bad Frames Class                          | 12:8  | RO     | 1                | Default class for error or truncated frames. These frames are placed in this class of service group when the Allow Bad Frame bit (bit 11) is set in the Mode Control Register.                                                                                                                               |
| Number of Active Lists                    | 7:3   | RW     | 0                | The total number of active receive lists. The value must be between 1 and 16. This value must be an integer multiple of the Number of Lists per Distribution Group value.                                                                                                                                    |
| Number of Lists per Distribution<br>Group | 2:0   | RW     | 0                | Specifies the number of lists per interrupt distribution group. This register must always be a power of 2. For example, if the system wants four classes of service and four interrupt distribution lists per class of service, this value is set to four and the Number of Active Lists value is set to 16. |

### 13.14.5 Receive List Placement Statistics Control Register (offset: 0x2014)

| Name              | Bits | Access | Default<br>Value | Description                                                                        |
|-------------------|------|--------|------------------|------------------------------------------------------------------------------------|
| Reserved          | 31:3 | RO     | 0                | -                                                                                  |
| Statistics Clear  | 2    | RW     | 0                | When set, resets local statistics counters to zero. Clears only masked statistics. |
|                   |      |        |                  | Self-clearing when done.                                                           |
| Reserved          | 1    | RO     | 0                | -                                                                                  |
| Statistics Enable | 0    | RW     | 0                | When set, allow the local statistics counters to increment.                        |
|                   |      |        |                  | When reset, counters hold their values until the next update to the NIC memory.    |
|                   |      |        |                  | Enables only masked statistics.                                                    |

# 13.14.6 Receive List Placement Statistics Enable Mask Register (offset: 0x2018)

| Name                           | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                       |
|--------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                       | 31:26 | RO     | 0                | -                                                                                                                                                                                                                 |
| RSS_Priority                   | 25    | RW     | 0x0              | This bit enables the receive packet to choose receive return ring in terms of RSS hash value instead of RC class when both RSS and RC rules are matched. Default is to give priority to RC.                       |
| RC Return Ring Enable          | 24    | RW     | 0x0              | 1: Enable receive packet to use RC rule class as return ring number if RC rule is matched. This bit will be used in conjunction with bit25 to derive the final receive return ring.                               |
|                                |       |        |                  | 0: Disable receive packet to use RC rule class as return ring number. Receive packet only uses RSS hash to select the receive return ring. If no any RSS hash types are applied, the default ring 0 will be used. |
| CPU MACTQ Priority Disable     | 23    | RW     | 0x0              | 1: Disable CPU priority over SDC when arbitrating the MACTQ write requests.                                                                                                                                       |
|                                |       |        |                  | 0: Enable CPU priority over SDC when arbitrating the MACTQ write requests.                                                                                                                                        |
| Reserved                       | 22:19 | RO     | 0                | -                                                                                                                                                                                                                 |
| Disable MACTQ Double Ack issue | 18    | RW     | 1                | Disable MACTQ double ack issue fix.                                                                                                                                                                               |
| fix                            |       |        |                  | 1: Disabled                                                                                                                                                                                                       |
|                                |       |        |                  | 0: Enabled                                                                                                                                                                                                        |
| Reserved                       | 17:2  | RO     | N/A              | _                                                                                                                                                                                                                 |
| Disable ASF Lockup Issue Fix   | 1     | RW     | 1                | Disable ASF Lockup Fix.                                                                                                                                                                                           |
|                                |       |        |                  | 1: Disabled                                                                                                                                                                                                       |
|                                |       |        |                  | 0: Enabled                                                                                                                                                                                                        |
| Reserved                       | 0     | RO     | 0                | -                                                                                                                                                                                                                 |

# 13.14.7 Receive List Placement Statistics Increment Mask Register (offset: 0x201C)

| Name                          | Bits  | Access   | Default<br>Value | Description                                                                                                                                                                                              |
|-------------------------------|-------|----------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                      | 31:22 | RO       | 0                | -                                                                                                                                                                                                        |
| Counters Increment Mask 21:16 | 21:16 | 21:16 WO | 0                | Writing a 1 to a Counters Increment Mask bit forces the corresponding statistics counter to increment by 1. Not affected by Statistics Enable Mask.                                                      |
|                               |       |          |                  | Bits 16-21 correspond to statistics for Drop due to filter, DMA Write Queue Full, DMA High Priority Write Queue Full, No More Receive BD, ifInDiscards, and ifInErrors.                                  |
| Reserved                      | 15:1  | RO       | 0                | -                                                                                                                                                                                                        |
| Counters Increment Mask       | 0     | WO       | 0                | Writing a 1 to a Counters Increment Mask bit forces the corresponding statistics counter to increment by 1. Not affected by Statistics Enable Mask.  Bit 0 corresponds to statistics Class of Service 1. |

#### 13.14.8 Receive Selector List Head & Tail Pointers (offset: 0x2100)

The 16 receive selector lists head and tail pointers are MBUF cluster pointers. The selector list head pointer is the MBUF cluster pointer of the first frame queued in the associated selector list. Similarly, the selector list tail pointer is the MBUF cluster pointer of the last frame queued in that selector list.

#### 13.14.9 Receive Selector List 1 Count Registers (Offset: 0x2108)

These registers indicate how many frames are currently queued to the associated selector list.

Receive Selector List 2 Count Register (offset: 0x2118)

Receive Selector List 3 Count Registers (offset: 0x2128)

Receive Selector List 4 Count Registers (offset: 0x2138)

Receive Selector List 5 Count Registers (offset: 0x2148)

Receive Selector List 6 Count Registers (offset: 0x2158)

Receive Selector List 7 Count Registers (offset: 0x2168)

Receive Selector List 8 Count Registers (offset: 0x2178)

Receive Selector List 9 Count Registers (offset: 0x2188)

Receive Selector List 10 Count Registers (offset: 0x2198)

Receive Selector List 11 Count Registers (offset: 0x21a8)

Receive Selector List 12 Count Registers (offset: 0x21b8)

Receive Selector List 13 Count Registers (offset: 0x21c8)

Receive Selector List 14 Count Registers (offset: 0x21d8)

Receive Selector List 15 Count Registers (offset: 0x21e8)

Receive Selector List 16 Count Registers (offset: 0x21f8)

# 13.15 Receive Data and Receive BD Initiator Control Registers

All registers reset are core reset unless specified.

### 13.15.1 Receive Data and Receive BD Initiator Mode Register (offset: 0x2400)

| Name                                               | Bits  | Access | Default<br>Value | Description                                                                                                                                               |
|----------------------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                           | 31:17 | RO     | 0                | _                                                                                                                                                         |
| Legacy                                             | 31:14 |        | 0                | Defined by Legacy                                                                                                                                         |
| Large RX Ring Sizes                                | 16    | RW     | 0                | When this bit is 1, following are the maximum allowable Receive Ring sizes:                                                                               |
|                                                    |       |        |                  | Standard Producer Ring == 2048                                                                                                                            |
|                                                    |       |        |                  | Jumbo Producer Ring == 1024                                                                                                                               |
|                                                    |       |        |                  | Receive Return Ring == 4096                                                                                                                               |
|                                                    |       |        |                  | When this bit is 0, following are the maximum allowable Receive Ring sizes:                                                                               |
|                                                    |       |        |                  | Standard Producer Ring == 512                                                                                                                             |
|                                                    |       |        |                  | Jumbo Producer Ring == 256                                                                                                                                |
|                                                    |       |        |                  | Receive Return Ring == 1024                                                                                                                               |
| Reserved                                           | 15    | RO     | 0                | _                                                                                                                                                         |
| No BD Discard Policy                               | 14:13 | RW     | 00               | This field decides what to do with a packet in RXMBUF belonging to a generic VRQ, when not a single BD is available in the VRQ's BD Cache:                |
|                                                    |       |        |                  | 00 => The RDI shall discard an RX packet belonging to a VRQ, if no corresponding RX BD is available in the VRQ's BD Cache                                 |
|                                                    |       |        |                  | 01 => RDI shall place the RX packet in the Default VRQ instead                                                                                            |
|                                                    |       |        |                  | 10 => RDI shall wait for a BD to become available in the VRQ's BD cache, no matter how long it takes.                                                     |
|                                                    |       |        |                  | 11 => Reserved for future use.                                                                                                                            |
|                                                    |       |        |                  | Ignored in non-IOV mode                                                                                                                                   |
| HDS Look-Ahead Boundary                            | 12:6  | RW     | 0x00             | This field indicates the size, in 1B increments, of the Header that the chip would replicate when HDS feature is enabled (meaningful only if bit[5] == 1) |
|                                                    |       |        |                  | 0x00 => 128B                                                                                                                                              |
|                                                    |       |        |                  | 0x01 => 1B                                                                                                                                                |
|                                                    |       |        |                  | 0x02 => 2B                                                                                                                                                |
|                                                    |       |        |                  |                                                                                                                                                           |
|                                                    |       |        |                  |                                                                                                                                                           |
|                                                    |       |        |                  | 0x7F => 127B                                                                                                                                              |
| 1100 5 11                                          | -     | DW     | 0                | Ignored in non-IOV mode.                                                                                                                                  |
| HDS Enable                                         | 5     | RW     | 0                | When this bit is written 1, the Header Data Split feature is enabled. This bit is meaningful only when IOV mode is enabled (0x400[5] == 1)                |
| Legacy                                             | 4:0   |        |                  | Defined by Legacy.                                                                                                                                        |
| Illegal Return Ring Size                           | 4     | RW     | _                | Enables illegal return ring size attention.                                                                                                               |
| Frame Size is too large to fit into one Receive BD | 3     | RW     | _                | Enables frame size is too large to fit into one Receive BD attention.                                                                                     |

| Name     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                       |
|----------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved | 2    | RO     | 0                | -                                                                                                                                                                                                                                 |
| Enable   | 1    | RW     | 1                | This bit controls whether the Receive Data and Receive BD Initiator state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset    | 0    | RW     | 0                | When this bit is set to 1, the Receive Data and Receive BD Initiator state machine is reset. This is a self-clearing bit.                                                                                                         |

# 13.15.2 Receive Data and Receive BD Initiator Status Register (offset: 0x2404)

| Name                                               | Bits | Access | Default<br>Value | Description                                                                            |
|----------------------------------------------------|------|--------|------------------|----------------------------------------------------------------------------------------|
| Reserved                                           | 31:5 | RO     | 0                | -                                                                                      |
| Illegal Return Ring Size                           | 4    | RO     | _                | One of the return rings contains illegal ring size (e.g., only contains 1024 entries). |
| Frame size is too large to fit into one Receive BD | 3    | RO     | _                | The received frame size is too big for the selected Receive BD.                        |
| Jumbo Frame Enable                                 | 2    | RW     | 0                | Enable Jumbo Receive BD is needed and Jumbo Receive BD ring is disabled attention.     |
| Reserved                                           | 1:0  | RO     | 0                | -                                                                                      |

# 13.15.3 VRQ Status Register (offset: 0x240C)

| Name               | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                               |
|--------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Legacy             | 31:17 | RU     | 0x0              | Unused                                                                                                                                                                                                    |
| VRQ Active Bit-Map | 16:0  | RW     | 0x0              | A position of the Bit-Map shows a 1, in case the VRQ is currently enabled or recently disabled and is at the verge of being flushed, and thus there could possibly be associated traffic inside the chip. |
|                    |       |        |                  | A bit-position shows 0, when a VRQ is completely disabled and there is no traffic whatsoever associated with it either inside the chip or in the PCle link between the chip and the Root-Complex.         |

# 13.15.4 VRQ Flush Control Register (Offset: 0x2410)

| Name                                   | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S/W flush IOV vector                   | 31:15 | RW     | 0x0              | S/W Flush vector [16:0].                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Reserved                               | 14:9  | RW     | 0x0              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| S/W flush reset request                | 8     | RW/SC  | 0x0              | Software writing 1 to this bit to force an internal index reset request. Bit-8 combining with [31:15] bit-map indicates which IOV index group to be reset. The function is identical to bit-1 hardware flush reset. This bit is self-clear.                                                                                                                                                                                                                |
| Reserved                               | 7:4   | RW     | 0x0              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| VRQ hardware flush drop enable         | 3     | RW     | 0x0              | 1: Enable hardware drop packet function immediately when the IOV enable bits are disabled from driver. This bit will force RDI and WDMA engines to place the incoming packets into drop queue when the IOV enable bit is disabled in EMAC for that particular IOV child process.                                                                                                                                                                           |
| VRQ status update and interrupt enable | 2     | RW     | 0x0              | 1: Enable hardware triggered host status interrupt and status block update request.                                                                                                                                                                                                                                                                                                                                                                        |
|                                        |       |        |                  | RDI engine will generate a single pulse request signal to HC alone with current IOV status vector value for status block update.                                                                                                                                                                                                                                                                                                                           |
| VRQ hardware flush reset enable        | 1     | RW     | 0x0              | 1: Enable hardware local index reset feature when VRQ flush timer expires.                                                                                                                                                                                                                                                                                                                                                                                 |
|                                        |       |        |                  | RDI engine will generate a single pulse clear request along with current IOV status [16:0] vector to various modules to clear local maintained index values for that particular IOV process.                                                                                                                                                                                                                                                               |
| VRQ hardware Flush enable              | 0     | RW     | 0x0              | This value will be loaded into a count-down counter triggered by a falling-edge of any bit of VRQ Enable register (0x560). The count-down is based on internal CORE_CLK. The purpose of this counter is to allow hardware to drain out certain pending DMA requests within WDMA pipeline and PCIE core. Once the timer expires, hardware shall invoke the Automatic VRQ Flush Procedure. A value 0x0 in this register effectively zeroes this timer count. |

#### 13.15.5 VRQ Flush Timer Register (offset: 0x2414)

| Name            | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IOV Flush Timer | 31:0 | RW     | 0x0              | This value will be loaded into a count-down counter triggered by a falling-edge of any bit of VRQ Enable register (0x560). The count-down is based on internal CORE_CLK. The purpose of this counter is to allow hardware to drain out certain pending DMA requests within WDMA pipeline and PCIE core. Once the timer expires, hardware shall invoke the Automatic VRQ Flush Procedure. A value 0x0 in this register effectively zeroes this timer count. |

#### 13.15.6 RDI B2HRX Hardware Debugging Register (offset: 0x2418)

| Name   | Bits | Access | Default<br>Value | Description                |
|--------|------|--------|------------------|----------------------------|
| Legacy | 31:0 | RO     | 0x0              | RDI internal B2HRX status. |

### 13.15.7 Jumbo Producer Ring Host Address High Register (offset: 0x2440)

| Name              | Bits | Access | Default<br>Value | Description                                                          |
|-------------------|------|--------|------------------|----------------------------------------------------------------------|
| Host Address High | 31:0 | RW     | 0                | The host ring address is the host address of the first ring element. |
|                   |      |        |                  | The host ring address is in host address format.                     |

## 13.15.8 Jumbo Producer Ring Host Address Low Register (offset: 0x2444)

| Name             | Bits | Access | Default<br>Value | Description                                                          |
|------------------|------|--------|------------------|----------------------------------------------------------------------|
| Host Address Low | 31:0 | RW     | 0                | The host ring address is the host address of the first ring element. |
|                  |      |        |                  | The host ring address is in host address format.                     |

### 13.15.9 Jumbo Producer Length/Flags Register (offset: 0x2448)

| Name         | Bits  | Access | Default<br>Value | Description                                                                                                     |
|--------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------|
| Max Length   | 31:16 | RW     | 0                | Specifies the number of entries for Jumbo ring based on bit-mask (Supported values are 32,64,128,256,512,1024). |
| Reserved     | 15:2  | RO     | 0                | -                                                                                                               |
| Disable Ring | 1     | RW     | 0                | Set to disable the use of the ring.                                                                             |
| Reserved     | 0     | RO     | 0                | -                                                                                                               |

### 13.15.10 Jumbo Producer Ring NIC Address Register (offset: 0x244C)

| Name        | Bits | Access | Default<br>Value | Description                                                                                     |
|-------------|------|--------|------------------|-------------------------------------------------------------------------------------------------|
| NIC Address | 31:0 | RW     | 0x0004440        | The NIC ring address is the NIC address of the first ring element.                              |
|             |      |        | 0                | <b>NOTE:</b> For the BCM571X/BCM5720 family, do not initialize this register; leave as default. |

### 13.15.11 Standard Receive BD Ring RCB Registers

#### 13.15.11.1 Receive Producer Ring Host Address High Register (offset: 0x2450)

| Name              | Bits |    | Default<br>Value | Description                                                                                                           |
|-------------------|------|----|------------------|-----------------------------------------------------------------------------------------------------------------------|
| Host Address High | 31:0 | RW |                  | The host ring address is the host address of the first ring element. The host ring address is in host address format. |

#### 13.15.11.2 Receive Producer Ring Host Address Low Register (offset: 0x2454)

| Name             | Bits | Access | Default<br>Value | Description                                                                                                           |
|------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------|
| Host Address Low | 31:0 | RW     | 0                | The host ring address is the host address of the first ring element. The host ring address is in host address format. |

#### 13.15.11.3 Receive Producer Length/Flags Register (offset: 0x2458)

| Name         | Bits  | Access | Default<br>Value | Description             |
|--------------|-------|--------|------------------|-------------------------|
| Max Length   | 31:16 | RW     | 0                | Programmable ring size: |
|              |       |        |                  | ■ 2048                  |
|              |       |        |                  | ■ 1024                  |
|              |       |        |                  | ■ 512                   |
|              |       |        |                  | <b>■</b> 256            |
|              |       |        |                  | ■ 128                   |
|              |       |        |                  | <b>■</b> 64             |
|              |       |        |                  | ■ 32                    |
| Reserved     | 15:2  | RO     | 0                | Maximum RX frame size.  |
| Disable Ring | 1     | RW     | 0                | 1 = Ring Disabled       |
|              |       |        |                  | 0 = Ring Enabled        |
| Reserved     | 0     | RO     | 0                | Reserved                |

#### 13.15.11.4 Receive Producer Ring NIC Address Register (offset: 0x245C)

| Name        | Bits | Access | Default<br>Value | Description                                                                        |
|-------------|------|--------|------------------|------------------------------------------------------------------------------------|
| NIC Address | 31:0 | RW     | 0x0004000        | The NIC ring address is the NIC address of the first ring element.                 |
|             |      |        |                  | For the BCM571X/BCM5720 family, do not initialize this register; leave as default. |

# 13.15.12 Receive Diagnostic Data and Receive BD Ring Initiator Local NIC Jumbo Receive BD Consumer Index (offset: 0x2470)

This set of registers keeps track of the current DMAs queued to move receive data from the controller to the host. The receive data and receive BD initiator maintains the state of the indices by keeping two local copies, a copy of the controller's return ring producer index and a copy of the controller's receive BD consumer index.

The local return ring producer index is set to the value placed in the DMA descriptor. The local controller receive return consumer index is also set to the value placed in the DMA descriptor.

# 13.15.13 Receive BD Ring Initiator Local NIC Standard Receive BD Consumer Index (offset: 0x2474)

This set of registers keeps track of the current DMAs queued to move receive data from the NIC to the host. The Receive Data and Receive BD Initiator maintains the state of the indices by keeping two local copies, a copy of the NIC's return ring producer index, and a copy of the NIC's receive BD consumer index. The local return ring producer index is set to the value placed in the DMA descriptor. The local NIC receive return consumer index is also set to the value placed in the DMA descriptor.

# 13.15.14 Receive Data and Receive BD Initiator Hardware Diagnostic Register (offset: 0x24C0)

| Name        | Bits | Access | Default<br>Value | Description          |
|-------------|------|--------|------------------|----------------------|
| Diagnostics | 31:0 | RO     | 0                | Hardware Diagnostics |

### 13.15.15 B2HRX Byte-count Statistics Count (offset: 0x24D0)

| Name         | Bits | Access | Default<br>Value | Description                         |
|--------------|------|--------|------------------|-------------------------------------|
| B2HRX OCTETS | 31:0 | CORW   | 0                | Host B2HRX total packet byte count. |

### 13.15.16 B2HRX Unicast Statistics Count (offset: 0x24D4)

| Name            | Bits | Access | Default<br>Value | Description                      |
|-----------------|------|--------|------------------|----------------------------------|
| B2HRX UCAST PKT | 31:0 | CORW   | 0                | Host B2HRX unicast packet count. |

### 13.15.17 B2HRX Multicast Statistics Count (offset: 0x24D8)

| Name            | Bits | Access | Default<br>Value | Description                        |
|-----------------|------|--------|------------------|------------------------------------|
| B2HRX MCAST PKT | 31:0 | CORW   | 0                | Host B2HRX multicast packet count. |

### 13.15.18 B2HRX Broadcast Statistics Count (offset: 0x24DC)

| Name            | Bits | Access | Default<br>Value | Description                        |
|-----------------|------|--------|------------------|------------------------------------|
| B2HRX BCAST PKT | 31:0 | CORW   | 0                | Host B2HRX broadcast packet count. |

### 13.15.19 B2HRX Drop Packet Count (offset: 0x24E0)

| Name           | Bits | Access | Default<br>Value | Description                                    |
|----------------|------|--------|------------------|------------------------------------------------|
| B2HRX DROP PKT | 31:0 | CORW   | 0                | Host B2HRX packet drop count due to empty RBD. |

### 13.15.20 B2HRX Drop Packet Byte Count (offset: 0x24E4)

| Name              | Bits | Access | Default<br>Value | Description                                         |
|-------------------|------|--------|------------------|-----------------------------------------------------|
| B2HRX DROP OCTETS | 31:0 | CORW   | 0                | Host B2HRX packet drop byte count due to empty RBD. |

### 13.15.21 B2HRX APE Byte-count Statistics Count (offset: 0x24E8)

| Name         | Bits | Access | Default<br>Value | Description                        |
|--------------|------|--------|------------------|------------------------------------|
| B2HRX OCTETS | 31:0 | CORW   | 0                | APE B2HRX total packet byte count. |

### 13.15.22 B2HRX APE Unicast Statistics Count (offset: 0x24EC)

| Name            | Bits | Access | Default<br>Value | Description                     |
|-----------------|------|--------|------------------|---------------------------------|
| B2HRX UCAST PKT | 31:0 | CORW   | 0                | APE B2HRX unicast packet count. |

## 13.15.23 B2HRX APE Multicast Statistics Count (offset: 0x24F0)

| Name            | Bits | Access | Default<br>Value | Description                       |
|-----------------|------|--------|------------------|-----------------------------------|
| B2HRX MCAST PKT | 31:0 | CORW   | 0                | APE B2HRX multicast packet count. |

## 13.15.24 B2HRX APE Broadcast Statistics Count (offset: 0x24F4)

| Name        | Bits | Access | Default<br>Value | Description                       |
|-------------|------|--------|------------------|-----------------------------------|
| B2HRX BCAST | 31:0 | CORW   | 0                | APE B2HRX broadcast packet count. |

## 13.15.25 B2HRX APE Drop Packet Count (offset: 0x24F8)

| Name           | Bits |      | Default<br>Value | Description                                   |
|----------------|------|------|------------------|-----------------------------------------------|
| B2HRX DROP PKT | 31:0 | CORW | 0                | APE B2HRX packet drop count due to empty RBD. |

## 13.15.26 B2HRX APE Drop Packet Byte Count (offset: 0x24FC)

| Name              | Bits | Access | Default<br>Value | Description                                        |
|-------------------|------|--------|------------------|----------------------------------------------------|
| B2HRX DROP OCTETS | 31:0 | CORW   | 0                | APE B2HRX packet drop byte count due to empty RBD. |

# 13.16 Receive Data Completion Control Registers

All registers reset are core reset unless specified.

## 13.16.1 Receive Data Completion Mode Register (offset: 0x2800)

| Name             | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                         |
|------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved         | 31:3 | RO     | 0                | -                                                                                                                                                                                                                   |
| Attention Enable | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                                                                                 |
| Enable           | 1    | RW     | 1                | This bit controls whether the Receive Data Completion state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset            | 0    | RW     | 0                | When this bit is set to 1, the Receive Data Completion state machine is reset. This is a self-clearing bit.                                                                                                         |

## 13.17 Receive BD Initiator Control Registers

All registers reset are core reset unless specified.

### 13.17.1 Receive BD Initiator Mode Register (offset: 0x2C00)

| Name                                                       | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                      |
|------------------------------------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                   | 31:3 | RO     | 0                | -                                                                                                                                                                                                                |
| Receive BDs available on a disabled Receive BD Ring Enable | 2    | RW     | 0                | Attention enable for Receive BDs available on a disabled Receive BD ring.                                                                                                                                        |
| Enable                                                     | 1    | RW     | 1                | This bit controls whether the Receive BD Initiator state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                                                      | 0    | RW     | 0                | When this bit is set to 1, the Receive BD Initiator state machine is reset. This is a self-clearing bit.                                                                                                         |

### 13.17.2 Receive BD Initiator Status Register (offset: 0x2C04)

| Name                                                       | Bits | Access | Default<br>Value | Description                                          |
|------------------------------------------------------------|------|--------|------------------|------------------------------------------------------|
| Reserved                                                   | 31:3 | RO     | 0                | -                                                    |
| Receive BDs available on a disabled Receive BD Ring status | 2    | RO     | 0                | Host requests to DMA Receive BDs to a disabled ring. |
| Reserved                                                   | 1:0  | RO     | 0                | -                                                    |

# 13.17.3 Receive BD Initiator Local NIC Jumbo Receive BD Producer Index (offset: 0x2C08)

| Name                                                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                         |
|----------------------------------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                 | 31:8 | RO     | 0                | _                                                                                                                                                                                   |
| Local Received BD jumbo<br>Producer Ring requested Index | 7:0  | RO     | 0                | Current Jumbo Received BD Index requested by RBDI for BD fetching. Notice that, this index is different from MB producer index and also different from the index indicated by RBDC. |

# 13.17.4 Receive BD Initiator Local NIC Receive BD Producer Index Register (offset: 0x2C0C-0x2C13)

This set of registers is used to keep track of the current DMAs queued to move receive BDs from the host to the NIC.

# 13.17.5 Standard Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C18)

| Name      | Bits  | Access | Default<br>Value | Description                                                                                                                                                     |
|-----------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved  | 31:10 | RO     | 0                | -                                                                                                                                                               |
| BD Number | 9:0   | RW     |                  | Number of buffer descriptors indicated by the receive producer index for the DMA engine to initiate a transfer of buffer descriptors for replenishing the ring. |

# 13.17.6 Jumbo Receive BD Producer Ring Replenish Threshold Register (offset: 0x2C1C)

All registers reset are core reset unless specified.

| Name      | Bits  | Access | Default<br>Value | Description                                                                                                                                                     |
|-----------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved  | 31:10 | RO     | 0                | _                                                                                                                                                               |
| BD Number | 9:0   | RW     | 0                | Number of buffer descriptors indicated by the receive producer index for the DMA engine to initiate a transfer of buffer descriptors for replenishing the ring. |

### 13.17.7 Standard Replenish LWM Register (offset 0x2D00)

| Name                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                          |
|--------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Legacy                   | 31:8 | RU     | 0x0              | Unused                                                                                                                                                                               |
| Replenish Low Water Mark | 7:0  | RW     | 0x0              | This field must be programmed with the desired                                                                                                                                       |
|                          |      |        |                  | LWM for Standard RBD cache/memory. The value equally applies to all VRQs. Whenever the number of BDs in a VRQ's BD memory falls below this (LWM+1), a BD fetch is request triggered. |
|                          |      |        |                  | Recommended Settings:                                                                                                                                                                |
|                          |      |        |                  | Non-IOV mode:                                                                                                                                                                        |
|                          |      |        |                  | STD LWM: 32. (1/4 of total RBDs)                                                                                                                                                     |
|                          |      |        |                  | IOV mode:                                                                                                                                                                            |
|                          |      |        |                  | STD LWM: 16. (1/2 of total RBDs)                                                                                                                                                     |

## 13.17.8 Jumbo Replenish LWM Register (offset 0x2D04)

| Name   | Bits | Access | Default<br>Value | Description |
|--------|------|--------|------------------|-------------|
| Legacy | 31:8 | RU     | 0x0              | Unused      |

| Name                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                         |
|--------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Replenish Low Water Mark | 7:0  | RW     | 0x0              | This field must be programmed with the desired LWM for Jumbo RBD cache/memory. The value equally applies to all VRQs. Whenever the number of BDs in a VRQ's BD memory falls below this (LWM+1), a BD fetch is request triggered. Recommended Settings:  Non-IOV mode:  JMB LWM: 16. (1/4 of total RBDs)  IOV mode:  JMB LWM: 4. (1/4 of total RBDs) |

#### 13.17.8.1 BD Fetch Limit Register (Offset 0x2D08)

This register is meaningful only in the IOV-Mode.

| Name           | Bits | Access | Default<br>Value | Description                                                                             |
|----------------|------|--------|------------------|-----------------------------------------------------------------------------------------|
| Legacy         | 31:5 | RU     | 0x0              | Unused                                                                                  |
| BD Fetch Limit | 4:0  | RW     | 0x1F             | The number of BDs fetched by a single DMA request shall be the lesser of the following: |
|                |      |        |                  | Space available in the respective BD cache.                                             |
|                |      |        |                  | Standard or Jumbo Replenish Threshold.                                                  |
|                |      |        |                  | Number of BDs made available in the Host memory based Ring.                             |
|                |      |        |                  | Programmed Value of this Field.                                                         |

## 13.18 Receive BD Completion Control Registers

All registers reset are core reset unless specified.

### 13.18.1 Receive BD Completion Mode Register (offset: 0x3000)

| Name             | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                       |
|------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved         | 31:3 | RO     | 0                | -                                                                                                                                                                                                                 |
| Attention Enable | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                                                                               |
| Enable           | 1    | RW     | 1                | This bit controls whether the Receive BD Completion state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset            | 0    | RW     | 0                | When this bit is set to 1, the Receive BD Completion state machine is reset. This is a self-clearing bit.                                                                                                         |

### 13.18.2 Receive BD Completion Status Register (offset: 0x3004)

| Name     | Bits |    | Default<br>Value | Description                         |
|----------|------|----|------------------|-------------------------------------|
| Reserved | 31:3 | RO | 0                | -                                   |
| Error    | 2    | RO | 0                | Receive BD Completion Error Status. |
| Reserved | 1:0  | RO | 0                | -                                   |

## 13.18.3 NIC Jumbo Receive BD Producer Index Register (offset: 0x3008)

All registers reset are core reset unless specified.

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 31:8 | RO     | 0                | _           |

| Name                                | Bits | Access | Default<br>Value | Description                                                                                           |
|-------------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------|
| NIC Jumbo Receive BD Producer Index | 7:0  | RW     |                  | Current Jumbo Received BD have been fetched by RDMA module and are available for incoming RX packets. |

### 13.18.4 NIC Standard Receive BD Producer Index Register (offset: 0x300C)

| Name                                      | Bits | Access | Default<br>Value | Description |
|-------------------------------------------|------|--------|------------------|-------------|
| Reserved                                  | 31:9 | RO     | 0                | _           |
| NIC Standard Receive BD<br>Producer Index | 8:0  | RW     | _                | _           |

# 13.19 Central Power Management Unit (CPMU) Registers

## 13.19.1 CPMU Control Register (offset: 0x3600)

This register is reset by POR Reset except for Powerdown bit (bit #2)

| Name                                                                              | Bits  | Access | Default<br>Value                                           | Description                                                                                                                        |
|-----------------------------------------------------------------------------------|-------|--------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                                          | 31:29 | DC     | 0x0                                                        | -                                                                                                                                  |
| Software controlled GPHY Force DLL on                                             | 28    | RW     | 0x0                                                        | When this bit is enabled, GPHY DLL will be forced on by CPMU (unless the chip is in Low Power mode). This bit is intended for ASF. |
| Enable GPHY powerdown in D0u (this feature is not used in BCM571X/BCM5720 family) | 27    | RW     | 0x0                                                        | Enable CPMU to powerdown GPHY when the device enters D0u.  1: Enable  0: Disable.                                                  |
| Reserved                                                                          | 26:22 | DC     | 0x0                                                        | _                                                                                                                                  |
| Reserved                                                                          | 21    | DC     | 0x1                                                        | _                                                                                                                                  |
| Reserved                                                                          | 20    | DC     | 0x0                                                        | -                                                                                                                                  |
| SGMII/PCS Powerdown                                                               | 19    | RW     | 0x0                                                        | Setting this bit will powerdown SGMII-PCS module.                                                                                  |
| Legacy Timer Enable                                                               | 18    | RW     | 0x0                                                        | This bit controls "cpmu_legacy_timer_enable" output.  1: Enable  0: Disable                                                        |
| Frequency Multiplier Enable /<br>Disable<br>(Reserved for BCM5719)                | 17    | RW     | 0x1 for<br>BCM5717<br>and<br>BCM5718<br>0x0 for<br>BCM5719 | 1: Enable 0: Disable                                                                                                               |
| GPHY 10 MB Receive Only mode<br>Enable                                            | 16    | RW     | 0x0                                                        | Enables GPHY 10 MB Receive Only mode when this bit is set to 1.                                                                    |
| Reserved                                                                          | 15    | RW     | 0x0                                                        | _                                                                                                                                  |
| Link Speed Power mode Enable                                                      | 14    | RW     | 0x0                                                        | Enable clock adjustment based on the link speed in mission mode.                                                                   |
| Reserved                                                                          | 13    | DC     | 0x0                                                        | -                                                                                                                                  |
| Reserved                                                                          | 12:11 | RW     | 0x0                                                        | _                                                                                                                                  |

| Name                         | Bits | Access | Default<br>Value | Description                                                                           |
|------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------|
| Link Aware Power mode Enable | 10   | RW     | 0x0              | Link Aware Power mode Enable.                                                         |
|                              |      |        |                  | 1: Enable                                                                             |
|                              |      |        |                  | 0: Disable                                                                            |
| Link Idle Power mode Enable  | 9    | RW     | 0x0              | Link Idle Power mode Enable.                                                          |
|                              |      |        |                  | 1: Enable                                                                             |
|                              |      |        |                  | 0: Disable                                                                            |
| Reserved                     | 8:6  | RW     | 0x0              | -                                                                                     |
| APE Deep Sleep mode Enable   | 5    | RW     | 0x0              | Enable APE deep sleep power management mode.                                          |
| APE Sleep mode Enable        | 4    | RW     | 0x0              | Enable APE sleep power management mode.                                               |
| Reserved                     | 3    | RW     | 0x0              | -                                                                                     |
| Power-down                   | 2    | RW     | 0x0              | Legacy Address: 0x6804:[20]                                                           |
|                              |      |        |                  | Force CPMU into Low Power State, LAN function will be powered down (GPHY, PCIE, APE). |
|                              |      |        |                  | This bit is cleared by a rising edge of PERST_L.                                      |
| CPMU Register Software Reset | 1    | RW SC  | 0x0              | Software reset for resetting all the registers to default.                            |
| CPMU Software Reset          | 0    | RW SC  | 0x0              | Software reset for all the CPMU logic expect for registers.                           |

# 13.19.2 Link Speed 10 MB/No Link Power Mode Clock Policy Register (offset: 0x3604)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name             | Bits  | Access | Default<br>Value | Description                                      |
|------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved         | 31:21 | DC     | 0x000            | -                                                |
| MAC Clock Switch | 20:16 | RW     | 10111            | Software Controlled MAC Core Clock Speed Select. |
|                  |       |        |                  | 00000: Core = 62.5 MHz (GPHY DLL/2)              |
|                  |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                  |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                  |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                  |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                  |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                  |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                  |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                  |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                  |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                  |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved         | 15:0  | DC     | 0x0000           | -                                                |

## 13.19.3 Link Speed 100 MB Power Mode Clock Policy Register (offset: 0x3608)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name             | Bits  | Access | Default<br>Value | Description                                      |
|------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved         | 31:21 | DC     | 0x000            | -                                                |
| MAC Clock Switch | 20:16 | RW     | 10001            | Software Controlled MAC Core Clock Speed Select. |
|                  |       |        |                  | 00000: Core = 62.5 MHz (GPHY DLL/2)              |
|                  |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                  |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                  |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                  |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                  |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                  |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                  |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                  |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                  |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                  |       |        |                  | 11001: Core = 781 kHz (CK25/32)                  |
|                  |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved         | 15:0  | DC     | 0x0000           | -                                                |

## 13.19.4 Link Speed 1000 MB Power Mode Clock Policy Register (offset: 0x360C)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed. This register shall be programmed to a different value only for engineering debug.

| Name             | Bits  | Access | Default<br>Value | Description                                      |
|------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved         | 31:21 | DC     | 0x0              | -                                                |
| MAC Clock Switch | 20:16 | RW     | 0x0              | Software Controlled MAC Core Clock Speed Select. |
|                  |       |        |                  | 00000: Core = 62.5 MHz (GPHY DLL/2)              |
|                  |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                  |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                  |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                  |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                  |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                  |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                  |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                  |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                  |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                  |       |        |                  | 11001: Core = 781 kHz (CK25/32)                  |
|                  |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved         | 15:0  | DC     | 0x0000           | _                                                |

## 13.19.5 Link Aware Power Mode Clock Policy Register (offset: 0x3610)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed, and the clock source of the clock policies programmed in this register must be the same as the host access clock policy register.

| Name                  | Bits  | Access | Default<br>Value | Description                                      |
|-----------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved              | 31:21 | DC     | 0x000            | -                                                |
| MAC Clock Switch      | 20:16 | RW     | 10111            | Software Controlled MAC Core Clock Speed Select. |
|                       |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                       |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                       |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                       |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                       |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                       |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                       |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                       |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                       |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                       |       |        |                  | 11001: Core = 781 kHz (CK25/32)                  |
|                       |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved              | 15:13 | RO     | 0x00             | _                                                |
| APE Clock Switch      | 12:8  | RW     | 10001            | Software Controlled APE Clock Speed Select       |
| (Reserved in BCM5719) |       |        |                  | 00001: 60.0 MHz (Alt Source/2)                   |
|                       |       |        |                  | 00011: 30.0 MHz (Alt Source/4)                   |
|                       |       |        |                  | 00101: 15.0 MHz (Alt Source/8)                   |
|                       |       |        |                  | 00111: 7.5 MHz (Alt Source/16)                   |
|                       |       |        |                  | 01001: 3.75 MHz (Alt Source/32)                  |
|                       |       |        |                  | 10001: 25.0 MHz (CK25)                           |
|                       |       |        |                  | 10011: 12.5 MHz (CK25/2)                         |
|                       |       |        |                  | 10101: 6.25 MHz (CK25/4)                         |
|                       |       |        |                  | 10111: 3.125 MHz (CK25/8)                        |
|                       |       |        |                  | 11001: 1.563 MHz (CK25/16)                       |
| Reserved              | 7:0   | DC     | 0x0000           | _                                                |

#### 13.19.6 D0u Clock Policy Register (offset: 0x3614)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name             | Bits  | Access | Default<br>Value | Description                                      |
|------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved         | 31:21 | DC     | 0x000            | -                                                |
| MAC Clock Switch | 20:16 | RW     | 10011            | Software Controlled MAC Core Clock Speed Select. |
|                  |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                  |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                  |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                  |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                  |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                  |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                  |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                  |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                  |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                  |       |        |                  | 11001: Core = 781 kHz (CK25/32)                  |
|                  |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved         | 15:0  | DC     | 0x0000           | _                                                |

### 13.19.7 Link Idle Power Mode Clock Policy Register (offset: 0x3618)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name             | Bits  | Access | Default<br>Value | Description                                      |
|------------------|-------|--------|------------------|--------------------------------------------------|
| Reserved         | 31:21 | DC     | 0x000            | -                                                |
| MAC Clock Switch | 20:16 | RW     | 10011            | Software Controlled MAC Core Clock Speed Select. |
|                  |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)            |
|                  |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)            |
|                  |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)            |
|                  |       |        |                  | 00111: Core = 7.5 MHz (Alt Source/16)            |
|                  |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)           |
|                  |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                  |
|                  |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                  |
|                  |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                 |
|                  |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                |
|                  |       |        |                  | 11001: Core = 781 kHz (CK25/32)                  |
|                  |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)      |
| Reserved         | 15:0  | DC     | 0x0000           | -                                                |

### 13.19.8 APE CLK Policy Register (offset: 0x361C)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name                                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                             |
|----------------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (BCM5718) Reserved                           | 31:13 | DC     | 0x00000          | _                                                                                                                                                                                                                                       |
| (BCM5719) APE Sleep mode<br>Enable           | 31    | RW     | 0x0              | Enable APE sleep power management mode.                                                                                                                                                                                                 |
| (BCM5719) APE Deep Sleep mode Enable         | 30    | RW     | 0x0              | Enable APE deep sleep power management mode.                                                                                                                                                                                            |
| (BCM5719) APE Clock Speed<br>Override Enable | 29    | RW     | 0x0              | Enable APE clock speed override.                                                                                                                                                                                                        |
| (BCM5719) Force APE FCLK                     | 28    | RW     | 0x0              | APE FCLK clock Disable.                                                                                                                                                                                                                 |
| Disable                                      |       |        |                  | 1: Disable APE FCLK clock                                                                                                                                                                                                               |
|                                              |       |        |                  | 0: Enable APE FCLK clock                                                                                                                                                                                                                |
| (BCM5719) Force APE HCLK                     | 27    | RW     | 0x0              | APE HCLK Disable.                                                                                                                                                                                                                       |
| Disable                                      |       |        |                  | 1: Disable APE HCLK clock                                                                                                                                                                                                               |
|                                              |       |        |                  | 0: Enable APE HCLK clock                                                                                                                                                                                                                |
| (BCM5719) APE Memory Bank 2<br>Deselect      | 26    | RW     | 0x0              | When this bit is set, deselect APE Scratchpad Memory Bank 2.                                                                                                                                                                            |
| (BCM5719) APE Memory Bank 1<br>Deselect      | 25    | RW     | 0x0              | When this bit is set, deselect APE Scratchpad Memory Bank 1.                                                                                                                                                                            |
| (BCM5719) APE Memory Bank 0<br>Deselect      | 24    | RW     | 0x0              | When this bit is set, deselect APE Scratchpad Memory Bank 0.                                                                                                                                                                            |
| (BCM5719) Reserved                           | 23:21 | DC     | 0x0              | _                                                                                                                                                                                                                                       |
| (BCM5719) Clock Override APE<br>Clock Switch | 20:16 | RW     |                  | Software Controlled APE Clock Speed Select for Clock Override. 00000: 62.5 MHz (NCSI DLL/2)10001: 25.0 MHz (CK25) 10011: 12.5 MHz (CK25/2) 10101: 6.25 MHz (CK25/4) 10111: 3.125 MHz (CK25/8) 11001: 1.563 MHz (CK25/16) 11110: 125 MHz |

| Name                  | Bits | Access | Default<br>Value | Description                                                                    |
|-----------------------|------|--------|------------------|--------------------------------------------------------------------------------|
| APE Clock Switch      | 12:8 | RW     | 00000            | Software Controlled APE Clock Speed Select.                                    |
|                       |      |        |                  | BCM5718:                                                                       |
|                       |      |        |                  | 00000: 62.5 MHz (CLK125/2)                                                     |
|                       |      |        |                  | 00001: 60.0 MHz (Alt Source/2)                                                 |
|                       |      |        |                  | 00011: 30.0 MHz (Alt Source/4)                                                 |
|                       |      |        |                  | 00101: 15.0 MHz (Alt Source/8)                                                 |
|                       |      |        |                  | 00111: 7.5 MHz (Alt Source/16)                                                 |
|                       |      |        |                  | 01001: 3.75 MHz (Alt Source/32)                                                |
|                       |      |        |                  | 10001: 25.0 MHz (CK25)                                                         |
|                       |      |        |                  | 10011: 12.5 MHz (CK25/2)                                                       |
|                       |      |        |                  | 10101: 6.25 MHz (CK25/4)                                                       |
|                       |      |        |                  | 10111: 3.125 MHz (CK25/8)                                                      |
|                       |      |        |                  | 11001: 1.563 MHz (CK25/16)                                                     |
|                       |      |        |                  | 11110: 83 MHz                                                                  |
|                       |      |        |                  | BCM5719:                                                                       |
|                       |      |        |                  | 00000: 62.5 MHz (NCSI DLL/2)                                                   |
|                       |      |        |                  | 10001: 25.0 MHz (CK25)                                                         |
|                       |      |        |                  | 10011: 12.5 MHz (CK25/2)                                                       |
|                       |      |        |                  | 10101: 6.25 MHz (CK25/4)                                                       |
|                       |      |        |                  | 10111: 3.125 MHz (CK25/8)                                                      |
|                       |      |        |                  | 11001: 1.563 MHz (CK25/16)                                                     |
|                       |      |        |                  | 11110: 125 MHz                                                                 |
| Reserved              | 7:5  | DC     | 0                | _                                                                              |
| LAPM APE Clock Switch | 4:0  | RW     | 10001            | Software Controlled APE Clock Speed Select in Link Aware Power mode in BCM5719 |
|                       |      |        |                  | 10001: 25.0 MHz (CK25)                                                         |
|                       |      |        |                  | (BCM5717) Reserved                                                             |
|                       |      |        |                  | 10011: 12.5 MHz (CK25/2)                                                       |
|                       |      |        |                  | (BCM5718) 10101: 6.25MHz (CK25/4)                                              |
|                       |      |        |                  | 10111: 3.125 MHz (CK25/8)                                                      |
|                       |      |        |                  | 11001: 1.563 MHz (CK25/16)                                                     |

## 13.19.9 APE Sleep State Clock Policy Register (offset: 0x3620)

This register is reset by POR Reset or CPMU Register Software Reset. Please note that clocks generated by digital frequency multiplier could be up to 3% slower than intended clock speed.

| Name                       | Bits  | Access | Default<br>Value | Description                                                         |
|----------------------------|-------|--------|------------------|---------------------------------------------------------------------|
| APE Sleep HCLK Disable     | 31    | RW     | 0x1              | Software Controlled APE HCLK shutoff in sleep and deep sleep state. |
| Reserved                   | 30:21 | DC     | 0x000            | _                                                                   |
| APE Deep Sleep FCLK Switch | 20:16 | RW     | 10001            | Software Controlled APE Clock Speed Select.                         |
|                            |       |        |                  | 00001: 60.0 MHz (Alt Source/2)                                      |
|                            |       |        |                  | 00011: 30.0 MHz (Alt Source/4)                                      |
|                            |       |        |                  | 00101: 15.0 MHz (Alt Source/8)                                      |
|                            |       |        |                  | 00111: 7.5 MHz (Alt Source/16)                                      |
|                            |       |        |                  | 01001: 3.75 MHz (Alt Source/32)                                     |
|                            |       |        |                  | 10001: 25.0 MHz (CK25)                                              |
|                            |       |        |                  | 10011: 12.5 MHz (CK25/2)                                            |
|                            |       |        |                  | 10101: 6.25 MHz (CK25/4)                                            |
|                            |       |        |                  | 10111: 3.125 MHz (CK25/8)                                           |
|                            |       |        |                  | 11001: 1.563 MHz (CK25/16)                                          |
| Reserved                   | 15:5  | DC     | 0x000            | _                                                                   |
| APE Sleep FCLK Switch      | 4:0   | RW     | 10001            | Software Controlled APE Clock Speed Select.                         |
|                            |       |        |                  | 00001: 60.0 MHz (Alt Source/2)                                      |
|                            |       |        |                  | 00011: 30.0 MHz (Alt Source/4)                                      |
|                            |       |        |                  | 00101: 15.0 MHz (Alt Source/8)                                      |
|                            |       |        |                  | 00111: 7.5 MHz (Alt Source/16)                                      |
|                            |       |        |                  | 01001: 3.75 MHz (Alt Source/32)                                     |
|                            |       |        |                  | 10001: 25.0 MHz (CK25)                                              |
|                            |       |        |                  | 10011: 12.5 MHz (CK25/2)                                            |
|                            |       |        |                  | 10101: 6.25 MHz (CK25/4)                                            |
|                            |       |        |                  | 10111: 3.125 MHz (CK25/8)                                           |
|                            |       |        |                  | 11001: 1.563 MHz (CK25/16)                                          |

## 13.19.10 Clock Speed Override Policy Register (offset: 0x3624)

| Name                     | Bits  | Access | Default<br>Value | Description                                                                                        |
|--------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------|
| MAC Clock Speed Override | 31    | RW     | 0x0              | Enable MAC clock speed override*.                                                                  |
| Enable                   |       |        |                  | For 5719 and 5720 only                                                                             |
| Reserved                 | 30:21 | DC     | 0x000            | -                                                                                                  |
| MAC Clock Switch         | 20:16 | RW     | 00000            | Software Controlled MAC Core Clock Speed Select                                                    |
|                          |       |        |                  | 00000: Core = 62.5 MHz (NCSI DLL/2)                                                                |
|                          |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)                                                                    |
|                          |       |        |                  | 10011: Core = 6.25 MHz (CK25/4)                                                                    |
|                          |       |        |                  | 10101: Core = 3.125 MHz (CK25/8)                                                                   |
|                          |       |        |                  | 10111: Core = 1.563 MHz (CK25/16)                                                                  |
|                          |       |        |                  | For 5718                                                                                           |
|                          |       |        |                  | Software Controlled MAC Core Clock Speed Select00000: Core = 62.5MHz (GPHY DLL/2)                  |
|                          |       |        |                  | 00001: Core = 60.0 MHz (Alt Source/2)                                                              |
|                          |       |        |                  | 00011: Core = 30.0 MHz (Alt Source/4)                                                              |
|                          |       |        |                  | 00101: Core = 15.0 MHz (Alt Source/8)                                                              |
|                          |       |        |                  | 00111: Core = 7.5M Hz (Alt Source/16)                                                              |
|                          |       |        |                  | 01001: Core = 3.75 MHz (Alt Source/32)                                                             |
|                          |       |        |                  | 10001: Core = 12.5 MHz (CK25/2)10011: Core = 6.25MHz (CK25/                                        |
|                          |       |        |                  | 4)10101: Core = 3.125 MHz (CK25/8)10111: Core = 1.563 MHz (CK25/16)11001: Core = 781 KHz (CK25/32) |
|                          |       |        |                  | 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)                                                        |
| Reserved                 | 15:0  | DC     | 0x0              | -                                                                                                  |

# 13.19.11 Clock Override Enable Register (offset: 0x3628)

This register is reset by POR Reset or CPMU Register Software Reset. \*The Force Disable bit has higher priority than Override Enable.

| Name                       | Bits  | Access | Default<br>Value | Description                       |
|----------------------------|-------|--------|------------------|-----------------------------------|
| Reserved                   | 31:14 | DC     | 0x0              | -                                 |
| MAC Clock Speed Override   | 13    | RW     | 0x0              | Enable MAC clock speed override*. |
| Enable                     |       |        |                  | 1: Enable                         |
|                            |       |        |                  | 0: Disable                        |
| APE Clock Speed Override   | 12    | RW     | 0x0              | Enable APE clock speed override*. |
| Enable                     |       |        |                  | 1: Enable                         |
|                            |       |        |                  | 0: Disable                        |
| Flash Clock Speed Override | 11    | RW     | 0x0              | Enable Flash clock override*.     |
| Enable                     |       |        |                  | 1: Enable                         |
|                            |       |        |                  | 0: Disable                        |
| Reserved                   | 10:7  | DC     | 0x0              | -                                 |
| Force Flash Clock Disable  | 6     | RW     | 0x0              | Flash clock Disable*.             |
|                            |       |        |                  | 1: Disable Flash clock            |
|                            |       |        |                  | 0: Enable Flash clock             |

| Name                   | Bits | Access | Default<br>Value | Description               |
|------------------------|------|--------|------------------|---------------------------|
| Reserved               | 5:2  | DC     | 0x0              | -                         |
| Force APE FCLK Disable | 1    | RW     | 0x0              | APE FCLK clock Disable*.  |
|                        |      |        |                  | 1: Disable APE FCLK clock |
|                        |      |        |                  | 0: Enable APE FCLK clock  |
| Force APE HCLK Disable | 0    | RW     | 0x0              | APE HCLK Disable*.        |
|                        |      |        |                  | 1: Disable APE HCLK clock |
|                        |      |        |                  | 0: Enable APE HCLK clock  |

# 13.19.12 Status Register (offset: 0x362C)

This register is reset by POR Reset or CPMU Register Software Reset.

| Bits  | Access                                             | Default<br>Value                                | Description                                                                                                                                                                                                                                                                                                                     |
|-------|----------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO                                                 | _                                               | For 5719 four port devices, the bit31 will be used by FUNC_NUMBER. For 5718/5720 two port devices will not.                                                                                                                                                                                                                     |
| 31:30 | RO                                                 | 0x0                                             | PCIE function number 1: function number                                                                                                                                                                                                                                                                                         |
|       |                                                    |                                                 | 3: function 3                                                                                                                                                                                                                                                                                                                   |
|       |                                                    |                                                 | 2: function 2                                                                                                                                                                                                                                                                                                                   |
|       |                                                    |                                                 | 1: function 1                                                                                                                                                                                                                                                                                                                   |
|       |                                                    |                                                 | 0: function 0                                                                                                                                                                                                                                                                                                                   |
|       |                                                    |                                                 | CPMU port0 is tied to function 0, CPMU port1 is tied to function1.                                                                                                                                                                                                                                                              |
|       |                                                    |                                                 | CPMU port2 is tied to function2.                                                                                                                                                                                                                                                                                                |
|       |                                                    |                                                 | CPMU port3 is tied to functiion3.                                                                                                                                                                                                                                                                                               |
| 29:25 | RO                                                 | _                                               | Function Enable input from System BIOS.                                                                                                                                                                                                                                                                                         |
| 24:23 | RO                                                 | _                                               | APE Engine Status                                                                                                                                                                                                                                                                                                               |
|       |                                                    |                                                 | 11: Reserved                                                                                                                                                                                                                                                                                                                    |
|       |                                                    |                                                 | 10: Deep Sleep State                                                                                                                                                                                                                                                                                                            |
|       |                                                    |                                                 | 01: Sleep State                                                                                                                                                                                                                                                                                                                 |
|       |                                                    |                                                 | 00: Active State                                                                                                                                                                                                                                                                                                                |
| 22    | RO                                                 | _                                               | 1: ACPI detection enabled                                                                                                                                                                                                                                                                                                       |
|       |                                                    |                                                 | 0: ACPI detection disabled                                                                                                                                                                                                                                                                                                      |
| 21    | RO                                                 | _                                               | 1: Magic Packet Detection enabled                                                                                                                                                                                                                                                                                               |
|       |                                                    |                                                 | 0: Magic Packet Detection disabled                                                                                                                                                                                                                                                                                              |
| 20:19 | RO                                                 | _                                               | EthernetLink Status                                                                                                                                                                                                                                                                                                             |
|       |                                                    |                                                 | 11: no link                                                                                                                                                                                                                                                                                                                     |
|       |                                                    |                                                 | 10: 10 Mb                                                                                                                                                                                                                                                                                                                       |
|       |                                                    |                                                 | 01: 100 Mb                                                                                                                                                                                                                                                                                                                      |
|       |                                                    |                                                 | 00: 1000 Mb                                                                                                                                                                                                                                                                                                                     |
| 18    | RO                                                 | _                                               | Link Idle status                                                                                                                                                                                                                                                                                                                |
|       |                                                    |                                                 | 1: Idle                                                                                                                                                                                                                                                                                                                         |
|       |                                                    |                                                 | 0: Active                                                                                                                                                                                                                                                                                                                       |
| 17    | RO                                                 | _                                               | 1: Locked                                                                                                                                                                                                                                                                                                                       |
|       |                                                    |                                                 | 0: Not locked                                                                                                                                                                                                                                                                                                                   |
|       | 31<br>31:30<br>29:25<br>24:23<br>22<br>21<br>20:19 | 31 RO 31:30 RO 29:25 RO 24:23 RO 21 RO 20:19 RO | Bits         Access         Value           31         RO         -           31:30         RO         0x0           29:25         RO         -           24:23         RO         -           22         RO         -           21         RO         -           20:19         RO         -           18         RO         - |

| Name                                    | Bits  | Access | Default<br>Value | Description                                                             |
|-----------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------|
| NCSI DLL lock status                    | 16    | RO     | _                | 1: Locked                                                               |
|                                         |       |        |                  | 0: Not locked                                                           |
| WOL ACPI Detection Enable               | 15    | RO     | _                | 1: ACPI detection enabled.                                              |
| Status of Port 0                        |       |        |                  | 0: ACPI detection disabled.                                             |
| WOL Magic Packet Detection              | 14    | RO     | _                | 1: Magic Packet Detection Enabled.                                      |
| Enable Status of Port 0                 |       |        |                  | 0: Magic Packet Detection Disabled.                                     |
| VMAIN power status                      | 13    | RO     | _                | VMAIN Power Status                                                      |
|                                         |       |        |                  | 1: On                                                                   |
|                                         |       |        |                  | 0: Off                                                                  |
| Reserved                                | 12:10 | DC     | 0x0              | _                                                                       |
| Power State                             | 9:8   | RO     | _                | Device Power State Status.                                              |
|                                         |       |        |                  | 11: D3                                                                  |
|                                         |       |        |                  | 00: D0                                                                  |
| Energy Detect Status                    | 7     | RO     | _                | Energy Status                                                           |
|                                         |       |        |                  | 1: On                                                                   |
|                                         |       |        |                  | 0: Off                                                                  |
| CPMU Power State                        | 6:4   | RO     | _                | Indicates the current power state of the CPMU.                          |
| Power Management State<br>Machine State | 3:0   | RO     | _                | Indicates the current state of hardware power management state machine. |

### 13.19.13 Clock Status Register (offset: 0x3630)

**NOTE:** This is for BCM5718. See "Clock Status Register (offset: 0x3630)" for BCM5719.

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                       | Bits  | Access | Default<br>Value | Description                        |
|----------------------------|-------|--------|------------------|------------------------------------|
| Reserved                   | 31:30 | DC     | 0x0              | -                                  |
| Flash CLOCK Disable Status | 29    | RO     | _                | Flash clock disable status         |
| Reserved                   | 28    | DC     | _                | Reserved                           |
| Reserved                   | 27:26 | RO     | _                | -                                  |
| APE HCLK Disable Status    | 25    | RO     | _                | APE HCLK clock disable status      |
| APE FCLK Disable Status    | 24    | RO     | _                | APE FCLK clock disable status      |
| PERST_N status             | 23    | RO     | _                | PERST_N status                     |
| Reserved                   | 22:21 | DC     | 0x0              | -                                  |
| MAC Clock Switch Status    | 20:16 | RO     | _                | MAC Core Clock Speed Select Status |
| Reserved                   | 15:13 | DC     | 0x0              | -                                  |
| APE Clock Switch Status    | 12:8  | RO     | _                | APE Clock Speed Select Status      |
| Reserved                   | 7     | DC     | 0x0              | -                                  |
| Flash Clock Switch Status  | 6:4   | RO     | _                | Flash Clock Speed Select Status    |
| Reserved                   | 3:0   | DC     | 0x0              | -                                  |

### 13.19.14 Clock Status Register (offset: 0x3630)

NOTE: This is for BCM5719. See "Clock Status Register (offset: 0x3630)" for BCM5718.

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                       | Bits  | Access | Default<br>Value | Description                        |
|----------------------------|-------|--------|------------------|------------------------------------|
| Reserved                   | 31:30 | DC     | 0x0              | -                                  |
| Flash CLOCK Disable Status | 29    | RO     | _                | Flash clock disable status         |
| Reserved                   | 28:27 | DC     | _                | -                                  |
| Reserved                   | 26    | RO     | _                | -                                  |
| APE FCLK Disable Status    | 25    | RO     | _                | APE FCLK clock disable status      |
| APE HCLK Disable Status    | 24    | RO     | _                | APE HCLK clock disable status      |
| Reserved                   | 23:21 | DC     | 0x0              | -                                  |
| MAC Clock Switch Status    | 20:16 | RO     | _                | MAC Core Clock Speed Select Status |
| Reserved                   | 15:13 | DC     | 0x0              | -                                  |
| APE Clock Switch Status    | 12:8  | RO     | _                | APE Clock Speed Select Status      |
| Flash Clock Switch Status  | 7:5   | RO     | _                | Flash Clock Speed Select Status    |
| Reserved                   | 4:0   | DC     | 0x0              | -                                  |

# 13.19.15 GPHY Control/Status Register (offset: 0x3638)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                                            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                            |
|-------------------------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                        | 31:14 | DC     | 0x0              | -                                                                                                                                                                                      |
| (BCM5719) Reserved                              | 31:29 | DC     | 0x0              | -                                                                                                                                                                                      |
| (BCM5719) Keep NCSI PLL on                      | 28    | RW     | 0x0              | Keep NCSI PLL on during low power mode.                                                                                                                                                |
| During Low Power mode                           |       |        |                  | 0: NCSI PLL is powered off in low power mode                                                                                                                                           |
|                                                 |       |        |                  | 1: NCSI PLL is kept running in low power mode                                                                                                                                          |
| (BCM5719) Switching Regulator                   | 27    | RW     | 0x0              | Switching regulator power down control bit                                                                                                                                             |
| Power Down                                      |       |        |                  | 0: Switching regulator on                                                                                                                                                              |
|                                                 |       |        |                  | 1: Switching regulator off                                                                                                                                                             |
| (BCM5719) TLP Clock Source                      | 26    | RW     | 0x0              | TLP clock source mux control.                                                                                                                                                          |
|                                                 |       |        |                  | 0: From PCIE SERDES                                                                                                                                                                    |
|                                                 |       |        |                  | 1: 125 MHz from NCSI PLL                                                                                                                                                               |
| (BCM5719) NCSI PLL Lock Status                  | 25    | RO     | 0x0              | NCSI PLL Lock Status                                                                                                                                                                   |
| (BCM5719) OTP SERDES PLL<br>Lock Status         | 24    | RO     | 0x0              | OTP SERDES PLL Lock Status                                                                                                                                                             |
| (BCM5719) GPHY PLL Lock<br>Status               | 23    | RO     | 0x0              | GPHY PLL Lock Status                                                                                                                                                                   |
| (BCM5719) PCIE SERDES PLL<br>Lock Status        | 22    | RO     | 0x0              | PCIE SERDES PLL Lock Status                                                                                                                                                            |
| (BCM5719) NCSI PLL Test Select                  | 21:18 | RW     | 0x0              | NCSI PLL Test Select                                                                                                                                                                   |
| (BCM5719) NCSI PLL Test<br>Enable               | 17    | RW     | 0x0              | NCSI PLL Test Enable                                                                                                                                                                   |
| (BCM5719) NCSI PLL Power<br>Down                | 16    | RW     | 0x0              | NCSI PLL Power Down                                                                                                                                                                    |
| (BCM5719) SGMII/PCS<br>Powerdown                | 15    | RW     | 0x0              | Setting this bit will powerdown SGMII-PCS module.                                                                                                                                      |
| (BCM5719) SGMII/PCS Reset                       | 14    | RW     | 0x0              | Setting this bit will reset SGMII-PCS module.                                                                                                                                          |
| GPHY 10 MB Receive Only mode                    | 13:12 | RW     | 0x1              | 10 MB Receive Only mode TX Idle Debounce Timer.                                                                                                                                        |
| TX Idle Debounce Timer                          |       |        |                  | 0x1 = 6 μs                                                                                                                                                                             |
| (BCM5718) Reserved                              | 11    | DC     | 0x0              | -                                                                                                                                                                                      |
| (BCM5719) Software controlled GPHY Force DLL on | 11    | RW     | 0x0              | When this bit is enabled, GPHY DLL will be forced on by CPMU (unless the chip is in Low Power mode). This bit is intended for ASF.                                                     |
| GPHY DLL IDDQ state                             | 10    | RO     | 0x0              | Gphy_iddq_dll_act state                                                                                                                                                                |
| GPHY pwrdn                                      | 9     | RO     |                  | CPMU controlled output to GPHY                                                                                                                                                         |
| GPHY set_bias_iddq                              | 8     | RO     |                  | CPMU controlled output to GPHY                                                                                                                                                         |
| GPHY force_dll_on                               | 7     | RO     |                  | CPMU controlled output to GPHY                                                                                                                                                         |
| GPHY dll_pwrdn_ok                               | 6     | RO     |                  | CPMU controlled output to GPHY                                                                                                                                                         |
| SW controlled POR to GPHY                       | 5     | RW     | 0x0              | This bit is allows the boot code to reset the GPHY during an unexpected shutdown, so that it enters 100BT instead of remaining in the Gig mode to avoid unnecessary power consumption. |
| (BCM5717 and BCM5718)<br>Reserved               | 4     | DC     | 0x0              | _                                                                                                                                                                                      |

| Name                              | Bits | Access | Default<br>Value | Description                                                                                                                                                               |
|-----------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (BCM5719) Power-down              | 4    | RW     | 0x0              | Legacy Address: 0x6804:[20] Force CPMU into Low Power State, LAN function will be powered down (GPHY, PCIE, IPSEC, APE). This bit is cleared by a rising edge of PERST_L. |
| (BCM5717 and BCM5718)<br>Reserved | 3    | DC     | 0x0              | -                                                                                                                                                                         |
| CPMU Register Software Reset      | 3    | RW SC  | 0x0              | Software reset for resetting all the registers to default.                                                                                                                |
| Reserved                          | 2    | DC     | 0x0              | -                                                                                                                                                                         |
| CPMU Software Reset               | 2    | RW     | 0x0              | Software reset for all the CPMU logic expect for registers.                                                                                                               |
| BIAS IDDQ                         | 1    | RW     | 0x0              | Legacy Address: 0x6804:[22] When this bit is set, BIAS will be powered down.                                                                                              |
| GPHY IDDQ                         | 0    | RW     | 0x0              | Legacy Address: 0x6804:[21]. When this bit is set, GPHY will be powered down.                                                                                             |

## 13.19.16 RAM Control Register (offset: 0x363C)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                | Bits | Access | Default<br>Value | Description                 |
|---------------------|------|--------|------------------|-----------------------------|
| Core RAM Power down | 31   | RW     | 0x0              | Legacy Address: 0x6804:[24] |
|                     |      |        |                  | Core RAM power down         |
| BD RAM Power down   | 30   | RW     | 0x0              | Legacy Address: 0x6804:[24] |
|                     |      |        |                  | BD RAM power down           |
| Reserved            | 29:0 | DC     | 0                | -                           |

# 13.19.17 Core Idle Detection De-Bounce Control Register (offset: 0x3648)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                          | Bits | Access | Default<br>Value | Description                                                                     |
|-------------------------------|------|--------|------------------|---------------------------------------------------------------------------------|
| Link Idle Detection De-bounce | 31:0 | RW     | 0x20             | De-bounce timer setting for core link from active to non-active.                |
| Timer                         |      |        |                  | Unit is in number of CPMU clock cycles                                          |
|                               |      |        |                  | Range: up to 232 CPMU clock cycles                                              |
|                               |      |        |                  | Default Value (10 CPMU CLK) multiplied by given Core CLK scale parameter below. |
|                               |      |        |                  | x1 00000: Core = 62.5 MHz (GPHY DLL/2)                                          |
|                               |      |        |                  | x1 00001: Core = 60.0 MHz (Alt Source/2)                                        |
|                               |      |        |                  | x2 00011: Core = 30.0 MHz (Alt Source/4)                                        |
|                               |      |        |                  | x4 00101: Core = 15.0 MHz (Alt Source/8)                                        |
|                               |      |        |                  | x8 00111: Core = 7.5 MHz (Alt Source/16)                                        |
|                               |      |        |                  | x16 01001: Core = 3.75 MHz (Alt Source/32)                                      |
|                               |      |        |                  | x8 10001: Core = 12.5 MHz (CK25/2)                                              |
|                               |      |        |                  | x16 10011: Core = 6.25 MHz (CK25/4)                                             |
|                               |      |        |                  | x32 10101: Core = 3.125 MHz (CK25/8)                                            |
|                               |      |        |                  | x64 10111: Core = 1.563 MHz (CK25/16)                                           |
|                               |      |        |                  | x128 11001: Core = 781 kHz (CK25/32),                                           |
|                               |      |        |                  | x64 11111: Core = 12.5 MHz/1.25 MHz (MII_CLK/2)                                 |

### 13.19.18 PCIE Idle Detection De-Bounce Control Register (offset: 0x364C)

This register is reset by POR Reset or CPMU Register Software Reset. This register is shared by all MAC ports. User must first gain grant from the global MUTEX registers (0x36F0 & 0x36F4) before writing to it.

| Name                                   | Bits | Access | Default<br>Value | Description                                                                                                                                                           |
|----------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCIE Idle Detection De-bounce<br>Timer | 31:0 | RW     | BCM5718          | De-bounce timer setting for PCIE link from active to non-active. Unit is in number of CPMU clock cycles. Range: up to 232 CPMU clock cycles. Default: 10 CPMU clocks. |

### 13.19.19 Energy Detection De-Bounce Timer (offset: 0x3650)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                                | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                              |
|-------------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                            | 31:10 | RO     | 0                | -                                                                                                                                                                                                                                        |
| Energy Detect Select                | 9     | RW     | 0x0              | Legacy Address: 0x6890:[26]                                                                                                                                                                                                              |
|                                     |       |        |                  | 1: use energy_det_apd from GPHY core                                                                                                                                                                                                     |
|                                     |       |        |                  | 0: use output from the energy debounce logic                                                                                                                                                                                             |
| Select HW_Energy_Det                | 8     | RW     | 0x1              | This bit selects the source of the System Energy_Det output                                                                                                                                                                              |
|                                     |       |        |                  | This bit is allows the boot code to reset the GPHY during an unexpected shutdown, so that it enters 100BT instead of remaining in the Gig mode to avoid unnecessary power consumption.                                                   |
|                                     |       |        |                  | 1: Select Output of De-bounce Logic                                                                                                                                                                                                      |
|                                     |       |        |                  | 0: Select Combination of Software Force_Energy_Det and Output of De-bounce Logic to generate System Energy_Det                                                                                                                           |
| Select<br>SW_HW_Oring_Energy_Det    | 7     | RW     | 0x0              | This bit is allows the boot code to reset the GPHY during an unexpected shutdown, so that it enters 100BT instead of remaining in the Gig mode to avoid unnecessary power consumption.                                                   |
|                                     |       |        |                  | 1: Generate System Energy_Det by Oaring the SW_Force_Energy_Det with the Output of the De-bounce Logic                                                                                                                                   |
|                                     |       |        |                  | 0: Generate System Energy_Det based on the SW_Force_Energy_Det Output                                                                                                                                                                    |
| SW_Force_Energy_Det_Value           | 6     | RW     | 0x1              | This bit allows the software to control the state of the System Energy_Det signal if the Select_HW_Energy_Det control bit (b12) is 0                                                                                                     |
|                                     |       |        |                  | 1: Drive System Energy_Det high                                                                                                                                                                                                          |
|                                     |       |        |                  | 0: Drive System Energy_Det low                                                                                                                                                                                                           |
| Disable Energy_Det De-bounce<br>Low | 5     | RW     | 0x1              | This bit is used to disable the Energy_Det_Debounce_Low Logic from debouncing the GPHY Energy_Det_APD signal going low. When disabled, the Energy_Det signal will go low if the GPHY Energy_Det input signal is low for at least 640 ns. |
|                                     |       |        |                  | 0: Enable De-bounce Low                                                                                                                                                                                                                  |
|                                     |       |        |                  | 1: Disable De-bounce Low                                                                                                                                                                                                                 |

| Name                                 | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Disable Energy_Det De-bounce<br>High | 4    | RW     | 0x1              | This bit is used to disable the Energy_Det_Debounce_High Logic from debouncing the GPHY Energy_Det_APD signal going high. When disabled, the Energy_Det signal will go high if the GPHY Energy_Det input signal is high for at least 640 ns.  0: Enable De-bounce High  1: Disable De-bounce High                                                                                                                  |
| Energy_Det De-bounce High Limit      | 3:2  | RW     | 0x0              | This parameter is used to control the debounce limit of the GPHY Energy_Det_APD signal going high.  00: 128 million CPMU clocks (5 seconds if CPMU clock frequency is 25 MHz)  01: 256 million CPMU clocks (10 seconds if CPMU clock frequency is 25 MHz)  10: 512 million CPMU clocks (20 seconds if CPMU clock frequency is 25 MHz)  11: 1024 million CPMU clocks (40 seconds if CPMU clock frequency is 25 MHz) |
| Energy_Det De-bounce Low Limit       | 1:0  | RW     | 0x1              | This parameter is used to control the debounce limit of the GPHY Energy_Det_APD signal going low.  00: 128 million CPMU clocks (5 seconds if CPMU clock frequency is 25 MHz)  01: 256 million CPMU clocks (10 seconds if CPMU clock frequency is 25 MHz)  10: 512 million CPMU clocks (20 seconds if CPMU clock frequency is 25 MHz)  11: 1024 million CPMU clocks (40 seconds if CPMU clock frequency is 25 MHz)  |

## 13.19.20 DLL Lock Timer Register (offset: 0x3654)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                                    | Bits  | Access | Default<br>Value | Description                                                                                  |
|-----------------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------|
| (BCM5718) Alternate Clock Lock<br>Timer | 31:16 | RW     | 0x61FF           | This parameter is used to preset the Alternate DLL Lock Timer. This timer is always enabled. |
|                                         |       |        |                  | Unit is in number of CPMU clock cycles                                                       |
|                                         |       |        |                  | Range: up to 2 <sup>16</sup> CPMU clock cycles                                               |
|                                         |       |        |                  | Default: 25088 CPMU clocks (1ms if CPMU clock frequency is 25 MHz)                           |
| (BCM5719) NCSI PLL Lock Timer           | 31:16 | RW     | 0xF              | This parameter is used to preset the NCSI PLL Lock Timer. This timer is always enabled.      |
|                                         |       |        |                  | Unit is in number of CPMU clock cycles                                                       |
|                                         |       |        |                  | Range: up to 2 <sup>16</sup> CPMU clock cycles                                               |
|                                         |       |        |                  | Default: 15 CPMU clocks                                                                      |
| Reserved                                | 15:11 | DC     | 0                | -                                                                                            |
| GPHY DLL Lock Timer                     | 10:0  | RW     | 0x3FF            | GPHY DLL Lock timer value.                                                                   |
|                                         |       |        |                  | Unit is in number of CPMU clock cycles                                                       |
|                                         |       |        |                  | Range: up to 81920 CPMU clock cycles                                                         |
|                                         |       |        |                  | Default: 1024 CPMU clocks (40.9 micro-seconds if CPMU clock frequency is 25 MHz).            |

## 13.19.21 CHIP ID Register (offset: 0x3658)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                             | Bits  | Access | Default<br>Value | Description                  |
|----------------------------------|-------|--------|------------------|------------------------------|
| Reserved                         | 31:28 | DC     | 0x0              | -                            |
| Chip ID                          | 27:12 | RO     | 0x5717           | -                            |
|                                  |       |        | 0x5718           |                              |
|                                  |       |        | 0x5719           |                              |
| Base Layer Revision Information  | 11:8  | RO     | 0000             | Base layer revision history  |
|                                  |       |        |                  | 0000: A0                     |
|                                  |       |        |                  | 0001: B0                     |
|                                  |       |        |                  | 0010: C0                     |
| Metal Layer Revision Information | 7:0   | RO     | 0x0              | Metal layer revision history |

### 13.19.22 Mutex Request Register (offset: 0x365C)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                           |
|-----------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                    | 31:16 | DC     | 0                | -                                                                                                                                                                                                                                     |
| Set Request/Request Pending | 15:0  | RW1S   | 0x0              | Writing a 1 to any of these bits pends a Mutex lock request on behalf of a software agent. The bit is subsequently latched by hardware and shall read 1 as long as the request is pending. Writing a 0 to a bit shall have no effect. |
|                             |       |        |                  | Reading this field may return zero or more bits with value 1. Each bit with value 1 indicates a pending request.                                                                                                                      |

### 13.19.23 Mutex Grant Register (offset: 0x3660)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                           |
|-----------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                    | 31:16 | DC     | 0                | -                                                                                                                                                                                     |
| Set Request/Request Pending | 15:0  | RW1S   | 0x0              | Reading this field shall return a maximum of one set bit at any time. The set bit shall point to the lock owner. If the Mutex is not locked, then a read shall return a value 0x0000. |
|                             |       |        |                  | Writing a 1 to the already set bit shall relinquish the lock and the set bit shall be cleared.                                                                                        |
|                             |       |        |                  | Writing a 1 to an unset bit shall cancel the corresponding pending request if there was one, and the pairing bit in the Mutex_Request_Reg shall be cleared.                           |
|                             |       |        |                  | Writing a 0 to any bits has no effect.                                                                                                                                                |

### 13.19.24 GPHY Strap Register (offset: 0x3664)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                      | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                       |
|---------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                  | 31:6 | DC     | 0x0              | Readable and writeable reserved bits.                                                                                                                                                                                                             |
| APE CM3 Big Endian Enable | 8    | RW     | 0x0              | Enable APE CM3 Big Endian Setting.                                                                                                                                                                                                                |
| Reserved                  | 7:6  | DC     | 0x0              | Readable and writeable reserved bits.                                                                                                                                                                                                             |
| Current port strap value  | 5    | RW     | 0x0              | This bit is used by the APE to deposit the current port's strap value decoded from the CPMU debug register. Please note, the bit is only applicable to BCM571X/BCM5720 family A0 when APE path code is enabled.  0x0: GPHY mode  0x1: SERDES mode |
| RXCPU SPAD ECC ENABLE     | 4    | RW     | 0x0              | Enable ECC for rxcpu scratchpad.                                                                                                                                                                                                                  |
| RXMBUF ECC ENABLE         | 3    | RW     | 0x0              | Enable RXMBUF ECC.                                                                                                                                                                                                                                |
| TXMBUF ECC ENABLE         | 2    | RW     | 0x0              | Enable TXMBUF ECC.                                                                                                                                                                                                                                |

| Name                             | Bits | Access | Default<br>Value | Description                                                       |
|----------------------------------|------|--------|------------------|-------------------------------------------------------------------|
| Debug UART Port Switch           | 1    | RW     | 0x0              | Invert the current value of this bit to switch to the other port. |
| Mission board SerDes mode enable | 0    | RW     | 0x0              | Enable SerDes test mode on mission board.                         |

# 13.19.25 Padring Control Register (offset: 0x3668)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                                                       | Bits  | Access | Default<br>Value      | Description                                                                                  |
|------------------------------------------------------------|-------|--------|-----------------------|----------------------------------------------------------------------------------------------|
| Reserved                                                   | 31:27 | DC     | 0x0                   | Readable and writeable reserved bits.                                                        |
| APE Status                                                 | 26    | RW     | 0                     | This bit is used by bootcode to post the APE initialization status.                          |
| Eclk switch using link status<br>Disable                   | 25    | RW     | 0x0<br>BCM5718<br>0x1 | Switch emac clocks to core clock based on lnk state.  0: Enable  1: Disable                  |
|                                                            |       |        | BCM5719               |                                                                                              |
| OOB Power Consumption FIX for 5784 Option 4                | 24    | RW     | 0x0                   | Enable fix for OOB Power Consumption FIX for 5784 option 4.  1 = Enable                      |
|                                                            |       |        |                       | 0 = Disable                                                                                  |
| OOB Power Consumption FIX for 5784 Option 3                | 23    | RW     | 0x0                   | Disable fix for OOB Power Consumption FIX for 5784 option 3.  1 = Enable  0 = Disable        |
| OOB Power Consumption FIX for 5784 Option 2                | 22    | RW     | 0x0                   | Disable fix for OOB Power Consumption FIX for 5784 option 2.  1 = Disable  0 = Enable        |
| OOB Power Consumption FIX for 5784 Option 1                | 21    | RW     | 0x0                   | Enable fix for OOB Power Consumption FIX for 5784 option 1.  1 = Enable 0 = Disable          |
| Incorrect checksum on LSO packets Fix Disable              | 20    | RW     | 0x0                   | Disable fix for incorrect checksum on LSO packets.  1 = Disable  0 = Enable                  |
| PCIE pcie_tmux_sel[1:0]                                    | 19:18 | RW     | 0x0                   | -                                                                                            |
| Reserved                                                   | 17:13 | DC     | 0                     | -                                                                                            |
| PLLisUp signal drive                                       | 12    | RW     | 0x0                   | When 0, force the PLLisUp signal to be 1. When 1, let the hardware drive the PLLisUp signal. |
| PCIE pcie_tmux_sel[3:2]                                    | 11:10 | RW     | 0x0                   | -                                                                                            |
| Reserved                                                   | 9     | RW     | 0                     | _                                                                                            |
| Capability version for completion timeout ECN for PCIE 1.1 | 8     | RW     | 0x0                   | 1 = Version 1; Fix Disable<br>0 = Version 2; Fix Enable                                      |
| Reserved                                                   | 7:0   | DC     | 0x0                   | -                                                                                            |

## 13.19.26 Flash Clock Policy Register (offset: 0x366C)

For BCM5719/5720 only. This register is reset by POR Reset or CPMU Register Software Reset. The Force Disable bit has higher priority than Override Enable. This register is shared by all 4 MAC ports. User must first gain grant from the global MUTEX registers (0x36F0 & 0x36F4) before writing to this register.

|                             |       |        | Default |                                                                                         |
|-----------------------------|-------|--------|---------|-----------------------------------------------------------------------------------------|
| Name                        | Bits  | Access | Value   | Description                                                                             |
| Flash Clock Speed           | 31    | RW     | 0x0     | Enable Flash clock override*.                                                           |
|                             |       |        |         | Override Enable                                                                         |
|                             |       |        |         | 1: Enable Flash clock override                                                          |
|                             |       |        |         | 0: Disable Flash clock override                                                         |
| Force Flash Clock Disable   | 30    | RW     | 0x0     | Flash clock Disable*.                                                                   |
|                             |       |        |         | 1: Disable Flash clock                                                                  |
|                             |       |        |         | 0: Enable Flash clock                                                                   |
| Flash Idle mode Enable      | 29    | RW     | 0x0     | Flash Idle mode Enable                                                                  |
|                             |       |        |         | 1: Enable Flash Idle mode                                                               |
|                             |       |        |         | 0: Disable Flash Idle mode                                                              |
| Force EAV Clock Disable     | 28    | RW     | 0x0     | EAV clock Disable                                                                       |
|                             |       |        |         | 1: Disable EAV clock                                                                    |
|                             |       |        |         | 0: Enable EAV clock                                                                     |
| Reserved                    | 27:20 | DC     | 0       | _                                                                                       |
| EAV Clock Policy            | 19:12 | RW     | 0x0     | Software Controlled EAV Clock Speed Select                                              |
| ,                           |       |        |         | 00000000: divide-by-256 Clock frequency 4.8 MHz                                         |
|                             |       |        |         | 00000001: divide-by-1 Clock frequency 1250 MHz (Unused for                              |
|                             |       |        |         | EAV)                                                                                    |
|                             |       |        |         | 00000010: divide-by-2 Clock frequency 625 MHz (Unused for                               |
|                             |       |        |         | EAV)                                                                                    |
|                             |       |        |         | ···                                                                                     |
|                             |       |        |         | 00001010: divide-by-10 Clock frequency of 125 MHz                                       |
|                             |       |        |         | 00001011: divide-by-11 Clock frequency of 113.6 MHz                                     |
|                             |       |        |         |                                                                                         |
|                             |       |        |         | 11111111=divide-by-255 Clock frequency of 4.9 MHz                                       |
| Reserved                    | 11    | DC     | 0       | _                                                                                       |
| Flash Idle Clock Policy     | 10:8  | RW     | 0x2     | Software Controlled Flash Clock Speed Select000: 62.5 MHz (NCSI DLL) 010: 25 MHz (CK25) |
| Reserved                    | 7     | DC     | 0       | _                                                                                       |
| Flash Clock Policy          | 6:4   | RW     | 0x0     | Software Controlled Flash Clock Speed Select000: 62.5 MHz (NCSI DLL) 010: 25 MHz (CK25) |
| Reserved                    | 3     | DC     | 0       | -                                                                                       |
| Override Flash Clock Switch | 2:0   | RW     | 0x2     | Software Controlled Flash Clock Speed Select000: 62.5 MHz (NCSI DLL) 010: 25 MHz (CK25) |

# 13.19.27 Link Idle Control Register (offset: 0x3670)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name          | Bits  | Access | Default<br>Value | Description                                                                       |
|---------------|-------|--------|------------------|-----------------------------------------------------------------------------------|
| Reserved      | 31:25 | DC     | 0                | Readable and writeable reserved bits.                                             |
| PCIE Idle     | 24    | RW     | 1                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode   |
| APE ATP Empty | 23    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| APE ATPM Idle | 22    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| DBU Idle      | 21    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| NVM Idle      | 20    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| SBDI Idle     | 19    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| RBDI Idle     | 18    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode   |
| MB Idle       | 17    | RW     | 0                | Link idle/Host Access condition control.                                          |
|               |       |        |                  | 1: disable this idle condition when entering link idle mode and host access mode. |
|               |       |        |                  | 0: enable this idle condition when entering link idle mode and host access mode.  |
| Reserved      | 16    | DC     | 0                | -                                                                                 |

| Name             | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                   |
|------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDMA Idle        | 15   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| RDMA Idle        | 14   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| MSI Idle         | 13   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| TXMAC FIFO empty | 12   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| RXMAC FIFO empty | 11   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| COL = 0          | 10   | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| CRS = 0          | 9    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| TXAMAC Idle      | 8    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| RXER = 0         | 7    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |

| Name          | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                   |
|---------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXDV = 0      | 6    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| MDIO Idle     | 5    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| FTQ empty     | 4    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| GRC Idle      | 3    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| MBUF empty    | 2    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| MA Idle       | 1    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |
| No core reset | 0    | RW     | 0                | Link idle/Host Access condition control.  1: disable this idle condition when entering link idle mode and host access mode.  0: enable this idle condition when entering link idle mode and host access mode. |

## 13.19.28 Link Idle Status Register (offset: 0x3674)

This register is reset by POR Reset or CPMU Register Software Reset.

| Name             | Bits  | Access | Default<br>Value | Description                          |
|------------------|-------|--------|------------------|--------------------------------------|
| Reserved         | 31:25 | DC     | _                | Readable and writeable reserved bits |
| PCIE Idle        | 24    | RO     | _                | Idle Status.                         |
| APE ATP Empty    | 23    | RO     | _                | 1: Idle                              |
| APE ATPM Idle    | 22    | RO     | _                | 0: Busy                              |
| DBU Idle         | 21    | RO     | _                |                                      |
| NVM Idle         | 20    | RO     | _                |                                      |
| SBDI Idle        | 19    | RO     | _                |                                      |
| RBDI Idle        | 18    | RO     | _                |                                      |
| MB Idle          | 17    | RO     | _                |                                      |
| Reserved         | 16    | DC     | _                | _                                    |
| WDMA Idle        | 15    | RO     | _                | Idle Status.                         |
| RDMA Idle        | 14    | RO     | _                | 1: Idle                              |
| MSI Idle         | 13    | RO     | _                | 0: Busy                              |
| TXMAC FIFO empty | 12    | RO     | _                |                                      |
| RXMAC FIFO empty | 11    | RO     | _                |                                      |
| COL = 0          | 10    | RO     | _                |                                      |
| CRS = 0          | 9     | RO     | _                |                                      |
| TXAMAC Idle      | 8     | RO     | _                |                                      |
| RXER = 0         | 7     | RO     | _                |                                      |
| RXDV = 0         | 6     | RO     | _                |                                      |
| MDIO Idle        | 5     | RO     | _                |                                      |
| FTQ empty        | 4     | RO     | _                |                                      |
| GRC Idle         | 3     | RO     | _                |                                      |
| MBUF empty       | 2     | RO     | _                |                                      |
| MA Idle          | 1     | RO     | _                |                                      |
| No core reset    | 0     | RO     | _                |                                      |

# 13.19.29 Top Level Miscellaneous Control 1 Register (offset: 0x367C)

For BCM5719/5720 only. This register is reset by POR Reset or CPMU Register Software Reset. This register is shared by 4 MAC ports. User must first gain grant from the global MUTEX registers (0x36F0 & 0x36F4) before writing to this register.

| Name                      | Bits | Access | Default<br>Value | Description                                                                                     |
|---------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------|
| Reserved                  | 31:6 | RW     | 0                | -                                                                                               |
| Low power IDDQ mode       | 5    | RW     | 0                | 1-Enable to put all ports in GPHY mode during low power IDDQ to select GPHY mode to save power. |
|                           |      |        |                  | 0-SerDes mode in low power IDDQ mode by default, draws more current                             |
| NCSI Clock output disable | 4    | RW     | 0                | 1-To enable the NCSI clock disable feature, NCSI clock signal pin is driven low                 |
|                           |      |        |                  | 0–NCSI clock output active (default)                                                            |
| 47147 fix disable         | 3    | RW     | 0                | 47147 fix disable-PCIe MDIO reset fix disable.                                                  |
|                           |      |        |                  | 1-Disable                                                                                       |
|                           |      |        |                  | 0–Enable                                                                                        |
| 47173 fix disable         | 2    | RW     | 0                | 47173 fix disable-CLKREQ_L tri-state fix disable.                                               |
|                           |      |        |                  | 1-Disable                                                                                       |
|                           |      |        |                  | 0–Enable                                                                                        |
| Debug UART Port Selection | 1    | RW     | 0                | Select the Debug UART Port.                                                                     |
|                           |      |        |                  | 00: port0                                                                                       |
|                           |      |        |                  | 01: port1                                                                                       |
|                           |      |        |                  | 10: port2                                                                                       |
|                           |      |        |                  | 11: port3                                                                                       |

## 13.19.30 Miscellaneous Control Register (offset: 0x36AC)

| Name                           | Bits  | Access | Default<br>Value | Description                                                                       |
|--------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------|
| Reserved                       | 31:26 | DC     | 0x0              | -                                                                                 |
| Speculative early L1 exit mode | 25:24 | RW     | 0x0              | Mode control for speculative early L1 exit.                                       |
|                                |       |        |                  | 2'b00: Enable speculative early L1 exit when Ethernet is linked to 1000 Mb/s only |
|                                |       |        |                  | 2'b01: Enable speculative early L1 exit regardless link speed                     |
|                                |       |        |                  | 2'b10: Disabled speculative early L1 exit                                         |
|                                |       |        |                  | 2'b11: Reserved                                                                   |

| Name                            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Speculative early L1 exit delay | 23:16 | RW     | 0x0              | Delay control for speculative early L1 exit detection. The detection circuit uses the earliest receive packet indicator after mac address filtering circuit. Each increment increases the delay by 10.240 μS. 0x0: no delay 0x1: 10.24 μs delay 0x2: 20.48 μs delay 0xFF: 2621.44 μs delay 0xFF: 2621.44 μs delay The optimal value of this delay is a function of link speed, packet size, L1 exit latency, L1 entrance inactive timer value and the following simulation data. 1000 MB/s 1518byte packet—advances l1aspm exiting by 13.880 μs with no delay 1000 MB/s 64byte packet—advances l1aspm exiting by 2.488 μs with no delay 100 MB/s 1518byte packet—advances l1aspm exiting by 129.377 μs with no delay 100 MB/s 64byte packet—advances l1aspm exiting by 13.217 μs with no delay 10 MB/s 1518byte packet—advances l1aspm exiting by 13.217 μs with no delay 10 MB/s 1518byte packet—advances l1aspm exiting by 1274.94 μs |
| December                        | 45.0  | DO.    | 00               | with no delay 10 MB/s 64byte packet–advances l1aspm exiting by 113.98 µs with no delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Reserved                        | 15:0  | DC     | 0x0              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## 13.19.31 EEE Mode Register (offset: 0x36B0)

| Name                           | Bits  | Access | Default<br>Value | Description                                                                                                             |
|--------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| Reserved                       | 31:20 | RO     | 0x0              | -                                                                                                                       |
| Drive Allow LPI Enable         | 19    | RW     | 0x0              | Enable Control bit allocated for driver to allow CPMU to go into EEE mode.                                              |
| EEE Block Time                 | 18:11 | RW     | 0x0              | Block out time from de-assertion of EEE MAC TX request to when the EEE module considers new request to enter LPI again. |
| Auto Wake Enable               | 10    | RW     | 0x0              | Enable automatic removal of Link from LPI state when MAC wants to transmit.                                             |
| RX LPI Enable                  | 9     | RW     | 0x0              | Enable LPI indication in RX direction.                                                                                  |
| TX LPI Enable                  | 8     | RW     | 0x0              | Enable LPI indication in TX direction.                                                                                  |
| User LPI Enable                | 7     | RW     | 0x0              | Main LPI enable bit set by user.                                                                                        |
| Send Index Detection Enable    | 6     | RW     | 0x0              | This bit allows CPMU to use the send consumer and producer equal term to determine EEE mode.                            |
| RX CPU Allow LPI Enable        | 5     | RW     | 0x0              | Enable Control bit allocated for RX CPU to allow CPMU to go into EEE mode.                                              |
| PCIE L1 Exit Detection Enable  | 4     | RW     | 0x0              | This bit allows CPMU to use the PCIE early L1 exit detection term to determine EEE mode.                                |
| EEE Link Idle Detection Enable | 3     | RW     | 0x0              | This bit allows CPMU to use the EEE link idle detection term to determine EEE mode.                                     |
| APE TX Detection Enable        | 2     | RW     | 0x0              | This bit allows CPMU to use the APE TX detection term to determine EEE mode.                                            |
| Drive Allow LPI                | 1     | RW     | 0x0              | Control bit allocated for driver to allow CPMU to go into EEE mode.                                                     |
| RX CPU Allow LPI               | 0     | RW     | 0x0              | Control bit allocated for RX CPU to allow CPMU to go into EEE mode.                                                     |

## 13.19.32 EEE Debounce Timer 1 Control Register (offset: 0x36B4)

| Name                                 | Bits  | Access | Default<br>Value | Description                                                   |
|--------------------------------------|-------|--------|------------------|---------------------------------------------------------------|
| PCIE Early L1 Exit Debounce<br>Timer | 31:16 | RW     | 0x3F             | PCIE early L1 exit debounce timer in us.<br>Default is 63 μs. |
| EEE Link Idle Debounce Timer         | 15:0  | RW     | 0x3F             | EEE link idle debounce timer in us.                           |
|                                      |       |        |                  | Default is 63 μs.                                             |

## 13.19.33 EEE Debounce Timer 2 Control Register (offset: 0x36B8)

| Name                        | Bits  | Access | Default<br>Value | Description                                                  |
|-----------------------------|-------|--------|------------------|--------------------------------------------------------------|
| APE Transmit Debounce Timer | 31:16 | RW     | 0x3F             | APE transmit debounce timer in us.                           |
|                             |       |        |                  | Default is 63 μs.                                            |
| Send Index Equal Debounce   | 15:0  | RW     | 0x3F             | Send producer and consumer index equal debounce timer in µs. |
| Timer                       |       |        |                  | Default is 63 μs.                                            |

# 13.19.34 EEE Link Idle Control Register (offset: 0x36BC)

| Name                       | Bits  | Access | Default<br>Value | Description                                                                                                                      |
|----------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Reserved                   | 31:25 | RO     | 0x0              | -                                                                                                                                |
| PCIE not in L0 State       | 24    | RW     | 0x0              | PCIE status control.                                                                                                             |
|                            |       |        |                  | 1: disable this idle condition from the EEE idle detection logic.                                                                |
|                            |       |        |                  | 0: enable this idle condition in the EEE idle detection logic UART is idle.No on-going MDIO access.IE is in L0s, L1 or L2 state. |
| Reserved                   | 23:4  | RW     | 0x0              | _                                                                                                                                |
| MDIO Idle                  | 3     | RW     | 0x0              | MDIO status control.                                                                                                             |
|                            |       |        |                  | 1: disable this idle condition from the EEE idle detection logic.                                                                |
|                            |       |        |                  | 0: enable this idle condition in the EEE idle detection logic UART is idle.No on-going MDIO access.                              |
| Debug UART Idle            | 2     | RW     | 0x0              | Debug UART status control.                                                                                                       |
|                            |       |        |                  | 1: disable this idle condition from the EEE idle detection logic.                                                                |
|                            |       |        |                  | 0: enable this idle condition in the EEE idle detection logic UART is idle.                                                      |
| APE TX Packet Buffer Empty | 1     | RW     | 0x0              | APE subsystem internal packet buffer status control.                                                                             |
|                            |       |        |                  | 1: disable this idle condition from the EEE idle detection logic.                                                                |
|                            |       |        |                  | 0: enable this idle condition in the EEE idle detection logic.                                                                   |
| LAN TX Packet Buffer Empty | 0     | RW     | 0x0              | LAN core internal packet buffer status control.                                                                                  |
|                            |       |        |                  | 1: disable this idle condition from the EEE idle detection logic.                                                                |
|                            |       |        |                  | 0: enable this idle condition in the EEE idle detection logic.                                                                   |

# 13.19.35 EEE Link Idle Status Register (offset: 0x36C0)

| Name                       | Bits  | Access | Default<br>Value | Description                                               |
|----------------------------|-------|--------|------------------|-----------------------------------------------------------|
| Reserved                   | 31:25 | RO     | 0x0              | -                                                         |
| PCIE not in L0 State       | 24    | RO     | 0x0              | PCIE is in L0s, L1 or L2 state.                           |
| Reserved                   | 23:4  | RO     | 0x0              | _                                                         |
| MDIO Idle                  | 3     | RO     | 0x0              | No on-going MDIO access.                                  |
| Debug UART Idle            | 2     | RO     | 0x0              | Debug UART is idle.                                       |
| APE TX Packet Buffer Empty | 1     | RO     | 0x0              | Internal packet buffers in APE subsystem for TX is empty. |
| LAN TX Packet Buffer Empty | 0     | RO     | 0x0              | Internal packet buffers in LAN core for TX is empty.      |

# 13.19.36 EEE Statistic Counter 1 Register (offset: 0x36C4)

| Name                      | Bits | Access | Default<br>Value | Description                                                                                                                      |
|---------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------|
| EEE Mode Entering Counter | 31:0 | RW     | 0x0              | This counter counts the number of times CPMU goes into EEE mode. The entire 32 bit register can be cleared by writing 0xFFFFFFF. |

## 13.19.37 EEE Statistic Counter 2 Register (offset: 0x36C8)

| Name                         | Bits | Access | Default<br>Value | Description                                                                                                                              |
|------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Receive LPI Entering Counter | 31:0 | RW     |                  | This counter counts the number of times the receive side goes into LPI. The entire 32 bit register can be cleared by writing 0xFFFFFFFF. |

## 13.19.38 EEE Statistics Counter 3 Register (offset: 0x36CC)

| Name                           | Bits | Access | Default<br>Value | Description                                                                                                                                                  |
|--------------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EEE Link Idle Entering Counter | 31:0 | RW     |                  | This counter counts the number of timers the debounced version of EEE link idle is asserted. The entire 32 bit register can be cleared by writing 0xFFFFFFF. |

## 13.19.39 EEE Control Register (offset: 0x36D0)

| Name               | Bits  | Access | Default<br>Value | Description                                                                                 |
|--------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------|
| EEE Minimum Assert | 31:16 | RW     | 0x0              | The minimum time from start of LPI message transmission to end of LPI message transmission. |
| EEE Exit Time      | 15:0  | RW     | 0x190            | Time from the end of LPI message transmission to when normal transmission is allowed again. |

# 13.19.40 Current Measurement Control Register (offset: 0x36D4)

| Name              | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                      |
|-------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved          | 31:5 | RW     | 0x0              | -                                                                                                                                                                                                                                |
| Freeze 2s Average | 4    | RW     | 0x0              | Stop the update of the 2 second average register. The accumulation and holding registers will still update.                                                                                                                      |
| Freeze Count      | 3    | RW     | 0x0              | Stop the accumulation process of the PDRIVE samples. This effectively disables the cur_meas block, and freezes all values of registers. This bit can be set to stop the register updates for register reads, and then restarted. |
| Recalibrate       | 2    | RW     | 0x0              | Restart the calibration process and capture a single 500 µs accumulation period.                                                                                                                                                 |

| Name                     | Bits | Access | Default<br>Value | Description                                                                      |
|--------------------------|------|--------|------------------|----------------------------------------------------------------------------------|
| Current Measurement Read | 1:0  | RW     | 0x0              | 0x0: Current Measurement Upper 32-bit Read Register = 0x0                        |
| Select                   |      |        |                  | Current Measurement Lower 32-bit Read Register = 500 µs Calibration Count        |
|                          |      |        |                  | 0x1: Current Measurement Upper 32-bit Read Register = 1s Hold Count[63:32]       |
|                          |      |        |                  | Current Measurement Lower 32-bit Read Register = 1s Hold Count[31:0]             |
|                          |      |        |                  | 0x2: Current Measurement Upper 32-bit Read Register = 2s Hold Count[63:32]       |
|                          |      |        |                  | Current Measurement Lower 32-bit Read Register = 2s Hold Count[31:0]             |
|                          |      |        |                  | 0x3: Current Measurement Upper 32-bit Read Register = 2s<br>Average Count[63:32] |
|                          |      |        |                  | Current Measurement Lower 32-bit Read Register = 2s Average Count [31:0          |

## 13.19.41 Current Measurement Upper 32-bit Read Register (offset: 0x36D8)

| Name                                         | Bits | Access | Default<br>Value | Description                 |
|----------------------------------------------|------|--------|------------------|-----------------------------|
| Upper 32-bit of Current<br>Measurement Count | 31:0 | RO     | 0x0              | Please refer to 0x36D4[1:0] |

## 13.19.42 Current Measurement Lower 32-bit Read Register (offset: 0x36DC)

| Name                                         | Bits | Access | Default<br>Value | Description                 |
|----------------------------------------------|------|--------|------------------|-----------------------------|
| Lower 32-bit of Current<br>Measurement Count | 31:0 | RO     | 0x0              | Please refer to 0x36D4[1:0] |

#### 13.19.43 Global Mutex Request Register (offset: 0x36F0)

**NOTE:** This register is for BCM5719/BCM5720 only.

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                    | 31:8 | DC     | 0                | -                                                                                                                                                                                                                                                                                                                                                |
| Set Request/Request Pending | 7:0  | RW 1S  | 0x0              | Writing a 1 to any of these bits pends a Mutex lock request on behalf of a s/w agent. The bit is subsequently latched by hardware and shall read 1 as long as the request is pending. Writing a 0 to a bit shall have no effect. Reading this field may return zero or more bits with value 1—each bit with value 1 indicates a pending request. |

#### 13.19.44 Global Mutex Grant Register (offset: 0x36F4)

**NOTE:** This register is for BCM5719/BCM5720 only.

This register is reset by POR Reset or CPMU Register Software Reset.

| Name                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                    | 31:8 | DC     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Set Request/Request Pending | 7:0  | RW 1S  | 0x0              | Reading this field shall return a maximum of one set bit at any time. The set bit shall point to the lock owner. If the Mutex is not locked, a read shall return a value 0x0000. Writing a 1 to the already set bit shall relinquish the lock and the set bit shall be cleared. Writing a 1 to an unset bit shall cancel the corresponding pending request if there was any—and the paring bit in the Mutex_Request_Reg shall be cleared. Writing a 0 to any bits has no effect. |

#### 13.19.45 Temperature Monitor Control Register (offset: 0x36FC)

**NOTE:** This register is for BCM5719 and BCM5720 only.

This register is reset by POR Reset or CPMU Register Software Reset. This register is shared by 4 MAC ports. User must first gain grant from the global MUTEX registers (0x36F0 & 0x36F4) before writing to it.

| Name                           | Bits  | Access | Default<br>Value | Description                    |
|--------------------------------|-------|--------|------------------|--------------------------------|
| Reserved                       | 31:19 | RO     | 0                | _                              |
| Temperature Monitor Power Down | 18    | RW     | 0                | Temperature Monitor Power Down |
| Temperature Monitor Hold       | 17    | RW     | 0                | Temperature Monitor Hold       |
| Temperature Data               | 16:8  | RO     | 0                | Temperature Data               |
| Bias Adjust                    | 7:1   | RW     | 0                | Bias Adjust                    |
| ADC Test Enable                | 0     | RW     | 1                | ADC Test Enable                |

## 13.20 Host Coalescing Control Registers

The Host Coalescing Control Registers are responsible for pacing the rate at which the NIC updates the host's transmit and receive buffer descriptor ring indices. Although the host produces and receives frames in one or more buffer descriptors, the Host Coalescing state machine always updates the host on frame boundaries. Additionally, the Host Coalescing state machine regulates the rate at which the statistics are updated in host memory.

All registers reset are core reset unless specified.

#### 13.20.1 Host Coalescing Mode Register (offset: 0x3C00)

| Name                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                |
|------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                     | 31:13 | RO     | 0                | -                                                                                                                                                                                                          |
| No Interrupt on DMAD Force   | 12    | RW     | _                | When set, the COAL_NOW bit of the buffer descriptor may be set to force a status block update without a corresponding interrupt.                                                                           |
| No Interrupt on Force update | 11    | RW     | _                | When set, writing the Coalesce Now bit will cause a status without a corresponding interrupt event.                                                                                                        |
| Reserved                     | 10    | RO     | 0                | When set, the TX Host Coalescing Tick counter initializes to the idle state and begins counting only after a transmit BD event is detected.                                                                |
| Clear Ticks Mode on Rx       | 9     | RW     | _                | When set, the RX Host Coalescing Tick counter initializes to the idle state and begins counting only after a receive BD event is detected.                                                                 |
| Status Block Size            | 8:7   | RW     | _                | Status Block Size for partial status block updates 00: Full status block 01: 64 byte 10: 32 byte 11: Undefined                                                                                             |
| MSI Bits                     | 6:4   | RW     | 1                | The least significant MSI 16-bit word is overwritten by these bits.  Defaults to 0.                                                                                                                        |
| Coalesce Now                 | 3     | RW     | 0                | If set, Host Coalescing updates the Status Block immediately and sends an interrupt to host. This is a self-clearing bit. (For debug purpose only.)                                                        |
| Attn Enable                  | 2     | RW     | _                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                                                                        |
| Enable                       | 1     | RW     | -                | This bit control whether the Host Coalescing state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                        | 0     | RW     | _                | When this bit is set to 1, the Host Coalescing state machine is reset. This is a self-clearing bit.                                                                                                        |

## 13.20.2 Host Coalescing Status Register (offset: 0x3C04)

| Name     | Bits | Access | Default<br>Value | Description                  |
|----------|------|--------|------------------|------------------------------|
| Reserved | 31:3 | RO     | 0                | _                            |
| Error    | 2    | RO     | _                | Host Coalescing Error Status |
| Reserved | 1:0  | RO     | 0                | -                            |

#### 13.20.3 Receive Coalescing Ticks Register (offset: 0x3C08)

The value in this register can be used to control how often the status block is updated (and how often interrupts are generated) due to receiving packets. The value in this register controls how many ticks, in units of 1 µs each, get loaded in an internal receive tick timer register. The timer will be reset to the value of this register and will start counting down after every status block update (regardless of the reason for the status block update). The timer is only reset after status block updates, and is not reset after any given packet is received. When the timer reaches 0, it will be considered to be in the expired state. Once the counter is in the expired state, a status block update will occur if a packet had been received and copied to host memory (via DMA) since the last status block update.

This register must be initialized by host software. A value of 0 in this register disables the receive tick coalescing logic. In this case, status block updates will occur for receive event only if the Receive Max Coalesced BD value is reached. Of course, status block updates for other reasons (e.g., transmit events) will also include any updates to the receive indices. By setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to receiving packets. This will generally increase performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. For host environments where receive interrupt latency needs to be very low, and the host is not close to be saturated, it is recommended that this register be set to 1.

#### IOV is enabled:

Receive Coalescing Ticks Register for VRQ 0 => 0x3C08

Receive Coalescing Ticks Register for VRQ 1 => 0x3D80

Receive Coalescing Ticks Register for VRQ 2 => 0x3D98

Receive Coalescing Ticks Register for VRQ 3 => 0x3DB0

Receive Coalescing Ticks Register for VRQ 4 => 0x3DC8

Receive Coalescing Ticks Register for VRQ 5 => 0x3DE0

Receive Coalescing Ticks Register for VRQ 6 => 0x3DF8

Receive Coalescing Ticks Register for VRQ 7 => 0x3E10

Receive Coalescing Ticks Register for VRQ 8 => 0x3E28

Receive Coalescing Ticks Register for VRQ 9 => 0x3E40

Receive Coalescing Ticks Register for VRQ 10 => 0x3E58

Receive Coalescing Ticks Register for VRQ 11 => 0x3E70

Receive Coalescing Ticks Register for VRQ 12 => 0x3E88

Receive Coalescing Ticks Register for VRQ 13 => 0x3EA0

Receive Coalescing Ticks Register for VRQ 14 => 0x3EB8

Receive Coalescing Ticks Register for VRQ 15 => 0x3ED0

Receive Coalescing Ticks Register for VRQ 16 => 0x3EE8

#### 13.20.4 Send Coalescing Ticks Register (offset: 0x3C0C)

The value in this register can be used to control how often the status block is updated (and how often interrupts are generated) according to the completion of transmit events. The value in this register controls how many ticks, in units of 1 µs each, get loaded in an internal transmit tick timer register. The timer will be reset to the value of this register and will start counting down, after every status block update (regardless of the reason for the status block update). The timer is only reset after status block updates, and is not reset after a transmit event completes. When the timer reaches 0, it will be considered to be in the expired state. Once the counter is in the expired state, a status block update will occur if a transmit event has occurred since the last status block update. In this case, a transmit event is defined by an update to one of the device's Send BD Consumer Indices. It should be noted that a Send Consumer Index increments whenever the data associated with a particular packet has been successfully moved (via DMA) across the bus, rather than when the packet is actually transmitted over the Ethernet wire.

This register must be initialized by host software. A value of 0 in this register disables the transmit tick coalescing logic. In this case, status block updates will occur for transmit events only if the Send Max Coalesced BD value is reached, or if the BD\_FLAG\_COAL\_NOW bit is set in a send BD. Status block updates for other reasons (e.g., receive events) will also include any updates to the send indices. By setting the value in this register to a high number, a software device driver can reduce the number of status block updates, and interrupts, that occur due to transmit completions. This will generally increase performance in hosts that do not require their send buffers to be freed quickly. For host environments that do require their send buffers to be recovered quickly, it is recommended that this register be set to 0.

#### IOV + Multiple TXQ:

Send Coalescing Ticks Register for TXQ 0 => 0x3C0C

Send Coalescing Ticks Register for TXQ 1 => 0x3D84

Send Coalescing Ticks Register for TXQ 2 => 0x3D9C

Send Coalescing Ticks Register for TXQ 3 => 0x3DB4

Send Coalescing Ticks Register for TXQ 4 => 0x3DCC

Send Coalescing Ticks Register for TXQ 5 => 0x3DE4

Send Coalescing Ticks Register for TXQ 6 => 0x3DFC

Send Coalescing Ticks Register for TXQ 7 => 0x3E14

Send Coalescing Ticks Register for TXQ 8 => 0x3E2C

Send Coalescing Ticks Register for TXQ 9 => 0x3E44

Send Coalescing Ticks Register for TXQ 10 => 0x3E5C

Send Coalescing Ticks Register for TXQ 11 => 0x3E74

Send Coalescing Ticks Register for TXQ 12 => 0x3E8C

Send Coalescing Ticks Register for TXQ 13 => 0x3EA4

Send Coalescing Ticks Register for TXQ 14 => 0x3EBC

Send Coalescing Ticks Register for TXQ 15 => 0x3ED4

Send Coalescing Ticks Register for TXQ 16 => 0x3EEC

#### 13.20.5 Receive Max Coalesced BD Count Register (offset: 0x3C10)

This register contains the maximum number of receive return ring BDs that must be filled in by the device before the device will update the status block due to a receive event. Whenever the device completes the reception of a packet, it will fill in a receive return ring BD, and then increment an internal receive coalesce BD counter. When this internal counter reaches the value in this register, a status block update will occur. This counter will be reset (i.e., zeroed) whenever a status block update occurs regardless of the reason for the status block update. This register must be initialized by host software. A value of 0 in this register disables the receive max BD coalescing logic. In this case, status block updates will occur for receive packets only via the Receive Coalescing Ticks mechanism. Status block updates for other reasons (e.g., transmit events) will also include any updates to the receive indices. For simplicity, if a host wanted to get a status block update for every received packet, the host driver should just set this register to a value of 1. On the other hand, by setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to receiving packets. This can increase performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. However, in lower traffic environments, there is no guarantee that consecutive packets will be received in a timely manner. Therefore, for those environments, it is recommended that the Receive Coalescing Ticks register is used to make sure that status block updates due to receiving packets are not delayed for an infinite amount of time.

When IOV is enabled:

Receive Max Coalesced BD Count Register for VRQ 0 => 0x3C10

Receive Max Coalesced BD Count Register for VRQ 1 => 0x3D88

Receive Max Coalesced BD Count Register for VRQ 2 => 0x3DA0

Receive Max Coalesced BD Count Register for VRQ 3 => 0x3DB8

Receive Max Coalesced BD Count Register for VRQ 4 => 0x3DD0

Receive Max Coalesced BD Count Register for VRQ 5 => 0x3DE8

Receive Max Coalesced BD Count Register for VRQ 6 => 0x3E00

Receive Max Coalesced BD Count Register for VRQ 7 => 0x3E18

Receive Max Coalesced BD Count Register for VRQ 8 => 0x3E30

Receive Max Coalesced BD Count Register for VRQ 9 => 0x3E48

Receive Max Coalesced BD Count Register for VRQ 10 => 0x3E60

Receive Max Coalesced BD Count Register for VRQ 11 => 0x3E78

Receive Max Coalesced BD Count Register for VRQ 12 => 0x3E90

Receive Max Coalesced BD Count Register for VRQ 13 => 0x3EA8

Receive Max Coalesced BD Count Register for VRQ 14 => 0x3EC0

Receive Max Coalesced BD Count Register for VRQ 15 => 0x3ED8

Receive Max Coalesced BD Count Register for VRQ 16 => 0x3EF0

#### 13.20.6 Send Max Coalesced BD Count Register (offset: 0x3C14)

This register contains the maximum number of send BDs that must be processed by the device before the device will update the status block due to the transmission of packets. Whenever the device completes the DMA of transmit packet buffer, it increments an internal send coalesce BD counter. When this internal counter reaches the value in this register, a status block update will occur. This counter will be reset (i.e. zeroed) whenever a status block update occurs regardless of the reason for the status block update. This register must be initialized by host software. A value of 0 in this register disables the send max BD coalescing logic. In this case, status block updates will occur for receive packets only via the Send Coalescing Ticks mechanism. Of course, status block updates for other reasons (e.g., receive events) will also include any updates to the send indices. For simplicity, if a host wanted to get a status block update for every transmitted packet, the host driver could just set this register to a value of 1. On the other hand, by setting the value in this register to a high number, a software device driver can reduce the number of status block updates and interrupts that occur due to transmitting packets. This can increase performance in hosts that are under a high degree of stress and whose RISCs are saturated due to handling a large number of interrupts from the network controller. However, in lower traffic environments, there is no guarantee that consecutive packets will be transmitted in a timely manner. Therefore, for those environments, it is recommended that the Send Coalescing Ticks register is used to make sure that status block updates due to transmitting packets are not delayed for an infinite amount of time.

#### IOV + Multiple TXQ:

Send Max Coalesced BD Count Register for TXQ 0 => 0x3C14

Send Max Coalesced BD Count Register for TXQ 1 => 0x3D8C

Send Max Coalesced BD Count Register for TXQ 2 => 0x3DA4

Send Max Coalesced BD Count Register for TXQ 3 => 0x3DBC

Send Max Coalesced BD Count Register for TXQ 4 => 0x3DD4

Send Max Coalesced BD Count Register for TXQ 5 => 0x3DEC

Send Max Coalesced BD Count Register for TXQ 6 => 0x3E04

Send Max Coalesced BD Count Register for TXQ 7 => 0x3E1C

Send Max Coalesced BD Count Register for TXQ 8 => 0x3E34

Send Max Coalesced BD Count Register for TXQ 9 => 0x3E4C

Send Max Coalesced BD Count Register for TXQ 10 => 0x3E64

Send Max Coalesced BD Count Register for TXQ 11 => 0x3E7C

Send Max Coalesced BD Count Register for TXQ 12 => 0x3E94

Send Max Coalesced BD Count Register for TXQ 13 => 0x3EAC

Send Max Coalesced BD Count Register for TXQ 14 => 0x3EC4

Send Max Coalesced BD Count Register for TXQ 15 => 0x3EDC

Send Max Coalesced BD Count Register for TXQ 16 => 0x3EF4

# 13.20.7 Receive Max Coalesced BD Count During Interrupt Register (offset: 0x3C18)

This register has the same attribute as that of 0x3C10 except that this parameter is active only during the During Interrupt state – which is the state during which the ISR has acknowledged an interrupt by writing a non-zero value to the MailBox register and thus the interrupt is in a masked state. If this parameter triggers (while in During Interrupt state), the chip will DMA the latest Status Block to the host memory, but the interrupt will remain deasserted.

#### When IOV is enabled:

Receive Max Coalesced BD Count During Interrupt Register for VRQ 0 => 0x3C18 Receive Max Coalesced BD Count During Interrupt Register for VRQ 1 => 0x3D90 Receive Max Coalesced BD Count During Interrupt Register for VRQ 2 => 0x3DA8 Receive Max Coalesced BD Count During Interrupt Register for VRQ 3 => 0x3DC0 Receive Max Coalesced BD Count During Interrupt Register for VRQ 4 => 0x3DD8 Receive Max Coalesced BD Count During Interrupt Register for VRQ 5 => 0x3DF0 Receive Max Coalesced BD Count During Interrupt Register for VRQ 6 => 0x3E08 Receive Max Coalesced BD Count During Interrupt Register for VRQ 7 => 0x3E20 Receive Max Coalesced BD Count During Interrupt Register for VRQ 8 => 0x3E38 Receive Max Coalesced BD Count During Interrupt Register for VRQ 9 => 0x3E50 Receive Max Coalesced BD Count During Interrupt Register for VRQ 10 => 0x3E68 Receive Max Coalesced BD Count During Interrupt Register for VRQ 11 => 0x3E80 Receive Max Coalesced BD Count During Interrupt Register for VRQ 12 => 0x3E98 Receive Max Coalesced BD Count During Interrupt Register for VRQ 13 => 0x3EB0 Receive Max Coalesced BD Count During Interrupt Register for VRQ 14 => 0x3EC8 Receive Max Coalesced BD Count During Interrupt Register for VRQ 15 => 0x3EE0

#### 13.20.8 Send Max Coalesced BD Count During Interrupt Register (offset: 0x3C1C)

This register has the same attribute as that of 0x3C14 except that this parameter is active only during the During Interrupt state – which is the state during which the ISR has acknowledged an interrupt by writing a non-zero value to the MailBox register and thus the interrupt is in a masked state. If this parameter triggers (while in During Interrupt state), the chip will DMA the latest Status Block to the host memory, but the interrupt will remain deasserted.

IOV + Multiple TXQ:

Send Max Coalesced BD Count During Interrupt Register for TXQ 0 => 0x3C1C

Receive Max Coalesced BD Count During Interrupt Register for VRQ 16 => 0x3EF8

Send Max Coalesced BD Count During Interrupt Register for TXQ 1 => 0x3D94 Send Max Coalesced BD Count During Interrupt Register for TXQ 2 => 0x3DAC Send Max Coalesced BD Count During Interrupt Register for TXQ 3 => 0x3DC4 Send Max Coalesced BD Count During Interrupt Register for TXQ 4 => 0x3DDC Send Max Coalesced BD Count During Interrupt Register for TXQ 5 => 0x3DF4 Send Max Coalesced BD Count During Interrupt Register for TXQ 6 => 0x3E0C Send Max Coalesced BD Count During Interrupt Register for TXQ 7 => 0x3E24 Send Max Coalesced BD Count During Interrupt Register for TXQ 8 => 0x3E3C Send Max Coalesced BD Count During Interrupt Register for TXQ 9 => 0x3E54 Send Max Coalesced BD Count During Interrupt Register for TXQ 10 => 0x3E6C Send Max Coalesced BD Count During Interrupt Register for TXQ 11 => 0x3E84 Send Max Coalesced BD Count During Interrupt Register for TXQ 12 => 0x3E9C Send Max Coalesced BD Count During Interrupt Register for TXQ 13 => 0x3EB4 Send Max Coalesced BD Count During Interrupt Register for TXQ 14 => 0x3ECC Send Max Coalesced BD Count During Interrupt Register for TXQ 15 => 0x3EE4 Send Max Coalesced BD Count During Interrupt Register for TXQ 16 => 0x3EFC

#### 13.20.8.1 HC Parameter Set Reset Register (Offset: 0x3C28)

Place this in HC block.

| Name                               | Bits  | Access | Default<br>Value | Description                                                                                                                                                      |
|------------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Legacy                             | 31:17 | RU     | 0x0              | Unused                                                                                                                                                           |
| HC Parameter Set Reset Bit-<br>Map | 16:0  | RW     | 0x0              | Write a 1 to the position of this bit map to clear the respective HC Parameter Register Set – the associated internal HC states are also cleared by this action. |
|                                    |       |        |                  | This is useful for VRQ Flush-Synch purposes while in IOV Mode.                                                                                                   |

#### 13.20.8.2 Status Block Host Address Register (offset: 0x3C38)

This 64-bit register is in host address format and tells the NIC where to DMA the status block.

When IOV is enabled:

Status Block 0 Host Address Register (offset: 0x3C38)

Status Block 1 Host Address Register (offset: 0x3D00)

Status Block 2 Host Address Register (offset: 0x3D08)

Status Block 3 Host Address Register (offset: 0x3D10)

Status Block 4 Host Address Register (offset: 0x3D18)

Status Block 5 Host Address Register (offset: 0x3D20)

Status Block 6 Host Address Register (offset: 0x3D28)

Status Block 7 Host Address Register (offset: 0x3D30)

Status Block 8 Host Address Register (offset: 0x3D38)

Status Block 9 Host Address Register (offset: 0x3D40)

Status Block 10 Host Address Register (offset: 0x3D48)

Status Block 11 Host Address Register (offset: 0x3D50)

Status Block 12 Host Address Register (offset: 0x3D58)

Status Block 13 Host Address Register (offset: 0x3D60)

Status Block 14 Host Address Register (offset: 0x3D68)

Status Block 15 Host Address Register (offset: 0x3D70)

Status Block 16 Host Address Register (offset: 0x3D78)

#### 13.20.9 Status Block Base Address Register (offset: 0x3C44)

This 32-bit register is the location of the status block structure in NIC memory.

**NOTE:** This register should always be set to 0xB00. See Appendix C: "Device Register and Memory Map," on page 513 for details.

#### 13.20.10 Flow Attention Register (offset: 0x3C48)

The Flow attention register reports attentions from the various transmit and receive state machines, flow-through queues and the MBUF allocator. Whenever one of these blocks detects an attention situation, it sets the appropriate bit in the Flow attention register. Refer to the state machine causing the attention to determine the exact cause. The attention bits are cleared by writing a one to the bit (W2C). If a bit is marked as fatal, it means that the associated state machine is halted, and that corrective action must be taken by a CPU.

| Name                            | Bits  | Access | Default<br>Value | Description                                                                        |
|---------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------|
| Send BD Initiator               | 31    | W2C    | _                | The Send BD Initiator state machine has caused an attention.                       |
| Send BD Completion              | 30    | W2C    | _                | The Send BD Completion state machine has caused an attention.                      |
| Send BD Ring Selector           | 29    | W2C    | _                | The Send BD Ring Selector state machine has caused an attention.                   |
| Send Data Initiator             | 28    | W2C    | _                | The Send Data Initiator state machine has caused an attention.                     |
| Send Data Completion            | 27    | W2C    | _                | The Send Data Completion state machine has caused an attention.                    |
| Reserved                        | 26:24 | RO     | 0                | -                                                                                  |
| Recv BD Initiator               | 23    | W2C    | _                | The Recv BD Initiator state machine has caused an attention.                       |
| Recv BD Completion              | 22    | W2C    | _                | The Recv BD Completion state machine has caused an attention.                      |
| Recv List Placement             | 21    | W2C    | _                | The Recv List Placement state machine has caused an attention.                     |
| Recv List Selector              | 20    | W2C    | _                | The Recv List Selector state machine has caused an attention.                      |
| Recv Data and Recv BD Initiator | 19    | W2C    | _                | The Recv Data and Recv BD Initiator state machine has caused an attention.         |
| Recv Data Completion            | 18    | W2C    | _                | The Recv Data Completion state machine has caused an attention.                    |
| RCB Incorrectly Configured      | 17    | W2C    | _                | Set if one of the RCBs is incorrectly configured based on the whole configuration. |
| DMA Completion Discard          | 16    | W2C    | _                | The DMA Completion Discard state machine has caused an attention.                  |
| Host Coalescing                 | 15    | W2C    | _                | The Host Coalescing state machine has caused an attention.                         |
| Reserved                        | 14:8  | RO     | 0                | -                                                                                  |
| Memory Arbiter                  | 7     | W2C    | _                | The Memory Arbiter has caused an attention.                                        |
| MBUF Low Water                  | 6     | W2C    | _                | The MBUF allocation state machine has reached the mbuf low water threshold.        |
| Reserved                        | 5:0   | RO     | 0                | -                                                                                  |

#### 13.20.10.1 NIC Jumbo Receive BD Consumer Index Register (offset: 0x3C50-0x3C58)

These three registers are shared by the Receive BD Completion and the Receive Data and Receive BD Initiator state machines. They are used to keep track of the receive BDs that have been DMAed to the controller.

| Name                                   | Bits | Access | Default<br>Value | Description                                                                                           |
|----------------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------|
| Reserved                               | 31:8 | RO     | 0                | _                                                                                                     |
| NIC Jumbo Receive BD<br>Producer Index | 7:0  | RW     | _                | Current Jumbo Received BD have been fetched by RDMA module and are available for incoming RX packets. |

#### 13.20.10.2 NIC Diag Receive Return Ring BD 0 Index Register (offset: 0x3C80)

| Name                                                  | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                        |
|-------------------------------------------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Local Diagnostic Receive<br>Return Ring 0 index value | 9:0  | RW     | 0                | Current Receive Return Ring 0 index value in HC module before applying RCB bit-mask value. The maximum value is 1023 for the BCM571X/BCM5720 family. This value will be masked by the RCB bit-mask in WDMA module before be DMAed in status block. |

#### 13.20.11 NIC Jumbo Receive BD Consumer Index Register (offset: 0x3C50)

| Name                                              | Bits | Access | Default<br>Value | Description                         |
|---------------------------------------------------|------|--------|------------------|-------------------------------------|
| Received BD jumbo Producer<br>Ring consumer Index | 7:0  | RW     | 0                | Current Received BD Consumer index. |

#### 13.20.12 NIC Standard Receive BD Consumer Index Register (offset: 0x3C54)

This registers is shared by the Receive BD Completion and the Receive Data and Receive BD Initiator state machines which is used to keep track of the receive BDs that have been DMAed to the NIC.

#### 13.20.13 NIC Mini Receive BD Consumer Index (offset: 0x3c58)

This register is shared by the Receive BD Completion and the Receive Data and Receive BD Initiator state machines which is used to keep track of the receive BDs that have been DMAed to the NIC.

#### 13.20.14 NIC Diagnostic Return Ring 0 Producer Index Register (offset: 0x3C80)

This register contains NIC Diagnostic Return Ring 0 Producer Index.

| Name                           | Bits | Access | Default<br>Value | Description                       |
|--------------------------------|------|--------|------------------|-----------------------------------|
| Reserved                       | 31:9 | RO     | 0                | -                                 |
| NIC Return Ring Producer Index | 8:0  | RW     | _                | NIC Return Ring 0 Producer Index. |

### 13.20.15 NIC Diagnostic Return Ring 1 Producer Index Register (offset: 0x3C84)

This register contains the Receive Return Ring 1 Producer Index.

| Name                           | Bits | Access | Default<br>Value | Description                       |
|--------------------------------|------|--------|------------------|-----------------------------------|
| Reserved                       | 31:9 | RO     | 0                | _                                 |
| NIC Return Ring Producer Index | 8:0  | RW     | _                | NIC Return Ring 1 Producer Index. |

#### 13.20.16 NIC Diagnostic Return Ring 2 Producer Index Register (offset: 0x3C88)

This register contains the Receive Return Ring 2 Producer Index.

| Name                           | Bits |    | Default<br>Value | Description                       |
|--------------------------------|------|----|------------------|-----------------------------------|
| Reserved                       | 31:9 | RO | 0                | -                                 |
| NIC Return Ring Producer Index | 8:0  | RW | _                | NIC Return Ring 2 Producer Index. |

#### 13.20.17 NIC Diagnostic Return Ring 3 Producer Index Register (offset: 0x3C8C)

This register contains the Receive Return Ring 3 Producer Index.

| Name                           | Bits | Access | Default<br>Value | Description                       |
|--------------------------------|------|--------|------------------|-----------------------------------|
| Reserved                       | 31:9 | RO     | 0                | -                                 |
| NIC Return Ring Producer Index | 8:0  | RW     | _                | NIC Return Ring 3 Producer Index. |

### 13.20.18 NIC Diagnostic Send BD Consumer Index Register (offset: 0x3CC0)

The register keeps track of the NIC local copy of the send BD ring consumer (not the host copy which is DMAed by the Host Coalescing engine to the host). It is shared between the Send BD Initiator and the Host Coalescing state machines.

| Name                       | Bits |    | Default<br>Value | Description                 |
|----------------------------|------|----|------------------|-----------------------------|
| Reserved                   | 31:9 | RO | 0                | -                           |
| NIC Send BD Consumer Index | 8:0  | RW | _                | NIC Send BD Consumer Index. |

# 13.21 Memory Arbiter Control Registers

All registers reset are core reset unless specified.

## 13.21.1 Memory Arbiter Mode Register (offset: 0x4000)

| Name                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                            |
|------------------------------|-------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                     | 31:30 | RO     | 0                | -                                                                                                                                                                                                                      |
| CPU pipeline Request Disable | 29    | RW     | 0                | When set to 1, the write/read requests from the internal CPU will be processed sequentially.                                                                                                                           |
| Low Latency Enable           | 28    | RW     | 0                | When set to 1, the read from the CPU to the RXMBUF will take the original MA protocol, where data_rd_valid always goes after cmd_ack.  If set to 0, the data_rd_valid overlaps at the same clock cycle as the cmd_ack. |
| Fast Path Read Disable       | 27    | RW     | 0                | Fast Path Read Disable. When set to 1, the read from the CPU to the RXMBUF will take the slow path that goes through the original memory arbitration logic.                                                            |
| Reserved                     | 26:21 | RO     | 0                | -                                                                                                                                                                                                                      |
| DMAW2 Addr Trap              | 20    | RW     | 0                | DMA Write 2 Memory Arbiter request trap enable.                                                                                                                                                                        |
| Reserved                     | 19:17 | RO     | 0                | -                                                                                                                                                                                                                      |
| SDI Addr Trap Enable         | 16    | RW     | 0                | Send Data Initiator Memory Arbiter request trap enable.                                                                                                                                                                |
| Reserved                     | 15:13 | RO     | 0                | -                                                                                                                                                                                                                      |
| RDI2 Addr Trap Enable        | 12    | RW     | 0                | Receive Data Initiator 2 Memory Arbiter request trap enable.                                                                                                                                                           |
| RDI1 Addr Trap Enable        | 11    | RW     | 0                | Receive Data Initiator 1 Memory Arbiter request trap enable.                                                                                                                                                           |
| RQ Addr Trap Enable          | 10    | RW     | 0                | Receive List Placement Memory Arbiter request trap enable.                                                                                                                                                             |
| Reserved                     | 9     | RO     | 0                | -                                                                                                                                                                                                                      |
| PCI Addr Trap Enable         | 8     | RW     | 0                | PCI Memory Arbiter request trap enable.                                                                                                                                                                                |
| Reserved                     | 7     | RO     | 0                | -                                                                                                                                                                                                                      |
| RX RISC Addr Trap Enable     | 6     | RW     | 0                | RX RISC Memory Arbiter request trap enable.                                                                                                                                                                            |
| DMAR1 Addr Trap Enable       | 5     | RW     | 0                | DMA Read 1 Memory Arbiter request trap enable.                                                                                                                                                                         |
| DMAW1 Addr Trap Enable       | 4     | RW     | 0                | DMA Write 1 Memory Arbiter request trap enable.                                                                                                                                                                        |
| RX-MAC Addr Trap Enable      | 3     | RW     | 0                | Receive MAC Memory Arbiter request trap enable.                                                                                                                                                                        |
| TX-MAC Addr Trap Enable      | 2     | RW     | 0                | Transmit MAC Memory Arbiter request trap enable.                                                                                                                                                                       |
| Enable                       | 1     | RW     | 1                | This bit controls whether the Memory Arbiter is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains 1 when read.                             |
| Reset                        | 0     | RW     | 0                | When this bit is set to 1, the Memory Arbiter state machine is reset. This is a self-clearing bit.                                                                                                                     |

# 13.21.2 Memory Arbiter Status Register (offset: 0x4004)

| Name             | Bits  |     | Default<br>Value | Description                              |
|------------------|-------|-----|------------------|------------------------------------------|
| Reserved         | 31:21 | RO  | 0                | -                                        |
| DMAW 2 Addr Trap | 20    | W2C | 0                | DMA Write 2 Memory Arbiter request trap. |

| Name              | Bits  | Access | Default<br>Value | Description                                           |
|-------------------|-------|--------|------------------|-------------------------------------------------------|
| Reserved          | 19:17 | RO     | 0                | -                                                     |
| SDI Addr Trap     | 16    | W2C    | 0                | Send Data Initiator Memory Arbiter request trap.      |
| Reserved          | 15:13 | RO     | 0                | -                                                     |
| RDI2 Addr Trap    | 12    | W2C    | 0                | Receive Data Initiator 2 Memory Arbiter request trap. |
| RDI1 Addr Trap    | 11    | W2C    | 0                | Receive Data Initiator 1 Memory Arbiter request trap. |
| RQ Addr Trap      | 10    | W2C    | 0                | Receive List Placement Memory Arbiter request trap.   |
| Reserved          | 9     | RO     | 0                | -                                                     |
| PCI Addr Trap     | 8     | W2C    | 0                | PCI Memory Arbiter request trap.                      |
| Reserved          | 7     | RO     | 0                | -                                                     |
| RX RISC Addr Trap | 6     | W2C    | 0                | RX RISC Memory Arbiter request trap.                  |
| DMAR1 Addr Trap   | 5     | W2C    | 0                | DMA Read 1 Memory Arbiter request trap.               |
| DMAW1 Addr Trap   | 4     | W2C    | 0                | DMA Write 1 Memory Arbiter request trap.              |
| RX-MAC Addr Trap  | 3     | W2C    | 0                | Receive MAC Memory Arbiter request trap.              |
| TX-MAC Addr Trap  | 2     | W2C    | 0                | Transmit MAC Memory Arbiter request trap.             |
| Reserved          | 1:0   | RO     | 0                | _                                                     |

## 13.21.3 Memory Arbiter Trap Address Low Register (offset: 0x4008)

| Name             | Bits  |    | Default<br>Value | Description                      |
|------------------|-------|----|------------------|----------------------------------|
| Reserved         | 31:21 | RO | 0                | -                                |
| MA Trap Addr Low | 20:0  | RW | _                | Memory Arbiter Trap Address Low. |

#### 13.21.4 Memory Arbiter Trap Address High Register (offset: 0x400C)

| Name              | Bits  | Access | Default<br>Value | Description                       |
|-------------------|-------|--------|------------------|-----------------------------------|
| Reserved          | 31:21 | RO     | 0                | -                                 |
| MA Trap Addr High | 20:0  | RW     | _                | Memory Arbiter Trap Address High. |

# 13.22 Buffer Manager Registers

All registers reset are core reset unless specified.

## 13.22.1 Buffer Manager Mode Register (offset: 0x4400)

| Name                              | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                           |
|-----------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXFIFO Underrun Prevention Enable | 31   | RW     | 0x1              | 1: Enable the EMAC TXFIFO underrun prevention during LSO offload operation. It will change the arbitration algorithm of TXMBUF read requests to round-robin among CPU, PCIE, RDMA and TXMAC. When TXFIFO is almost empty, RDMA will hold its request till TXFIFO is not almost empty. |
|                                   |      |        |                  | 0: Disable the EMAC TXFIFO underrun prevention during LSO offload operation. The arbitration algorithm of TXMBUF read requests will be priority-based among CPU, PCIE, RDMA and TXMAC. RDMA will ignore TXFIFO almost empty alert.                                                    |
| Reserved                          | 30:6 | RO     | 0                | -                                                                                                                                                                                                                                                                                     |
| Reset RXMBUF Pointer              | 5    | RWC    | 0                | When this bit is set, it will cause the RXMBUF allocation and deallocation pointer to reset back to the RXMBUF base. It will also cause the RXMAC to drop the preallocated MBUF and request a new one.                                                                                |
| MBUF Low Attn Enable              | 4    | RW     | 0                | MBUF Low Attn Enable MBUF low attention enable.                                                                                                                                                                                                                                       |
| BM Test mode                      | 3    | RW     | 0                | Buffer Manager Test mode. Must be set to 0 for normal operation.                                                                                                                                                                                                                      |
| Attention Enable                  | 2    | RW     | 0                | When this bit is set to 1, an internal attention is generated when an error occurs.                                                                                                                                                                                                   |
| Enable                            | 1    | RW     | 1                | This bit controls whether the Buffer Manager is active or not.                                                                                                                                                                                                                        |
|                                   |      |        |                  | When set to 0 it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read.                                                                                                                                                          |
| Reset                             | 0    | RW     | 0                | When this bit is set to 1, the Buffer Manager state machine is reset. This is a self-clearing bit.                                                                                                                                                                                    |

# 13.22.2 Buffer Manager Status Register (offset: 0x4404)

| Name               | Bits | Access | Default<br>Value | Description                 |
|--------------------|------|--------|------------------|-----------------------------|
| BM Test mode       | 31:5 | RO     | _                |                             |
| MBUF Low Attention | 4    | RO     | _                | MBUF Low Attention Status   |
| Reserved           | 3    | RO     | 0                | -                           |
| Error              | 2    | RO     | _                | Buffer Manager Error Status |
| Reserved           | 1:0  | RO     | 0                | -                           |

## 13.22.3 MBUF Pool Base Address Register (offset: 0x4408)

The MBUF Pool Base Address specifies the beginning of the MBUF.

| Name              | Bits  | Access | Default<br>Value | Description                                                                                                             |
|-------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| Reserved          | 31:23 | RO     | 0                | -                                                                                                                       |
| MBUF Base Address | 22:0  | RW     | 0xA000h          | Specifies beginning of the MBUF for receive packet.                                                                     |
|                   |       |        |                  | The base address will ignore the lower seven bits, thus aligning the beginning of the MBUF pool on a 128-byte boundary. |

#### 13.22.4 MBUF Pool Length Register (offset: 0x440C)

The register specifies the length of MBUF.

| Name        | Bits  | Access | Default<br>Value | Description                                                                                                                                                           |
|-------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved    | 31:23 | RO     | 0                | -                                                                                                                                                                     |
| MBUF Length | 22:0  | RW     |                  | Specifies the length of MBUF assigned for receive packet. The default is 32 KB. The lower seven bits should be ignored to align the MBUF pool on a 128-byte boundary. |

### 13.22.5 Read DMA MBUF Low Watermark Register (offset: 0x4410)

This 6-bit register indicates the number of free MBUFs that must be available for the Read DMA Engine to dequeue a descriptor from the normal priority FTQ. If the free MBUF count drops below this mark, it must go above the high watermark to resume normal operation.

#### 13.22.6 MAC RX MBUF Low Watermark Register (offset: 0x4414)

This 9-bit register indicates the number of free MBUFs that must be available for the RX MAC to accept a frame. If the free MBUF count drops below this mark, it must go above the high watermark to resume normal operation.

#### 13.22.7 Read DMA MBUF High Watermark Register (offset: 0x4418)

This 9-bit register indicates the number of free MBUFs that must be available before normal operation is restored to the Read DMA Engine and/or the RX MAC.

#### 13.22.8 RX RISC MBUF Cluster Allocation Request Register (offset: 0x441C)

The RX RISC MBUF Cluster Allocation Request register contains two fields:

- A requested size field which can be up to 64 KB long
- An allocation bit

The allocation bit is used to control the access to the response register. Use this register to set the size and allocation bit and then poll the register until the allocation bit is cleared. When the allocation bit is cleared, it is safe to read from the RX RISC MBUF Cluster Allocation Response register.

| Name           | Bits | Access | Default<br>Value | Description                                                                                         |
|----------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------|
| Allocation Bit | 31   | RW     | 0                | Set this bit to 1 to request for the MBUF.                                                          |
|                |      |        |                  | When this bit is read as 0, then read the MBUF allocation Response register for the TXMBUF pointer. |
| Reserved       | 30:0 | RO     | 0                | _                                                                                                   |

### 13.22.9 RX RISC MBUF Allocation Response Register (offset: 0x4420)

This register returns the MBUF cluster pointer of the specified size when the Allocation bit is cleared. If a second MBUF cluster allocation request is made before this register is read, an MBUF memory leak may occur.

This register is hardwired to 61, or 0x0000003D. The TXMBUF that is dedicated for ASF is the uppermost 384 bytes. The CPU should use 0x00009E80 as the starting address for ASF.

#### 13.22.10 BM Hardware Diagnostic 1 Register (offset: 0x444C)

This 32-bit register provides debug information on the TXMBUF pointer.

| Name                                  | Bits  | Access | Default<br>Value | Description                                                                   |
|---------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------|
| Reserved                              | 31:26 | RO     | 0                | -                                                                             |
| Last TXMBUF Deallocation Head Pointer | 25:20 | RO     | 0                | Captures the last deallocation head pointer of the TXMBUF.                    |
| Reserved                              | 19:16 | RO     | 0                | -                                                                             |
| Last TXMBUF Deallocation Tail Pointer | 15:10 | RO     | 0                | Captures the last deallocation tail pointer of the TXMBUF.                    |
| Reserved                              | 9:6   | RO     | 0                | -                                                                             |
| Next TXMBUF Allocation Pointer        | 5:0   | RO     | 0                | The value of the next TXMBUF allocation pointer (should be between 0 and 60). |

#### 13.22.11 BM Hardware Diagnostic 2 Register (offset: 0x4450)

This 32-bit register provides debug information on the TXMBUF and RXMBUF counts.

| Name         | Bits  | Access | Default<br>Value | Description                                |
|--------------|-------|--------|------------------|--------------------------------------------|
| Reserved     | 31:26 | RO     | 0                | _                                          |
| RXMBUF Count | 25:17 | RO     | 1                | The number of RXMBUFs that were allocated. |
| TXMBUF Count | 16:9  | RO     | 1                | The number of TXMBUFs that were allocated. |
| RXMBUF Left  | 8:0   | RO     | 0x13f            | The number of free RXMBUFs.                |

#### 13.22.12 BM Hardware Diagnostic 3 Register (offset: 0x4454)

This 32-bit register provides debug information on the RXMBUF pointer.

| Name                             | Bits  | Access | Default<br>Value | Description                                |
|----------------------------------|-------|--------|------------------|--------------------------------------------|
| Reserved                         | 31:25 | RO     | 0                | -                                          |
| Next RXMBUF Deallocation pointer | 24:16 | RO     | 0                | The next RXMBUF that is to be deallocated. |
| Reserved                         | 15:9  | RO     | 0                | -                                          |
| Next RXMBUF Allocation pointer   | 14:9  | RO     | 0                | The next RXMBUF that is to be allocated.   |

### 13.22.13 Receive Flow Threshold Register (offset: 0x4458)

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 31:9 | RO     | 0                | -           |

| Name           | Bits | Access | Default<br>Value | Description                                                                                     |
|----------------|------|--------|------------------|-------------------------------------------------------------------------------------------------|
| MBUF Threshold | 8:0  | RW     |                  | Defines the integer number of MBUFs remaining before the receive MAC will drop received frames. |

# 13.23 RDMA Registers

All registers reset are core reset unless specified.

# 13.23.1 LSO Read DMA Mode Register (offset: 0x4800)

| Name                                                                      | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                                  | 31:30 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| In-Band VLAN Tag Enable                                                   | 29    | RW     | 1                | In Band VLAN Tag Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                           |       |        |                  | 1: Enable In_Band VLAN Tag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                           |       |        |                  | 0: Disable In-Band VLAN Tag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Hardware IPv6 Post-DMA<br>Processing Enable                               | 28    | RW     | 0                | Enables hardware processing of LSO IPv6 packets. This bit has no effect on Post-DMA processing of IPv4 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Hardware IPv4 Post-DMA<br>Processing Enable                               | 27    | RW     | 0                | Enables hardware processing of LSO IPv4 packets. This bit has no effect on Post-DMA processing of IPv6 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Post-DMA Debug Enable                                                     | 26    | RW     | 0                | When this bit is set, the Send Data Completion State Machine will be halted if the Post-DMA bit of the Send BD is set.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Address Overflow Error Logging Enable                                     | 25    | RW     | 0                | This bit when set, enables the address overflow error to be generated when the DMA Read Engine performs a DMA operation that crosses a 4G boundary. This error is reported in bit 3 of the DMA Read Status Register. Subsequently, this will generate an internal event to interrupt the internal CPU and the DMA Read Engine will lock up after detecting this error. So it is recommended that this bit should not be set by firmware or software.  1: Enable Address Overflow Error Logging  0: Disable Address Overflow Error Logging. |
| Disable Multiple Outstanding                                              | 24    | WO     | 0                | 0: Enable Multiple Outstanding Read DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Read DMA                                                                  |       |        |                  | 1: Disable Multiple Outstanding Read DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                           |       |        |                  | This bit will always read back as 0, even if written as 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                           |       |        |                  | This feature should be disabled in 5718 A0 Chip                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Reserved                                                                  | 23:18 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PCI Request Burst Length for LSO engine                                   | 17:16 | RW     | 0                | The two bits define the burst length that the RDMA read engine would request to the PCI block.  00 = 128B  01 = 256B  10 = 512B  11 = 4KB  The actual size of the resulting PCIe memory read transaction may be further limited by the PCIe Maximum Read Request Size (MRRS) field of the PCIe Device Status Control Register (0xB4).                                                                                                                                                                                                      |
| Reserved                                                                  | 15:11 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI-X Split Transaction Timeout Expired Attention Enable         | 10    | RW     | 0                | Enable read DMA PCI-X split transaction timeout expired attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Read DMA Local Memory Write<br>Longer Than DMA Length<br>Attention Enable | 9     | RW     | 0                | Enable Read DMA Local Memory Write Longer Than DMA Length Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Read DMA PCI FIFO Overread<br>Attention Enable                            | 8     | RW     | 0                | Enable Read DMA PCI FIFO Overread Attention (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Name                                                         | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                |
|--------------------------------------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read DMA PCI FIFO Underrun<br>Attention Enable               | 7    | RW     | 0                | Enable Read DMA PCI FIFO Underrun Attention.                                                                                                                                                               |
| Read DMA PCI FIFO Overrun<br>Attention Enable                | 6    | RW     | 0                | Enable Read DMA PCI FIFO Overrun Attention.                                                                                                                                                                |
| Read DMA PCI Host Address<br>Overflow Error Attention Enable | 5    | RW     | 0                | Enable Read DMA PCI Host Address Overflow Error Attention. A host address overflow occurs when a single DMA read begins at an address below 4 GB and ends on an address above 4 GB. This is a fatal error. |
| Read DMA PCI Parity Error<br>Attention Enable                | 4    | RW     | 0                | Enable Read DMA PCI Parity Error Attention.                                                                                                                                                                |
| Read DMA PCI Master Abort<br>Attention Enable                | 3    | RW     | 0                | Enable Read DMA PCI Master Abort Attention.                                                                                                                                                                |
| Read DMA PCI Target Abort<br>Attention Enable                | 2    | RW     | 0                | Enable Read DMA PCI Target Abort Attention.                                                                                                                                                                |
| Enable                                                       | 1    | RW     | 1                | This bit controls whether the Read DMA state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read.       |
| Reset                                                        | 0    | RW     | 0                | When this bit is set to 1, the Read DMA state machine is reset. This is a self-clearing bit.                                                                                                               |

# 13.23.2 LSO Read DMA Status Register (offset: 0x4804)

| Name                                                        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                    | 31:11 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI-X Split Transaction Timeout Expired            | 10    | W2C    | 0                | Read DMA PCI-X split transaction timeout expired.                                                                                                                                                                                                                                                                                          |
| Read DMA Local Memory Write<br>Longer Than DMA Length Error | 9     | W2C    | 0                | Read DMA Local Memory Write Longer Than DMA Length Error.                                                                                                                                                                                                                                                                                  |
| Read DMA PCI FIFO Overread Error                            | 8     | W2C    | 0                | Read DMA PCI FIFO Overread Error (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                        |
| Read DMA PCI FIFO Underrun<br>Error                         | 7     | W2C    | 0                | Read DMA PCI FIFO Underrun Error.                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI FIFO Overrun<br>Error                          | 6     | W2C    | 0                | Read DMA PCI FIFO Overrun Error.                                                                                                                                                                                                                                                                                                           |
| Read DMA PCI Host Address<br>Overflow Error                 | 5     | W2C    | 0                | Read DMA PCI Host Address Overflow Error. A host address overflow occurs when a single DMA read begins at an address below a multiple of 4 GB and ends at an address above the same multiple of 4 GB (i.e., the host memory address transitions from 0xXXXXXXXX_FFFFFFFF to 0xYYYYYYYY_000000000 in a single read). This is a fatal error. |
| Read DMA PCI Parity Error                                   | 4     | W2C    | 0                | Read DMA PCI Parity Error.                                                                                                                                                                                                                                                                                                                 |
| Read DMA PCI Master Abort                                   | 3     | W2C    | 0                | Read DMA PCI Master Abort Error.                                                                                                                                                                                                                                                                                                           |
| Read DMA PCI Target Abort                                   | 2     | W2C    | 0                | Read DMA PCI Target Abort Error.                                                                                                                                                                                                                                                                                                           |
| Reserved                                                    | 1:0   | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                          |

# 13.23.3 LSO Read DMA Programmable IPv6 Extension Header Register (offset: 0x4808)

| Name                                            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                  |
|-------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Programmable Extension Header<br>Type #2 Enable | 31    | RW     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [15:8] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [15:8]. |
| Programmable Extension Header<br>Type #1 Enable | 30    | RW     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [7:0] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [7:0].   |
| Reserved                                        | 29:16 | RO     | 0                | -                                                                                                                                                                                                                                                            |
| Programmable Extension Header Type #2           | 15:8  | RW     | 0                | These bits contain the programmable extension header value for programmable header #2.                                                                                                                                                                       |
| Programmable Extension Header Type #1           | 7:0   | RW     | 0                | These bits contain the programmable extension header value for programmable header #1.                                                                                                                                                                       |

# 13.23.4 LSO Read DMA Reserved Control Register (offset: 0x4900)

| Name                                                                                                         | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIX for controller stop passing traffic                                                                      | 31:21 | RW     | 0                | Fix the controller stop passing traffic when flow control is enabled. It appears that the chip can get stuck in a permanent XOFF state under heavy bi-directional netperf traffic when flow control is enabled. |
| Fix in A1 for Rx discard counter update in offset x2250 when multicast/unicast/broadcast packets are dropped | 20    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                    |
| FIFO High Mark                                                                                               | 19:12 | RW     | 0x90             | -                                                                                                                                                                                                               |
| FIFO Low Mark                                                                                                | 11:4  | RW     | 0x40             | _                                                                                                                                                                                                               |
| Slow Clock Fix Disable                                                                                       | 3     | RW     | 0                | When cleared, it enables the fix to cover a corner case in the link idle mode to allow the DMA Read request to be generated when the core clock is transitioning from slow to fast Enable hardware fix 25155.   |
| Fix for the DMA FIFO overrun                                                                                 | 2     | RW     | 0                | When set, this bit enables the fix, where a DMA FIFO overrun occurs if a large number of Rx BDs are fetched while the Tx MBUF is full and the Read DMA FIFO is empty.                                           |
| Late Collision Fix Enable                                                                                    | 1     | RW     | 0                | 0: Disable Fix                                                                                                                                                                                                  |
|                                                                                                              |       |        |                  | 1: Enable Fix                                                                                                                                                                                                   |
| Select FED Enable                                                                                            | 0     | RW     | 0                | Ensure only 1 request is generated upon any condition where the core clock is switching from slow to fast or vice-versa.                                                                                        |

## 13.23.5 LSO Read DMA Flow Reserved Control Register (offset: 0x4904)

| Name                          | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                           |
|-------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fix for frequent TX time out. | 31:24 | RW     | 0                | This register contains various controls to configure hardware fix for<br>the chip getting stuck in a permanent XOFF state under heavy<br>bi-directional netperf traffic when flow control is enabled. |
| Fifo_threshold_mbuf_req       | 23:16 | RW     | 0x30             | -                                                                                                                                                                                                     |
| MBUF Threshold MBUF Request   | 15:8  | RW     | 0x54             | -                                                                                                                                                                                                     |
| Reserved                      | 7     | RW     | 0                | -                                                                                                                                                                                                     |
| Clock Request Fix Enable      | 6     | RW     | 0                | -                                                                                                                                                                                                     |
| MBUF Threshold Clk Req        | 5:0   | RW     | 0x7              | -                                                                                                                                                                                                     |

# 13.23.6 LSO/Non-LSO/BD Read DMA Corruption Enable Control Register (offset: 0x4910)

| Name                                                                                                                 | Bits  | Access | Default<br>Value | Description                     |
|----------------------------------------------------------------------------------------------------------------------|-------|--------|------------------|---------------------------------|
| DTM stress failure 8bytes<br>duplication fix disable in<br>Non-LSO engine                                            | 31    | RW     | 0                | 0: Enable fix 1: Disable fix    |
| Reserved                                                                                                             | 30:28 | RW     | 0                | -                               |
| Disable fix in A1 for B2B Pcie completion good pkt followed by bad pkt (that is, packet with LCRC error)             | 27    | RW     | 0                | 0: Enable fix<br>1: Disable fix |
| Disable fix in A1 for B2B Pcie completion good pkt followed by good pkt                                              | 26    | RW     | 0                | 0: Enable fix<br>1: Disable fix |
| Disable fix in A1 for DMA Read engine miscalculation of TXMBUF Available Space                                       | 25    | RW     | 0                | 0: Enable fix<br>1: Disable fix |
| Disable fix in A1 for DMA Read<br>Underrun when running Core Clk<br>same speed as TL Clock when<br>CLKREQ is enabled | 24    | RW     | 0                | 0: Enable fix<br>1: Disable fix |
| Disable fix in A1 for RDMA FIFO Overrun                                                                              | 23    | RW     | 0                | 0: Enable fix 1: Disable fix    |
| DTM stress failure DMA too large<br>error fix disable for Non-LSO<br>engine                                          | 22    | RW     | 0                | 0: Enable fix 1: Disable fix    |
| DTM stress test 8bytes missing failure fix disable for Non-LSO engine                                                | 21    | RW     | 0                | 0: Enable fix<br>1: Disable fix |
| DTM stress failure corruption fix disable for Non-LSO engine                                                         | 20    | RW     | 0                | 0: Enable fix<br>1: Disable fix |

| Name                                                             | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                   |
|------------------------------------------------------------------|-------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI Request Burst Length for Non-LSO RDMA engine                 | 19:18 | RW     | 0                | The two bits define the burst length that the Non-LSO RDMA read engine would request to the PCI block.  00 = 128B  01 = 256B  10 = 512B  11 = 4KB                                                                                             |
| PCI Request Burst Length for BD<br>RDMA engine                   | 17:16 | RW     | 0                | The two bits define the burst length that the BD RDMA read engine would request to the PCI block.  00 = 128B  01 = 256B  10 = 512B  11 = 4KB                                                                                                  |
| cq46758_fix_enable                                               | 15    | RW     | 0                | 0 0: Enable fix 1: Disable fix                                                                                                                                                                                                                |
| sbd_8b_less_fix_enable3                                          | 14    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| sbd_8b_less_fix_enable2                                          | 13    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| mem_too_large_fix_enable2                                        | 12    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| mem_too_large_fix_enable1                                        | 11    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| mem_too_large_fix_enable                                         | 10    | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| sbd_8b_less_fix_enable_fast_ret<br>urn                           | 9     | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| sbd_8b_less_fix_enable                                           | 8     | RW     | 0                | 0: Enable fix 1: Disable fix                                                                                                                                                                                                                  |
| Enable hardware fix for the wrong TCP checksum when LSO send out | 7     | RW     | 0                | The fix involves wiping out the tcp_checksum calculation.  0: Enable Fix  1: Disable Fix                                                                                                                                                      |
| Reserved                                                         | 6     | RW     | 0                | -                                                                                                                                                                                                                                             |
| Fix for IP header checksum error in high transfer rate           | 5     | RW     | 0                | This control bit is used to enable the fix for the IP Header Checksum Corruption occurs when an IPV4 payload contents match an IPV6 Header Type.  1: Disable fix 0: enable fix                                                                |
| Enable hardware fix for TX Read<br>DMA lock-up LOCKUP            | 4     | RW     | 1                | Set to 1 to enable fix for clock request gap problem of Tx Read DMA lock-up issue.  Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Enable hardware fix                                              | 3     | RW     | 1                | Set to 1 to enable fix for clock switching problem of Tx Read DMA lock-up issue.  Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28.   |

| Name                | Bits | Access | Default<br>Value | Description                                                                                                                                               |
|---------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable hardware fix | 2    | RW     | 1                | Set to 1 to enable fix for Tx Read DMA lock-up issue.                                                                                                     |
|                     |      |        |                  | Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Reserved            | 1    | RW     | 0                | -                                                                                                                                                         |
| Reserved            | 0    | RW     | 0                | -                                                                                                                                                         |

# 13.23.7 BD Read DMA Mode Register (offset: 0x4A00)

| Name                                                                      | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                                  | 31:29 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Hardware IPv6 Post-DMA<br>Processing Enable                               | 28    | RO     | 0                | Enables hardware processing of LSO IPv6 packets. This bit has no effect on Post-DMA processing of IPv4 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Hardware IPv4 Post-DMA<br>Processing Enable                               | 27    | RO     | 0                | Enables hardware processing of LSO IPv4 packets. This bit has no effect on Post-DMA processing of IPv6 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Post-DMA Debug Enable                                                     | 26    | RO     | 0                | When this bit is set, the Send Data Completion State Machine will be halted if the Post-DMA bit of the Send BD is set.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Address Overflow Error Logging Enable                                     | 25    | RO     | 0                | This bit when set, enables the address overflow error to be generated when the DMA Read Engine performs a DMA operation that crosses a 4G boundary. This error is reported in bit 3 of the DMA Read Status Register. Subsequently, this will generate an internal event to interrupt the internal CPU and the DMA Read Engine will lock up after detecting this error. So it is recommended that this bit should not be set by firmware or software.  1: Enable Address Overflow Error Logging  0: Disable Address Overflow Error Logging. |
| Reserved                                                                  | 24:18 | RO     | 0                | _<br>_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCI Request Burst Length                                                  | 17:16 | RO     | 0                | 00 = 128 bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| . Grand queen Danet Denigan                                               |       |        |                  | 01 = 256 bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                           |       |        |                  | 10 = 512 bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                           |       |        |                  | 11 = 4096 bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                           |       |        |                  | The actual size of the resulting PCIe memory read transaction may be further limited by the PCIe Maximum Read Request Size (MRRS) field of the PCIe Device Status Control Register (0xB4).                                                                                                                                                                                                                                                                                                                                                 |
| Reserved                                                                  | 15:11 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI-X Split<br>Transaction Timeout Expired<br>Attention Enable   | 10    | RO     | 0                | Enable read DMA PCI-X split transaction timeout expired attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Read DMA Local Memory Write<br>Longer Than DMA Length<br>Attention Enable | 9     | RO     | 0                | Enable Read DMA Local Memory Write Longer Than DMA Length Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Read DMA PCI FIFO Overread<br>Attention Enable                            | 8     | RO     | 0                | Enable Read DMA PCI FIFO Overread Attention (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Read DMA PCI FIFO Underrun<br>Attention Enable                            | 7     | RO     | 0                | Enable Read DMA PCI FIFO Underrun Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Read DMA PCI FIFO Overrun<br>Attention Enable                             | 6     | RO     | 0                | Enable Read DMA PCI FIFO Overrun Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Read DMA PCI Host Address<br>Overflow Error Attention Enable              | 5     | RO     | 0                | Enable Read DMA PCI Host Address Overflow Error Attention. A host address overflow occurs when a single DMA read begins at an address below 4 GB and ends on an address above 4 GB. This is a fatal error.                                                                                                                                                                                                                                                                                                                                 |
| Read DMA PCI Parity Error<br>Attention Enable                             | 4     | RO     | 0                | Enable Read DMA PCI Parity Error Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Read DMA PCI Master Abort<br>Attention Enable                             | 3     | RO     | 0                | Enable Read DMA PCI Master Abort Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Read DMA PCI Target Abort<br>Attention Enable                             | 2     | RO     | 0                | Enable Read DMA PCI Target Abort Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Name   | Bits | Access | Default<br>Value | Description                                                                                                                                                                                          |
|--------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable | 1    | RO     | 1                | This bit controls whether the Read DMA state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset  | 0    | RO     | 0                | When this bit is set to 1, the Read DMA state machine is reset. This is a self-clearing bit.                                                                                                         |

# 13.23.8 BD READ DMA Status Register (offset: 0x4A04)

| Name                                                     | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rdmad_length_b_0                                         | 31:16 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                         |
| Reserved                                                 | 15:11 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                         |
| Read DMA PCI-X Split Transaction Timeout Expired         | 10    | W2C    | 0                | Read DMA PCI-X split transaction timeout expired.                                                                                                                                                                                                                                                                                         |
| Read DMA Local Memory Write Longer Than DMA Length Error | 9     | W2C    | 0                | Read DMA Local Memory Write Longer Than DMA Length Error.                                                                                                                                                                                                                                                                                 |
| Read DMA PCI FIFO Overread Error                         | 8     | W2C    | 0                | Read DMA PCI FIFO Overread Error (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                       |
| Read DMA PCI FIFO Underrun<br>Error                      | 7     | W2C    | 0                | Read DMA PCI FIFO Underrun Error.                                                                                                                                                                                                                                                                                                         |
| Read DMA PCI FIFO Overrun Error                          | 6     | W2C    | 0                | Read DMA PCI FIFO Overrun Error.                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI Host Address<br>Overflow Error              | 5     | W2C    | 0                | Read DMA PCI Host Address Overflow Error. A host address overflow occurs when a single DMA read begins at an address below a multiple of 4 GB and ends at an address above the same multiple of 4 GB (i.e., the host memory address transitions from 0xXXXXXXX_FFFFFFFF to 0xYYYYYYYY_000000000 in a single read). This is a fatal error. |
| Read DMA PCI Parity Error                                | 4     | W2C    | 0                | Read DMA PCI Parity Error.                                                                                                                                                                                                                                                                                                                |
| Read DMA PCI Master Abort                                | 3     | W2C    | 0                | Read DMA PCI Master Abort Error.                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI Target Abort                                | 2     | W2C    | 0                | Read DMA PCI Target Abort Error.                                                                                                                                                                                                                                                                                                          |
| Reserved                                                 | 1:0   | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                         |

# 13.23.9 BD READ DMA Reserved Control Register (offset: 0x4A70)

| Name                   | Bits  | Access | Default<br>Value | Description                                                                                                                                                                         |
|------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Txmbuf_margin          | 31:21 | RO     | 0                | -                                                                                                                                                                                   |
| Reserved               | 20    | RO     | 0                | -                                                                                                                                                                                   |
| FIFO High Mark         | 19:12 | RO     | 0x90             | -                                                                                                                                                                                   |
| FIFO Low Mark          | 11:4  | RO     | 0x40             | -                                                                                                                                                                                   |
| Slow Clock Fix Disable | 3     | RO     | 0                | When cleared, it enables the fix to cover a corner case in the link idle mode to allow the DMA Read request to be generated when the core clock is transitioning from slow to fast. |

| Name                                      | Bits | Access | Default<br>Value | Description                                                                                                                                                      |
|-------------------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop communicating after heavy stress Fix | 2    | RO     | 0                | When set, this bit enables the fix for DMA FIFO overrun occurs if a large number of Rx BDs are fetched while the Tx MBUF is full and the Read DMA FIFO is empty. |
| Late Collision Fix Enable                 | 1    | RO     | 0                | 0: Disable Fix 1: Enable Fix                                                                                                                                     |
| Select FED Enable                         | 0    | RO     | 0                | Ensure only 1 request is generated upon any condition where the core clock is switching from slow to fast or vice-versa.                                         |

# 13.23.10 BD READ DMA Flow Reserved Control Register (offset: 0x4A74)

| Name                        | Bits  | Access | Default<br>Value | Description |
|-----------------------------|-------|--------|------------------|-------------|
| Fifo_threshold_bd_req       | 31:24 | RO     | 0                | -           |
| Fifo_threshold_mbuf_req     | 23:16 | RO     | 0x30             | -           |
| MBUF Threshold MBUF Request | 15:8  | RO     | 0x54             | -           |
| Reserved                    | 7     | RO     | 0                | -           |
| Clock Request Fix Enable    | 6     | RO     | 0                | _           |
| MBUF Threshold Clk Req      | 5:0   | RO     | 0x7              | -           |

# 13.23.11 BD READ DMA Corruption Enable Control Register (offset: 0x4A78)

| Name                                                                                                                                       | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                                                                                                   | 31:8 | RO     | 0                | -                                                                                                                                                                                                                                             |
| Enable hardware fix for wrong                                                                                                              | 7    | RO     | 0                | 0: Enable Fix                                                                                                                                                                                                                                 |
| TCP checksum                                                                                                                               |      |        |                  | 1: Disable Fix                                                                                                                                                                                                                                |
| Reserved                                                                                                                                   | 6    | RO     | 0                | -                                                                                                                                                                                                                                             |
| Enable hardware fix for IP Header checksum corruption                                                                                      | 5    | RO     | 0                | This control bit is used to enable the fix for the IP Header Checksum Corruption occurs when an IPV4 payload contents match an IPV6 Header Type.  1: Disable fix 0: enable fix                                                                |
| DMA Read Engine may be unable<br>to generate Memory Read<br>Request to PCIE Core upon<br>transitioning from L1 to L0 with<br>Clkreq Enable | 4    | RO     | 1                | Set to 1 to enable fix for clock request gap problem of Tx Read DMA lock-up issue.  Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Enable hardware fix for clock switching problem                                                                                            | 3    | RO     | 1                | Set to 1 to enable fix for clock switching problem of Tx Read DMA lock-up issue.  Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28.   |
| Enable hardware fix for PCIE client lockup                                                                                                 | 2    | RO     | 1                | Set to 1 to enable fix for Tx Read DMA lock-up issue.  Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28.                              |

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 1    | RO     | 0                | _           |
| Reserved | 0    | RO     | 0                | _           |

# 13.23.12 Non\_LSO Read DMA Mode Register (offset: 0x4B00)

| Name                                                                      | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                                  | 31:29 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Hardware IPv6 Post-DMA<br>Processing Enable                               | 28    | RO     | 0                | Enables hardware processing of LSO IPv6 packets. This bit has no effect on Post-DMA processing of IPv4 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Hardware IPv4 Post-DMA<br>Processing Enable                               | 27    | RO     | 0                | Enables hardware processing of LSO IPv4 packets. This bit has no effect on Post-DMA processing of IPv6 packets.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Post-DMA Debug Enable                                                     | 26    | RO     | 0                | When this bit is set, the Send Data Completion State Machine will be halted if the Post-DMA bit of the Send BD is set                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Address Overflow Error Logging Enable                                     | 25    | RO     | 0                | This bit when set, enables the address overflow error to be generated when the DMA Read Engine performs a DMA operation that crosses a 4G boundary. This error is reported in bit 3 of the DMA Read Status Register. Subsequently, this will generate an internal event to interrupt the internal CPU and the DMA Read Engine will lock up after detecting this error. So it is recommended that this bit should not be set by firmware or software.  1: Enable Address Overflow Error Logging  0: Disable Address Overflow Error Logging. |
| Reserved                                                                  | 24:18 | RO     | 0                | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PCI Request Burst Length                                                  | 17:16 | RO     | 0                | 00 = 128 bytes 01 = 256 bytes 10 = 512 bytes 11 = 4096 bytes The actual size of the resulting PCIe memory read transaction may be further limited by the PCIe Maximum Read Request Size (MRRS) field of the PCIe Device Status Control Register (0xB4).                                                                                                                                                                                                                                                                                    |
| Reserved                                                                  | 15:11 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI-X Split<br>Transaction Timeout Expired<br>Attention Enable   | 10    | RO     | 0                | Enable read DMA PCI-X split transaction timeout expired attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Read DMA Local Memory Write<br>Longer Than DMA Length<br>Attention Enable | 9     | RO     | 0                | Enable Read DMA Local Memory Write Longer Than DMA Length Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Read DMA PCI FIFO Overread<br>Attention Enable                            | 8     | RO     | 0                | Enable Read DMA PCI FIFO Overread Attention (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Read DMA PCI FIFO Underrun<br>Attention Enable                            | 7     | RO     | 0                | Enable Read DMA PCI FIFO Underrun Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Read DMA PCI FIFO Overrun<br>Attention Enable                             | 6     | RO     | 0                | Enable Read DMA PCI FIFO Overrun Attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Read DMA PCI Host Address<br>Overflow Error Attention Enable              | 5     | RO     | 0                | Enable Read DMA PCI Host Address Overflow Error Attention. A host address overflow occurs when a single DMA read begins at an address below 4 GB and ends on an address above 4 GB. This is a fatal error.                                                                                                                                                                                                                                                                                                                                 |

| Name                                          | Bits | Access | Default<br>Value | Description                                                                                                                                                                                          |
|-----------------------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read DMA PCI Parity Error<br>Attention Enable | 4    | RO     | 0                | Enable Read DMA PCI Parity Error Attention.                                                                                                                                                          |
| Read DMA PCI Master Abort<br>Attention Enable | 3    | RO     | 0                | Enable Read DMA PCI Master Abort Attention.                                                                                                                                                          |
| Read DMA PCI Target Abort<br>Attention Enable | 2    | RO     | 0                | Enable Read DMA PCI Target Abort Attention.                                                                                                                                                          |
| Enable                                        | 1    | RO     | 1                | This bit controls whether the Read DMA state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read. |
| Reset                                         | 0    | RO     | 0                | When this bit is set to 1, the Read DMA state machine is reset. This is a self-clearing bit.                                                                                                         |

# 13.23.13 Non-LSO Read DMA Status Register (offset: 0x4B04)

| Name                                                        | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rdmad_length_d_0                                            | 31:16 | RO     | 0                | -                                                                                                                                                                                                                                                                                                                                          |
| Reserved                                                    | 15:11 | RO     | 0                | _                                                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI-X Split<br>Transaction Timeout Expired         | 10    | W2C    | 0                | Read DMA PCI-X split transaction timeout expired.                                                                                                                                                                                                                                                                                          |
| Read DMA Local Memory Write<br>Longer Than DMA Length Error | 9     | W2C    | 0                | Read DMA Local Memory Write Longer Than DMA Length Error.                                                                                                                                                                                                                                                                                  |
| Read DMA PCI FIFO Overread Error                            | 8     | W2C    | 0                | Read DMA PCI FIFO Overread Error (PCI read longer than DMA length.)                                                                                                                                                                                                                                                                        |
| Read DMA PCI FIFO Underrun<br>Error                         | 7     | W2C    | 0                | Read DMA PCI FIFO Underrun Error.                                                                                                                                                                                                                                                                                                          |
| Read DMA PCI FIFO Overrun<br>Error                          | 6     | W2C    | 0                | Read DMA PCI FIFO Overrun Error.                                                                                                                                                                                                                                                                                                           |
| Read DMA PCI Host Address<br>Overflow Error                 | 5     | W2C    | 0                | Read DMA PCI Host Address Overflow Error. A host address overflow occurs when a single DMA read begins at an address below a multiple of 4 GB and ends at an address above the same multiple of 4 GB (i.e., the host memory address transitions from 0xXXXXXXXX_FFFFFFFFF to 0xYYYYYYYY_00000000 in a single read). This is a fatal error. |
| Read DMA PCI Parity Error                                   | 4     | W2C    | 0                | Read DMA PCI Parity Error.                                                                                                                                                                                                                                                                                                                 |
| Read DMA PCI Master Abort                                   | 3     | W2C    | 0                | Read DMA PCI Master Abort Error.                                                                                                                                                                                                                                                                                                           |
| Read DMA PCI Target Abort                                   | 2     | W2C    | 0                | Read DMA PCI Target Abort Error.                                                                                                                                                                                                                                                                                                           |
| Reserved                                                    | 1:0   | RO     | 3                | _                                                                                                                                                                                                                                                                                                                                          |

# 13.23.14 Non-LSO Read DMA Programmable IPv6 Extension Header Register (offset: 0x4B08)

| Name                                            | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                  |
|-------------------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Programmable Extension Header<br>Type #2 Enable | 31    | RO     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [15:8] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [15:8]. |
| Programmable Extension Header<br>Type #1 Enable | 30    | RO     | 0                | This bit enables programmable extension header #1. If this bit is clear, then the value programmed in bits [7:0] of this register will be ignored. If this bit is set, then extension headers will be checked for a type matching the value in bits [7:0].   |
| Reserved                                        | 29:28 | RO     | 0                | -                                                                                                                                                                                                                                                            |
| ch0_rlctr                                       | 27:19 | RO     | 0                | -                                                                                                                                                                                                                                                            |
| Reserved                                        | 18:16 | RO     | 0                | -                                                                                                                                                                                                                                                            |
| Programmable Extension Header Type #2           | 15:8  | RO     | 0                | These bits contain the programmable extension header value for programmable header #2.                                                                                                                                                                       |
| Programmable Extension Header Type #1           | 7:0   | RO     | 0                | These bits contain the programmable extension header value for programmable header #1.                                                                                                                                                                       |

#### 13.23.15 Host Address for the DMA Read Channel 0 (Offset: 0x4B28)

| Name      | Bits |    | Default<br>Value | Description          |
|-----------|------|----|------------------|----------------------|
| Host Addr | 31:0 | RO | 0                | Latched host address |

#### 13.23.16 Host Address for the DMA Read Channel 1 (offset: 0x4B30)

| Name      | Bits |    | Default<br>Value | Description          |
|-----------|------|----|------------------|----------------------|
| Host Addr | 31:0 | RO | 0                | Latched host address |

#### 13.23.17 Host Address for the DMA Read Channel 2 (offset: 0x4B38)

| Name      | Bits |    | Default<br>Value | Description          |
|-----------|------|----|------------------|----------------------|
| Host Addr | 31:0 | RO | 0                | Latched host address |

### 13.23.18 Host Address for the DMA Read Channel 3 (offset: 0x4B40)

| Name      | Bits | Access | Default<br>Value | Description          |
|-----------|------|--------|------------------|----------------------|
| Host Addr | 31:0 | RO     | 0                | Latched host address |

## 13.23.19 Non-LSO Read DMA Reserved Control Register (offset: 0x4B74)

| Name                                     | Bits  | Access | Default<br>Value | Description                                                                                                                                                                         |
|------------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Txmbuf_margin                            | 31:21 | RO     | 0                | -                                                                                                                                                                                   |
| Reserved                                 | 20    | RO     | 0                | -                                                                                                                                                                                   |
| FIFO High Mark                           | 19:12 | RO     | 0x90             | -                                                                                                                                                                                   |
| FIFO Low Mark                            | 11:4  | RO     | 0x40             | -                                                                                                                                                                                   |
| Slow Clock Fix Disable                   | 3     | RO     | 0                | When cleared, it enables the fix to cover a corner case in the link idle mode to allow the DMA Read request to be generated when the core clock is transitioning from slow to fast. |
| Hardware fix enable for DMA FIFO Overrun | 2     | RO     | 0                | When set, this bit enables the fix for DMA FIFO overrun occurs if a large number of Rx BDs are fetched while the Tx MBUF is full and the Read DMA FIFO is empty.                    |
| Late Collision Fix Enable                | 1     | RO     | 0                | 0: Disable Fix<br>1: Enable Fix                                                                                                                                                     |
| Select FED Enable                        | 0     | RO     | 0                | Ensure only 1 request is generated upon any condition where the core clock is switching from slow to fast or vice-versa.                                                            |

## 13.23.20 Non-LSO Read DMA Flow Reserved Control Register (offset: 0x4B78)

| Name                          | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                     |
|-------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fix for frequent TX time out. | 31:24 | RW     | 0                | This register contains various controls to configure hardware fix for the chip getting stuck in a permanent XOFF state under heavy bi-directional netperf traffic when flow control is enabled. |
| Fifo_threshold_mbuf_req       | 23:16 | RO     | 0x30             | _                                                                                                                                                                                               |
| MBUF Threshold MBUF Request   | 15:8  | RO     | 0x54             | -                                                                                                                                                                                               |
| Reserved                      | 7     | RO     | 0                | -                                                                                                                                                                                               |
| Clock Request Fix Enable      | 6     | RO     | 0                | _                                                                                                                                                                                               |
| MBUF Threshold Clk Req        | 5:0   | RO     | 0x7              | _                                                                                                                                                                                               |

# 13.23.21 Non-LSO Read DMA Corruption Enable Control Register (offset: 0x4B7C)

| Name                                                  | Bits | Access | Default<br>Value | Description                                                                                                                                                      |
|-------------------------------------------------------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                              | 31:8 | RO     | 0                | _                                                                                                                                                                |
| Enable hardware fix for wrong                         | 7    | RO     | 0                | 0: Enable Fix                                                                                                                                                    |
| TCP checksum                                          |      |        |                  | 1: Disable Fix                                                                                                                                                   |
| Reserved                                              | 6    | RO     | 0                | -                                                                                                                                                                |
| Enable hardware fix for IP Header checksum corruption | 5    | RO     | 0                | This control bit is used to enable the fix for the IP Header Checksum Corruption occurs when an IPV4 payload contents match an IPV6 Header Type.  1: Disable fix |
|                                                       |      |        |                  | 0: enable fix                                                                                                                                                    |

| Name                                                                     | Bits | Access | Default<br>Value | Description                                                                                                                                               |
|--------------------------------------------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA Read Engine may be unable to generate Memory Read                    | 4    | RO     | 1                | Set to 1 to enable fix for clock request gap problem of Tx Read DMA lock-up issue.                                                                        |
| Request to PCIE Core upon transitioning from L1 to L0 with Clkreq Enable |      |        |                  | Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Enable hardware fix for clock switching problem                          | 3 RO | RO     | 1                | Set to 1 to enable fix for clock switching problem of Tx Read DMA lock-up issue.                                                                          |
|                                                                          |      |        |                  | Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Enable hardware fix for PCIE                                             | 2    | RO     | 1                | Set to 1 to enable fix for Tx Read DMA lock-up issue.                                                                                                     |
| client lockup                                                            |      |        |                  | Note that increasing the ASPM L1 entry time to a value on the order of 1ms is recommended and may prevent this issue from occurring. See register 0x7d28. |
| Reserved                                                                 | 1    | RO     | 0                | -                                                                                                                                                         |
| Reserved                                                                 | 0    | RO     | 0                | -                                                                                                                                                         |

# 13.24 Write DMA Registers

All registers reset are core reset unless specified.

## 13.24.1 Write DMA Mode Register (offset: 0x4C00)

| Name                                                          | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                                                      | 31:30 | RO     | 0                | _                                                                                                                                                                                                                                                                          |
| Enable FIX for host coalescing                                | 29    | RW     | 0                | 1: Enable the FIX                                                                                                                                                                                                                                                          |
| bug                                                           |       |        |                  | 0: Disable the FIX                                                                                                                                                                                                                                                         |
|                                                               |       |        |                  | To Fix the bug that device will send out Status Block before the interrupt message.                                                                                                                                                                                        |
| (BCM5719/5720 only) WDMA                                      | 28    | RW     | 0                | wdma_small_packet_improvement_disable                                                                                                                                                                                                                                      |
| small packet improvement disable                              |       |        |                  | 0: Use new local RRR data instead of fetching from RBD memory (default enable).                                                                                                                                                                                            |
|                                                               |       |        |                  | 1: Use old implementation to fetch RRR data from RBD memory.                                                                                                                                                                                                               |
| Reserved                                                      | 28:19 | RO     | 0                | -                                                                                                                                                                                                                                                                          |
| Swap Test Enable                                              | 18    | RW     | 0                | When this bit is set, swap test mode will be enabled and bits 17 to 12 can be used to test different byte/word swap settings.                                                                                                                                              |
| HC Byte Swap                                                  | 17    | RW     | 0                | Byte swap control for status words.                                                                                                                                                                                                                                        |
| HC Word Swap                                                  | 16    | RW     | 0                | Word swap control for status words.                                                                                                                                                                                                                                        |
| BD Byte Swap                                                  | 15    | RW     | 0                | Byte swap control for return BDs.                                                                                                                                                                                                                                          |
| BD Word Swap                                                  | 14    | RW     | 0                | Word swap control for return BDs                                                                                                                                                                                                                                           |
| Data Byte Swap                                                | 13    | RW     | 0                | Byte swap control for data.                                                                                                                                                                                                                                                |
| Data Word Swap                                                | 12    | RW     | 0                | Word swap control for data.                                                                                                                                                                                                                                                |
| Software Byte Swap Control                                    | 11    | RW     | 0                | To override byte enables with all 1's.                                                                                                                                                                                                                                     |
| Receive Accelerate mode                                       | 10    | RW     | 0                | The write DMA-to-PCI request length is the available data size in the PCI RX FIFO.                                                                                                                                                                                         |
|                                                               |       |        |                  | Set to 1: The write DMA-to-PCI request length is the maximum length of the current transaction, regardless of the available data size in PCI RX FIFO. This mode cannot be used in slow core clock environment. Disable this mode before switching to slow core clock mode. |
| Write DMA Local Memory                                        | 9     | RW     | 0                | Attention Enable. Enable Write DMA Local Memory Read Longer Than DMA Length Attention.                                                                                                                                                                                     |
| Write DMA PCI FIFO Overwrite Attention Enable                 | 8     | RW     | 0                | Enable Write DMA PCI FIFO Overwrite Attention (PCI write longer than DMA length).                                                                                                                                                                                          |
| Write DMA PCI FIFO Underrun<br>Attention Enable               | 7     | RW     | 0                | Enable Write DMA PCI FIFO Underrun Attention.                                                                                                                                                                                                                              |
| Write DMA PCI FIFO Overrun<br>Attention Enable                | 6     | RW     | 0                | Enable Write DMA PCI FIFO Overrun Attention.                                                                                                                                                                                                                               |
| Write DMA PCI Host Address<br>Overflow Error Attention Enable | 5     | RW     | 0                | Enable Write DMA PCI Host Address Overflow Error Attention.                                                                                                                                                                                                                |
| Write DMA PCI Parity Error<br>Attention Enable                | 4     | RW     | 0                | Enable Write DMA PCI Parity Error Attention.                                                                                                                                                                                                                               |
| Write DMA PCI Master Abort<br>Attention Enable                | 3     | RW     | 0                | Enable Write DMA PCI Master Abort Attention.                                                                                                                                                                                                                               |

| Name                                        | Bits | Access | Default<br>Value | Description                                                                                                                                                                                         |
|---------------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write DMA PCI Target Abort Attention Enable | 2    | RW     | 0                | Enable Write DMA PCI Target Abort Attention.                                                                                                                                                        |
| Enable                                      | 1    | RW     | 1                | This bit controls whether the Write DMA state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains 1 when read. |
| Reset                                       | 0    | RW     | 0                | When this bit is set to 1, the Write DMA state machine is reset. This is a self-clearing bit.                                                                                                       |

# 13.24.2 Write DMA Status Register (offset: 0x4C04)

| Name                                                        | Bits  | Access | Default<br>Value | Description                                                            |
|-------------------------------------------------------------|-------|--------|------------------|------------------------------------------------------------------------|
| Reserved                                                    | 31:10 | RO     | 0                | -                                                                      |
| Write DMA Local Memory Read<br>Longer than DMA Length Error | 9     | W2C    | 0                | Write DMA Local Memory Read Longer Than DMA Length Error.              |
| Write DMA PCI FIFO Overwrite Error                          | 8     | W2C    | 0                | Write DMA PCI FIFO Overwrite Error (PCI write longer than DMA length). |
| Write DMA PCI FIFO Underrun<br>Error                        | 7     | W2C    | 0                | Write DMA PCI FIFO Underrun Error.                                     |
| Write DMA PCI FIFO Overrun<br>Error                         | 6     | W2C    | 0                | Write DMA PCI FIFO Overrun Error.                                      |
| Write DMA PCI Host Address<br>Overflow Error                | 5     | W2C    | 0                | Write DMA PCI Host Address Overflow Error.                             |
| Write DMA PCI Parity Error                                  | 4     | W2C    | 0                | Write DMA PCI Parity Error.                                            |
| Write DMA PCI Master Abort Error                            | 3     | W2C    | 0                | Write DMA PCI Master Abort Error.                                      |
| Write DMA PCI Target Abort Error                            | 2     | W2C    | 0                | Write DMA PCI Target Abort Error.                                      |
| Reserved                                                    | 1:0   | RO     | 0                | -                                                                      |

# 13.25 RX-CPU Registers

All registers reset are core reset unless specified.

## 13.25.1 RX RISC Mode Register (offset: 0x5000)

| Name                                  | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                 |
|---------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                              | 31:15 | RO     | 0                | -                                                                                                                                                                                                                                                                                           |
| Enable register address trap halt     | 14    | RW     | 0                | When set, if the GRC raises the trap signal to this processor, it will halt. Cleared on reset and Watchdog interrupt.                                                                                                                                                                       |
| Enable memory address trap halt       | 13    | RW     | 0                | When set, if the MA raises the trap signal to this processor, it will halt. Cleared on reset and Watchdog interrupt.                                                                                                                                                                        |
| Enable Invalid Instruction Fetch halt | 12    | RW     | 0                | When set, the condition that causes RX RISC state bit 6 to be set, also halts the RX RISC. Set by reset.  Cleared by Watchdog interrupt.                                                                                                                                                    |
| Enable Invalid Data access halt       | 11    | RW     | 0                | When set, the condition that causes RX RISC state bit 5 to be set, also halts the RX RISC. Set by reset.                                                                                                                                                                                    |
| Halt RX RISC                          | 10    | RW     | 0                | Cleared by Watchdog interrupt.  Set by TX RISC or the host to halt the RX RISC.Cleared on reset and Watchdog interrupt.                                                                                                                                                                     |
| Flush Instruction Cache               | 9     | WO     | 0                | Self-clearing bit which forces the instruction cache to flush.                                                                                                                                                                                                                              |
| Enable Instruction Cache prefetch     | 8     | RW     | 0                | Enables prefetch logic within the instruction cache. When disabled only a single cache line is read on a cache miss. Cleared on reset.                                                                                                                                                      |
| Enable Watchdog                       | 7     | RW     | 0                | Enables watchdog interrupt state machine. Used in conjunction with Watchdog Clear register, Watchdog Saved PC register and Watchdog Vector register. Cleared on reset and Watchdog interrupt.                                                                                               |
| ROM Fail                              | 6     | RW     | 1                | Asserted on reset. Cleared by ROM code after it successfully loads code from NVRAM. Afterwards, this bit can be used by software for any purpose.                                                                                                                                           |
| Enable Data Cache                     | 5     | RW     | 0                | Enables the data cache. Cleared on reset.  Note: Firmware developers should take care to clear this bit before polling internal SRAM memory locations, because the RX RISC processor uses a two-element LRU caching algorithm, which is not affected by writes from the PCI interface.      |
| Enable Write Post Buffers             | 4     | RW     | 0                | Enables absorption of multiple software operations for SRAM and register writes. When this bit is disabled, only one write at a time will be absorbed by the write post buffers. Cleared on reset.  Setting this bit on the BCM5705, BCM5721, and BCM5751 may cause unpredictable behavior. |
| Enable Page 0 Instr Halt              | 3     | RW     | 0                | When set, instruction references to the first 256 bytes of SRAM force the RX RISC to halt and cause bit 4 in the RX RISC state register to be latched. Cleared on reset and Watchdog interrupt.                                                                                             |
| Enable Page 0 Data Halt               | 2     | RW     | 0                | When set, data references to the first 256 bytes of SRAM force the RX RISC to halt and cause bit 3 in the RX RISC state register to be latched. Cleared on reset and Watchdog interrupt.                                                                                                    |
| Single-Step RX RISC                   | 1     | RW     | 0                | Advances the RX RISC's PC for one cycle. If halting condition still exists, the RX RISC will again halt; otherwise, it will resume normal operation.                                                                                                                                        |
| Reset RX RISC                         | 0     | WO     | 0                | Self-clearing bit which resets only the RX RISC.                                                                                                                                                                                                                                            |

## 13.25.2 RX RISC Status Register (offset: 0x5004)

The RX RISC State register reports the current state of the RX RISC and, if halted, gives reasons for the halt. There are four categories of information; informational (read-only), informational (write-to-clear), disable-able halt conditions (write-to-clear), and non-disable-able halt conditions (write-to-clear).

| Name                               | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                           |  |
|------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Blocking Read                      | 31    | RO     | 0                | A blocking data cache miss occurred, causing the RX RISC to stall while data is fetched from external (to the RX RISC) memory. This is intended as a debugging tool. No state is saved other than the fact that the miss occurred.    |  |
| MA Request FIFO overflow           | 30    | W2C    | 0                | MA_req_FIFO overflowed. The RX RISC is halted on this condition.                                                                                                                                                                      |  |
| MA data/bytemask FIFO overflow     | 29    | W2C    | 0                | MA_datamask_FIFO overflowed. The RX RISC is halted on this condition.                                                                                                                                                                 |  |
| MA outstanding read FIFO overflow  | 28    | W2C    | 0                | MA_rd_FIFO overflowed. The RX RISC is halted on this condition.                                                                                                                                                                       |  |
| MA outstanding write FIFO overflow | 27    | W2C    | 0                | MA_wr_FIFO overflowed. The RX RISC is halted on this condition.                                                                                                                                                                       |  |
| Reserved                           | 26:16 | RO     | 0                | -                                                                                                                                                                                                                                     |  |
| Instruction fetch stall            | 15    | RO     | 0                | The processor is currently stalled due to an instruction fetch.                                                                                                                                                                       |  |
| Data access stall                  | 14    | RO     | 0                | The processor is currently stalled due to a data access.                                                                                                                                                                              |  |
| Reserved                           | 13:11 | RO     | 0                | -                                                                                                                                                                                                                                     |  |
| RX RISC Halted                     | 10    | RO     | 0                | The RX RISC was explicitly halted via bit 10 in the RX RISC Mode register.                                                                                                                                                            |  |
| Register Address Trap              | 9     | W2C    | 0                | A signal was received from the Global Resources block indicating that this processor accessed a register location that triggered a software trap. The GRC registers are used to configure register address trapping.                  |  |
| Memory Address Trap                | 8     | W2C    | 0                | A signal was received from the Memory Arbiter indicating that some BCM5700 block, possibly this processor, accessed a memory location that triggered a software trap. The MA registers are used to configure memory address trapping. |  |
| Bad Memory Alignment               | 7     | W2C    | 0                | Load or Store instruction was executed with the least significant two address bits not valid for the width of the operation (e.g., Load word or Load Half-word from an odd byte address).                                             |  |
| Invalid Instruction Fetch          | 6     | W2C    | 0                | Program Counter (PC) is set to invalid location in processor address space.                                                                                                                                                           |  |
| Invalid Data Access                | 5     | W2C    | 0                | Data reference to illegal location.                                                                                                                                                                                                   |  |
| Page 0 Instruction Reference       | 4     | W2C    | 0                | When enabled in mode register, indicates the address in the PC is within the lower 256 bytes of SRAM.                                                                                                                                 |  |
| Page 0 Data Reference              | 3     | W2C    | 0                | When enabled in mode register, indicates data reference within lower 256 bytes of SRAM.                                                                                                                                               |  |
| Invalid Instruction                | 2     | W2C    | 0                | Invalid instruction fetched.                                                                                                                                                                                                          |  |
| Halt Instruction Executed          | 1     | W2C    | 0                | A halt-type instruction was executed by the RX RISC.                                                                                                                                                                                  |  |
| Hardware Breakpoint                | 0     | W2C    | 0                | When enabled in mode register, indicates hardware breakpoint has been reached.                                                                                                                                                        |  |

### 13.25.3 RX RISC Program Counter (offset: 0x501C)

The program counter register can be used to read or write the current Program Counter of each CPU. Reads can occur at any time. However writes can only be performed when the CPU is halted. Writes will also clear any pending instruction in the decode stage of the pipeline. Bits 31-2 are implemented. 1s written to bits 1-0 are ignored.

#### 13.25.4 RX RISC Hardware Breakpoint Register (offset: 0x5034)

This register is used to set a hardware breakpoint based on the RISC's program counter (PC). If the PC equals the value in this register, and the hardware breakpoint is enabled, the RISC is halted and the appropriate stopping condition is indicated in the RISC State Register. To enable the hardware breakpoint, simply write the byte address of the instruction to break on and clear the Disable Hardware Breakpoint bit.

| Name                        | Bits | Access | Default<br>Value | Description                                                |
|-----------------------------|------|--------|------------------|------------------------------------------------------------|
| Hardware Breakpoint         | 31:2 | RW     | 0                | Word address to break on.                                  |
| Reserved                    | 1    | RO     | 0                | -                                                          |
| Disable Hardware Breakpoint | 0    | RW     | 1                | When this bit is set, the Hardware Breakpoint is disabled. |

#### 13.26 VRQ Statistics

Apart from the Generic VRQ statistics, EMAC shall also offer statistics on the RX Default VRQ and RX Drop VRQ.

| VRQ# | Statistics Name     | Address | Size | Description      |
|------|---------------------|---------|------|------------------|
|      | IFHCOUTOCTETS       | 0x0A00  | 32   | Queue#1 Transmit |
|      | IFHCOUTUCAST        | 0x0A04  | 32   | Queue#1 Transmit |
| 1    | IFHCOUTMCAST        | 0x0A08  | 32   | Queue#1 Transmit |
|      | IFHCOUTBCAST        | 0x0A0C  | 32   | Queue#1 Transmit |
|      | IFHCINOCTETS_GOOD   | 0x0A10  | 32   | VRQ#1 Receive    |
|      | Reserved            | 0x0A14  | 32   | VRQ#1 Receive    |
|      | IFHCINUCASTPKTS     | 0x0A18  | 32   | VRQ#1 Receive    |
|      | IFHCINMULTICASTPKTS | 0x0A1C  | 32   | VRQ#1 Receive    |
|      | IFHCOUTOCTETS       | 0x0A20  | 32   | Queue#2 Transmit |
|      | IFHCOUTUCAST        | 0x0A24  | 32   | Queue#2 Transmit |
| 2    | IFHCOUTMCAST        | 0x0A28  | 32   | Queue#2 Transmit |
|      | IFHCOUTBCAST        | 0x0A2C  | 32   | Queue#2 Transmit |
|      | IFHCINOCTETS_GOOD   | 0x0A30  | 32   | VRQ#2 Receive    |
|      | Reserved            | 0x0A34  | 32   | VRQ#2 Receive    |
|      | IFHCINUCASTPKTS     | 0x0A38  | 32   | VRQ#2 Receive    |
|      | IFHCINMULTICASTPKTS | 0x0A3C  | 32   | VRQ#2 Receive    |
|      |                     |         | _    | -                |
|      |                     |         | _    | -                |

| VRQ# | Statistics Name     | Address | Size | Description       |
|------|---------------------|---------|------|-------------------|
|      | IFHCOUTOCTETS       | 0x0BE0  | 32   | Queue#16 Transmit |
|      | IFHCOUTUCAST        | 0x0BE4  | 32   | Queue#16 Transmit |
| 16   | IFHCOUTMCAST        | 0x0BE8  | 32   | Queue#16 Transmit |
|      | IFHCOUTBCAST        | 0x0BEC  | 32   | Queue#16 Transmit |
|      | IFHCINOCTETS_GOOD   | 0x0BF0  | 32   | VRQ#16 Receive    |
|      | Reserved            | 0x0BF4  | 32   | VRQ#16 Receive    |
|      | IFHCINUCASTPKTS     | 0x0BF8  | 32   | VRQ#16 Receive    |
|      | IFHCINMULTICASTPKTS | 0x0BFC  | 32   | VRQ#16 Receive    |

| VRQ#        | Sta | itistics Name       | Address | Size | Description                 |
|-------------|-----|---------------------|---------|------|-----------------------------|
|             | •   | IFHCINOCTETS_GOOD   | 0x09D0  | 32   | Default VRQ Stats (Receive) |
|             |     | IFHCINOCTETS_BAD    | 0x09D4  | 32   |                             |
| 0 (Default) | )   | IFHCINUCASTPKTS     | 0x09D8  | 32   |                             |
|             |     | IFHCINMULTICASTPKTS | 0x09DC  | 32   |                             |
|             |     | IFHCINBROADCASTPKTS | 0x09E0  | 32   |                             |
| 17 (Drop)   |     | IFHCINOCTETS_GOOD   | 0x09E4  | 32   | Drop VRQ Stats (Receive)    |
|             |     | Reserved            | 0x09E8  | 32   |                             |
|             |     | IFHCINUCASTPKTS     | 0x09EC  | 32   |                             |
|             |     | IFHCINMULTICASTPKTS | 0x09F0  | 32   |                             |
|             |     | IFHCINBROADCASTPKTS | 0x09F4  | 32   |                             |

## 13.27 VRQ Filter Set Registers

The filter block may be programmed via the following set of registers:

- VRQ FILT ELEM CFG REG [0 through 31]: (Offset 0x5400-0x547C)
- VRQ\_FILT\_ELEM\_PTTRN\_REG [0 through 31]: (Offset 0x5480-0x54FC)
- VRQ\_FILT\_SET\_MASK\_REG [1 through 31]: (Offset 0x5504–0x557C)

NOTE: There is no equivalent of FILT\_SET\_CFG\_REG(s) in VRQ-Filter Block. Also, Set#0 is non-existent.

### 13.28 VRQ Mapper Registers

Each VRQ Mapper Entry is represented by a pair of 32-bit registers, named 1st Half of Entry and 2nd Half of Entry. There shall be 18 such register pairs in order to map to 18 VRQ entries – including the Default VRQ and the Drop VRQ. This register pair is used to program an SOP equation expressed as:

Filter Result = (Perf A AND/OR Set A) || (Perf B AND/OR Set B) || (Perf C AND/OR Set C) || (Perf D AND/OR Set D).

| Name                                | Bits  | Access | Default<br>Value | Description                                                                                  |  |
|-------------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------|--|
| Product Term D                      |       |        |                  |                                                                                              |  |
| Reserved                            | 31:30 | RO     | 0                | -                                                                                            |  |
| Activate Perfect Match in this Term | 29    | RW     | 0                | Write a 1 in this field to activate the Perfect Match Address Reg selected by field [28:24]. |  |

| Name                                | Bits  | Access | Default<br>Value | Description                                                                                 |
|-------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------|
| Perfect Match Address Reg #         | 28:24 | RW     | 0x0              | Write 0 – 23 in this field to select the Perfect Match Address Reg Term D.                  |
| Product Term C                      |       |        |                  |                                                                                             |
| Reserved                            | 23:22 | RO     | 0                | -                                                                                           |
| Activate Perfect Match in this Term | 21    | RW     | 0                | Write a 1 in this field to activate the Perfect Match Address Reg selected by field [20:16] |
| Perfect Match Address Reg #         | 20:16 | RW     | 0x0              | Write $0-23$ in this field to select the Perfect Match Address Reg for Term C.              |
| Product Term B                      |       | *      | *                |                                                                                             |
| Reserved                            | 15:14 | RO     | 0                | -                                                                                           |
| Activate Perfect Match in this Term | 13    | RW     | 0                | Write a 1 in this field to activate the Perfect Match Address Reg selected by field [12:8]. |
| Perfect Match Address Reg #         | 12:8  | RW     | 0x0              | Write $0-23$ in this field to select the Perfect Match Address Reg for Term B.              |
| Product Term A                      |       | *      | *                |                                                                                             |
| Reserved                            | 7:6   | RO     | 0                | -                                                                                           |
| Activate Perfect Match in this Term | 5     | RW     | 0                | Write a 1 in this field to activate the Perfect Match Address Reg selected by field [4:0].  |
| Perfect Match Address Reg #         | 4:0   | RW     | 0x0              | Write 0 – 23 in this field to select the Perfect Match Address Reg for Term A.              |

| Name                                 | Bits  | Access | Default<br>Value | Description                                                                         |
|--------------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------|
| Product Term D                       |       |        |                  |                                                                                     |
| Activate Product Term D              | 31    | RW     | 0                | Write a 1 to activate this whole Product Term.                                      |
| AND/OR                               | 30    | RW     | 0                | 0 => Perfect Match Addr && VRQ Filter Set 1 => Perfect Match Addr    VRQ Filter Set |
| Activate VRQ Filter Set in this Term | 29    | RW     | 0                | Write a 1 in this field to activate the VRQ Filter Set selected by field [28:24].   |
| VRQ Filter Set #                     | 28:24 | RW     | 0x0              | Write 1 – 31 in this field to select the VRQ Filter Set for Term D.                 |
| Product Term C                       |       |        | <u> </u>         |                                                                                     |
| Activate Product Term C              | 23    | RW     | 0                | Write a 1 to activate this whole Product Term                                       |
| AND/OR                               | 22    | RW     | 0                | 0 => Perfect Match Addr && VRQ Filter Set 1 => Perfect Match Addr    VRQ Filter Set |
| Activate VRQ Filter Set in this Term | 21    | RW     | 0                | Write a 1 in this field to activate the VRQ Filter Set selected by field [20:16].   |
| VRQ Filter Set #                     | 20:16 | RW     | 0x0              | Write 1 – 31 in this field to select the VRQ Filter Set for Term C.                 |
| Product Term B                       |       |        | <u> </u>         |                                                                                     |
| Activate Product Term B              | 15    | RW     | 0                | Write a 1 to activate this whole Product Term                                       |
| AND/OR                               | 14    | RW     | 0                | 0 => Perfect Match Addr && VRQ Filter Set                                           |
|                                      |       |        |                  | 1 => Perfect Match Addr    VRQ Filter Set                                           |
| Activate VRQ Filter Set in this Term | 13    | RW     | 0                | Write a 1 in this field to activate the VRQ Filter Set selected by field [12:8].    |
| VRQ Filter Set #                     | 12:8  | RW     | 0x0              | Write 1 – 31 in this field to select the VRQ Filter Set for Term B.                 |
| Product Term A                       |       |        | <u> </u>         | <u>'</u>                                                                            |

| Name                                 | Bits | Access | Default<br>Value | Description                                                                         |
|--------------------------------------|------|--------|------------------|-------------------------------------------------------------------------------------|
| Activate Product Term A              | 7    | RW     | 0                | Write a 1 to activate this whole Product Term.                                      |
| AND/OR                               | 6    | RW     | 0                | 0 => Perfect Match Addr && VRQ Filter Set 1 => Perfect Match Addr    VRQ Filter Set |
| Activate VRQ Filter Set in this Term | 5    | RW     | 0                | Write a 1 in this field to activate the VRQ Set selected by field [4:0].            |
| VRQ Filter Set #                     | 4:0  | RW     | 0x0              | Write 1 – 31 in this field to select the VRQ Filter Set for Term A.                 |

The table below lists registers addresses of all 18 pairs:

| VRQ Entry # | Second Half Register Address | First Half Register Address |  |  |  |
|-------------|------------------------------|-----------------------------|--|--|--|
| 0 (Default) | 0x5604                       | 0x5600                      |  |  |  |
| 1           | 0x560C                       | 0x5608                      |  |  |  |
| 2           | 0x5614                       | 0x5610                      |  |  |  |
| 3           | 0x561C                       | 0x5618                      |  |  |  |
| 4           | 0x5624                       | 0x5620                      |  |  |  |
| 5           | 0x562C                       | 0x5628                      |  |  |  |
| 6           | 0x5634                       | 0x5630                      |  |  |  |
| 7           | 0x563C                       | 0x5638                      |  |  |  |
| 8           | 0x5644                       | 0x5640                      |  |  |  |
| 9           | 0x564C                       | 0x5648                      |  |  |  |
| 10          | 0x5654                       | 0x5650                      |  |  |  |
| 11          | 0x565C                       | 0x5658                      |  |  |  |
| 12          | 0x5664                       | 0x5660                      |  |  |  |
| 13          | 0x566C                       | 0x5668                      |  |  |  |
| 14          | 0x5674                       | 0x5670                      |  |  |  |
| 15          | 0x567C                       | 0x5678                      |  |  |  |
| 16          | 0x5684                       | 0x5680                      |  |  |  |
| 17 (Drop)   | 0x568C                       | 0x5688                      |  |  |  |

## 13.28.0.1 VRQ Enable Register (Offset 0x560)

This register contains an 18-bit field to provide the ability to enable or disable desired number of VRQs.

| Name               | Bits  | Access | Default<br>Value | Description                                                                                                                                 |
|--------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved           | 31:18 | RO     | 000              | Reserved                                                                                                                                    |
| VRQ Enable Bit-Map | 17:0  | RW     | 0x0000           | When a bit position is written 1 the respective VRQ# is enabled and is capable of receiving packets.                                        |
|                    |       |        |                  | When a bit position is written 0, the respective VRQ# is not capable of receiving packets – even though its VRQ Mapper Entry is programmed. |
|                    |       |        |                  | Bit[0] => Default VRQ                                                                                                                       |
|                    |       |        |                  | Bit[16:1] => Generic VRQs                                                                                                                   |
|                    |       |        |                  | Bit[17] => Drop Queue                                                                                                                       |

#### 13.28.0.2 RX Mail Box Registers for VRQ

A set of new High Priority Mail Box Registers are introduced. The register addresses are as shown in the table below:

| VRQ#      | RX Jumbo Ring<br>Producer Index | RX Standard Ring<br>Producer Index | RX Return<br>Consumer | _      | Comments                            | NIC Diagnostic RX Return Ring Producer Index |
|-----------|---------------------------------|------------------------------------|-----------------------|--------|-------------------------------------|----------------------------------------------|
| 0         | 0x270                           | UNDI – 0x98                        | UNDI – 0x8            | 38     | 64-bit                              | 0x3C80                                       |
| (Default) |                                 | HP – 0x268                         | HP - 0x280            | )      | Registers                           |                                              |
| 1         | 0x2D4                           | 0x354                              | 0x288                 | 64-bit | The new                             | 0x3C84                                       |
| 2         | 0x2D8                           | 0x358                              | 0x290                 | Regs   | Registers are                       | 0x3C88                                       |
| 3         | 0x2DC                           | 0x35C                              | 0x298                 |        | 32-bit                              | 0x3C8C                                       |
| 4         | 0x2E0                           | 0x360                              | 0x2A0                 |        | The new<br>Registers are<br>-32-bit | 0x3C90                                       |
| 5         | 0x2E4                           | 0x364                              | 0x2A4                 |        |                                     | 0x3C94                                       |
| 6         | 0x2E8                           | 0x368                              | 0x2A8                 |        |                                     | 0x3C98                                       |
| 7         | 0x2EC                           | 0x36C                              | 0x2AC                 |        |                                     | 0x3C9C                                       |
| 8         | 0x2F0                           | 0x370                              | 0x2B0                 |        |                                     | 0x3CA0                                       |
| 9         | 0x2F4                           | 0x374                              | 0x2B4                 |        |                                     | 0x3CA4                                       |
| 10        | 0x2F8                           | 0x378                              | 0x2B8                 |        |                                     | 0x3CA8                                       |
| 11        | 0x2FC                           | 0x37C                              | 0x2BC                 |        |                                     | 0x3CAC                                       |
| 12        | 0x340                           | 0x380                              | 0x2C0                 |        |                                     | 0x3CB0                                       |
| 13        | 0x344                           | 0x384                              | 0x2C4                 |        |                                     | 0x3CB4                                       |
| 14        | 0x348                           | 0x388                              | 0x2C8                 |        | 1                                   | 0x3CB8                                       |
| 15        | 0x34C                           | 0x38C                              | 0x2CC                 |        | 1                                   | 0x3CBC                                       |
| 16        | 0x350                           | 0x390                              | 0x2D0                 |        | 1                                   | 0x3CC4                                       |

**Note:** 0x268 – 0x298, 0x88, 0x98 are legacy registers.

NIC Diagnostic Standard RBD Consumer Index [1–16] == 0x3F40–0x3F7C

NIC Diagnostic Jumbo RBD Consumer Index [1-16] == 0x3F80-0x3FFC.

## 13.29 Perfect Match Destination Address Registers

Twenty more Perfect Match Destination Address Registers are added in RX-EMAC for VRQ Filtering purposes – Register [0 -3] are legacy, whilst [4 -23] are shown here:

# 13.29.1 VRQ\_PERFECT\_MATCH[4-23]\_HIGH\_REG (Offsets: 0x5690, 0x5698, 0x56A0 ... 0x5728)

There are total 24 Perfect (Destination Address) Match registers for VRQ Filtering in RX-MAC. These registers hold the higher 2 octets of the matching address.

| Name             | Bits  | Access | Default<br>Value | Description                  |
|------------------|-------|--------|------------------|------------------------------|
| Reserved         | 31:29 | RO     | 000              | Reserved                     |
| MAC High Address | 15:0  | RW     | 0x0000           | Upper 2-bytes of MAC address |

# 13.29.2 VRQ\_PERFECT\_MATCH[4 - 23]\_LOW\_REG (Offsets: 0x5694, 0x569C, 0x56A4 ... 0x572C)

There are a total 24 Perfect (Destination Address) Match registers for VRQ Filtering in RX-MAC. These registers hold the higher 2 octets of the matching address.

| Name            | Bits | Access | Default<br>Value | Description                  |
|-----------------|------|--------|------------------|------------------------------|
| MAC Low Address | 31:0 | RO     | 0x0000           | Lower 4-bytes of MAC address |

## 13.30 Low Priority Mailboxes

This is a 512 byte region that contains 64 registers. These registers are called low-priority mailbox registers (or low-priority mailboxes). When a value is stored in the least significant 32 bits of these registers, an event (known as a Mailbox Event) is generated to the RX RISC. Host software should use the high-priority mailbox region from 0x200–0x3FF for host standard and the low-priority mailbox region from 0x5800–0x59FF for indirect register access mode. The Mailbox registers starting at memory offset 0x200 for host standard and offset 0x5800 for indirect mode.

#### 13.30.1 Interrupt Mailbox 0 Register (offset: 0x5800)

This mailbox serves two functions. When the host writes it, the interrupt (IntA) is cleared. It is also used by the Host Coalescing engine to determine if the host is in the interrupt handler. If it is non-zero this indicates the host is in the interrupt handler. The Host Coalescing engine uses this information to determine which set of coalescing parameters it should use.

#### 13.30.2 Other Interrupt Mailbox Register (offset: 0x5808-0x5818)

This mailbox serves two functions. When the host writes it, the interrupt (IntA) is cleared. It is also used by the Host Coalescing engine to determine if the host is in the interrupt handler. If it is non-zero this indicates the host is in the interrupt handler. The Host Coalescing engine uses this information to determine which set of coalescing parameters it should use.

## 13.30.3 General Mailbox Registers 1-8 (offset: 0x5820-0x5824)

This mailbox serves two functions. When the host writes it, the interrupt (IntA) is cleared. It is also used by the Host Coalescing engine to determine if the host is in the interrupt handler. If it is non-zero this indicates the host is in the interrupt handler. The Host Coalescing engine uses this information to determine which set of coalescing parameters it should use.

## 13.30.4 Receive BD Standard Producer Ring Index Register (offset: 0x5868)

The Receive BD Standard Producer Ring Index register, contain the index of the next buffer descriptor for the standard producer ring that will be produced in the host for the NIC to DMA into NIC memory. Host software writes this register whenever it updates the standard producer ring. This register must be initialized to 0.

#### 13.30.5 Receive BD Jumbo Producer Ring Index Register (offset: 0x5870-5877)

The Receive BD Extended Producer Ring Index Register contains the index of the next buffer descriptor for the extended producer ring that will be produced in the host for the NIC to DMA into NIC memory. Host software writes this register whenever it updates the extended producer ring. This register must be initialized to 0.

| Name                                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Received BD jumbo Producer<br>Ring Index | 7:0  | RW     | _                | The Receive BD Extended Producer Ring Index register contains the index of the next buffer descriptor for the extended producer ring that will be produced in the host for the controller to DMA into controller memory. Host software writes this register whenever it updates the extended producer ring. This register must be initialized to 0. |

# 13.30.6 Receive BD Return Ring 0 Consumer Index Register (offset: 0x5880-0x5887)

The Receive BD Return Ring 0 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 0 that has been consumed. Host software writes this register whenever it updates the return ring 0. This register must be initialized to 0.

# 13.30.7 Receive BD Return Ring 1 Consumer Index Register (offset: 0x5888-0x588F)

The Receive BD Return Ring 1 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 1 that has been consumed. Host software writes this register whenever it updates the return ring 1. This register must be initialized to 0.

# 13.30.8 Receive BD Return Ring 2 Consumer Index Register (offset: 0x5890-0x5897)

The Receive BD Return Ring 2 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 2 that has been consumed. Host software writes this register whenever it updates the return ring 2. This register must be initialized to 0.

# 13.30.9 Receive BD Return Ring 3 Consumer Index Register (offset: 0x5898-0x589F)

The Receive BD Return Ring 3 Consumer Index Register contains the index of the last buffer descriptor for Receive Return Ring 3 that has been consumed. Host software writes this register whenever it updates the return ring 3. This register must be initialized to 0.

## 13.30.10 Send BD Ring Host Producer Index Register (offset: 0x5900)

The Send BD Ring Host Producer Index register, contain the index of the next buffer descriptor for a given send ring that will be produced in the host for the NIC to DMA into NIC memory. Host software writes this register whenever it updates the given send ring. This register must be initialized to 0. The host producer indices may not be used at the same time as the NIC producer indices.

When multiple TXQ is enabled:

Send BD Ring Host Producer Index Register for Ring 1 (offset: 0x5900)

Send BD Ring Host Producer Index Register for Ring 2 (offset: 0x5908)

Send BD Ring Host Producer Index Register for Ring 3 (offset: 0x590C)

Send BD Ring Host Producer Index Register for Ring 4 (offset: 0x5910)

Send BD Ring Host Producer Index Register for Ring 5 (offset: 0x5914)

Send BD Ring Host Producer Index Register for Ring 6 (offset: 0x5918)

Send BD Ring Host Producer Index Register for Ring 7 (offset: 0x591C)

Send BD Ring Host Producer Index Register for Ring 8 (offset: 0x5920)

Send BD Ring Host Producer Index Register for Ring 9 (offset: 0x5924)

Send BD Ring Host Producer Index Register for Ring 10 (offset: 0x5928)

Send BD Ring Host Producer Index Register for Ring 11 (offset: 0x592C)

Send BD Ring Host Producer Index Register for Ring 12 (offset: 0x5930)

Send BD Ring Host Producer Index Register for Ring 13 (offset: 0x5934)

Send BD Ring Host Producer Index Register for Ring 14 (offset: 0x5938)

Send BD Ring Host Producer Index Register for Ring 15 (offset: 0x593C)

Send BD Ring Host Producer Index Register for Ring 16 (offset: 0x5940)

## 13.30.11 Send BD Ring NIC Producer Index Register (offset: 0x5980)

The Send BD Ring NIC Producer Index register contains the index of the next buffer descriptor for a given send ring that will be produced in the host directly into NIC memory. The host software writes this register whenever it updates the given send ring. This register must be initialized to 0. The host producer indices may not be used at the same time as the NIC producer indices.

When multiple TXQ is enabled:

Send BD Ring Producer Index Register for Ring 1 (offset: 0x5980)

Send BD Ring Producer Index Register for Ring 2 (offset: 0x5984)

Send BD Ring Producer Index Register for Ring 3 (offset: 0x5988)

Send BD Ring Producer Index Register for Ring 4 (offset: 0x598C)

Send BD Ring Producer Index Register for Ring 5 (offset: 0x5990)

Send BD Ring Producer Index Register for Ring 6 (offset: 0x5994)

Send BD Ring Producer Index Register for Ring 7 (offset: 0x5998)

Send BD Ring Producer Index Register for Ring 8 (offset: 0x599C)

Send BD Ring Producer Index Register for Ring 9 (offset: 0x59A0)

Send BD Ring Producer Index Register for Ring 10 (offset: 0x59A4)

Send BD Ring Producer Index Register for Ring 11 (offset: 0x59A8)

Send BD Ring Producer Index Register for Ring 12 (offset: 0x59AC)

Send BD Ring Producer Index Register for Ring 13 (offset: 0x59B0)

Send BD Ring Producer Index Register for Ring 14 (offset: 0x59B4)

Send BD Ring Producer Index Register for Ring 15 (offset: 0x59B8)

Send BD Ring Producer Index Register for Ring 16 (offset: 0x59BC)

## 13.31 Flow Through Queues

All registers reset are core reset unless specified.

### 13.31.1 FTQ Reset Register (offset: 0x5C00)

| Name                              | Bits  | Access | Default<br>Value | Description                                                                                                                                                       |
|-----------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                          | 31:17 | RO     | 0                | -                                                                                                                                                                 |
| Reset Receive Data Completion FTQ | 16    | RW     | 0                | Set this bit to reset the Receive Data Completion flow through queue.  When set to 0, this FTQ is ready for use.  This bit is self-clearing.                      |
| Reserved                          | 15    | RO     | 0                | -                                                                                                                                                                 |
| Reset Receive List Placement FTQ  | 14    | RW     | 0                | Set this bit to reset the Receive List. This bit self-clearing placement flow through queue.  When set to 0, this FTQ is ready for use. This bit is self-clearing |
| Reset Receive BD Complete FTQ     | 13    | RW     | 0                | Set this bit to reset the Receive BD Complete flow through queue. When set to 0, this FTQ is ready for use. This bit is self-clearing                             |
| Reserved                          | 12    | RO     | 0                | -                                                                                                                                                                 |
| Reset MAC TX FTQ                  | 11    | RW     | 0                | Set this bit to reset the MAC TX flow through queue. When set to 0, this flow through queue is ready for use.  This bit is self-clearing.                         |
| Reset Host Coalescing FTQ         | 10    | RW     | 0                | Set this bit to reset the Host Coalescing flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing.                 |
| Reset Send Data Completion FTQ    | 9     | RW     | 0                | Set this bit to reset the Send Data Completion flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing.            |
| Reserved                          | 8     | RO     | 0                | -                                                                                                                                                                 |

| Name                              | Bits | Access | Default<br>Value | Description                                                                                                                                               |
|-----------------------------------|------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset DMA High Priority Write FTQ | 7    | RW     | 0                | Set this bit to reset the DMA High Priority Write flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing. |
| Reset DMA Write FTQ               | 6    | RW     | 0                | Set this bit to reset the DMA Write flow through queue. When set to 0, this flow through queue is ready for use.                                          |
|                                   |      |        |                  | This bit is self-clearing.                                                                                                                                |
| Reserved                          | 5    | RO     | 0                | _                                                                                                                                                         |
| Reset Send BD Completion FTQ      | 4    | RW     | 0                | Set this bit to reset the Send BD Completion flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing.      |
| Reserved                          | 3    | RO     | 0                | -                                                                                                                                                         |
| Reset DMA High Priority Read FTQ  | 2    | RW     | 0                | Set this bit to reset the DMA High Priority Read flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing.  |
| Reset DMA Read Queue FTQ          | 1    | RW     | 0                | Set this bit to reset the DMA Read Queue flow through queue. When set to 0, this flow through queue is ready for use. This bit is self-clearing.          |
| Reserved                          | 0    | RO     | 0                | -                                                                                                                                                         |

### 13.31.2 MAC TX FIFO Enqueue Register (offset: 0x5CB8)

A write to this register will add a transmit packet to the tail of the MACTQ FTQ. The host CPU uses this register to send an ASF message out.

The TXMBUF cluster for the ASF message is defaulted to the uppermost three TXMBUFs.

| Name                | Bits  | Access | Default<br>Value | Description                                                             |
|---------------------|-------|--------|------------------|-------------------------------------------------------------------------|
| Reserved            | 31    | WO     | 0                | Must Write 1 to transmit a packet                                       |
| Reserved            | 30:16 | WO     | 0                | Must Write 0                                                            |
| Head TXMBUF Pointer | 15:8  | WO     | 0                | Specifies the first MBUF of the TXMBUF cluster for the transmit packet. |
| Tail TXMBUF Pointer | 7:0   | WO     | 3Fh              | Specifies the last MBUF of the TXMBUF cluster for the transmit packet.  |

## 13.31.3 RXMBUF Cluster Free Enqueue Register (offset: 0x5CC8)

A write to this register will free a cluster of RXMBUFs. The host CPU uses this register to deallocate RXMBUFs after it has processed the received ASF message.

| Name                | Bits  | Access | Default<br>Value | Description                                                                         |
|---------------------|-------|--------|------------------|-------------------------------------------------------------------------------------|
| Reserved            | 31:18 | RO     | 0                | -                                                                                   |
| Head RXMBUF Pointer | 17:9  | WO     | 00h              | Specifies the first MBUF of the RXMBUF cluster for the received packet to be freed. |
| Tail RXMBUF Pointer | 8:0   | WO     | 00h              | Specifies the last MBUF of the TXMBUF cluster for the received packet to be freed.  |

#### 13.31.4 RDIQ FTQ Write/Peak Register (offset: 0x5CFC)

The host CPU uses this register to get the RXMBUF cluster pointers if the received packet requires the attention of the This could be an ASF or ACPI packet.

- A write to this register will modify the head of the RDIQ FTQ entry.
- A read of this register will peek at the head of the RDIQ FTQ entry.
- When the Valid bit is 1 and the Pass bit is 0, the CPU can take the RXMBUF cluster pointers to access the received Packet.
- When the CPU writes a 1 to the Skip bit, the hardware will pop the head of the queue entry.

| Name                | Bits  | Access | Default<br>Value | Description                                                                                             |
|---------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------|
| Reserved            | 31:21 | RO     | 0                | -                                                                                                       |
| Valid Bit           | 20    | RW     | 0                | Set only if the head of RDIQ entry is valid.                                                            |
| Skip Bit            | 19    | RW     | 0                | If this bit is set, the head of RDIQ entry will be popped.                                              |
| Pass Bit            | 18    | RW     | 0                | This bit is 0 if RDIQ head entry is intended for the CPU. It prevents the entry to be serviced by WDMA. |
| Head RXMBUF Pointer | 17:9  | RO     | 0                | Specifies the first MBUF of the RXMBUF cluster for the received packet.                                 |
| Tail RXMBUF Pointer | 8:0   | RO     | 0                | Specifies the last MBUF of the RXMBUF cluster for the received packet.                                  |

## 13.32 Message Signaled Interrupt Registers

All registers reset are core reset unless specified.

#### 13.32.1 MSI Mode Register (offset: 0x6000)

| Name                                      | Bits  | Access | Default<br>Value | Description                                                                                                                                                               |
|-------------------------------------------|-------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Priority                                  | 31:30 | RW     | 0                | Sets the priority of the MSI engine relative to the DMA read engine and DMA Write engine. Equal settings result in fair round robin arbitration.                          |
|                                           |       |        |                  | ■ 00: Lowest                                                                                                                                                              |
|                                           |       |        |                  | ■ 01: Low                                                                                                                                                                 |
|                                           |       |        |                  | ■ 10: High                                                                                                                                                                |
|                                           |       |        |                  | ■ 11: Highest                                                                                                                                                             |
| (BCM571X/BCM5720) Reserved                | 29:11 | RO     | 0                | -                                                                                                                                                                         |
| (BCM5719) Reserved                        | 29:24 | RO     | 0                | -                                                                                                                                                                         |
| (BCM5719) MSI ST Lower                    | 23:16 | RW     | 0x01             | This 8-bit value is used as the TPH Steering Tag when both TPH Interrupt Vector mode and MSI mode are enabled.                                                            |
| (BCM5719) Reserved                        | 15;11 | RO     | 0                | -                                                                                                                                                                         |
| MSI Message                               | 10:8  | RW     | 0                | This register sets the MSI message data bottom bits to the value programmed here. This register exists only for testing purposes and should always be programmed to zero. |
| (BCM571X/BCM5720) Reserved                | 7     | RO     | 0                | _                                                                                                                                                                         |
| (BCM5719) MSIX Multimode<br>Vector Enable | 7     | RW     | 0                | -                                                                                                                                                                         |

| Name                    | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSI Byte Swap           | 6    |        | 0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| MSI Single Shot Disable | 5    | RW     | 0                | Disable MSI Single Shot mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         |      |        |                  | 1: Disable One-Shot MSI mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                         |      |        |                  | 0: Enable One-Shot MSI mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |      |        |                  | One-Shot MSI mode works in conjunction with Tag Interrupt mode. The Tag Interrupt mode is enabled by setting bit 9 of Register 0x68. When One-Shot MSI mode is enabled, the hardware automatically auto-mask and auto-acknowledge when MSI Interrupt is generated by the hardware. Software needs to un-mask the interrupt after it has serviced the current MSI Interrupt to allow future interrupt to generate by the hardware. The mechanism for software to un-mask the interrupt is by writing to the mailbox register bits 31:24 with the same Tag value that was DMAed to the Host in the last Status Block update. See note below. |
| PCI Parity Error Attn   | 4    | RW     | 0                | PCI parity error attention enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PCI Master Abort Attn   | 3    | RW     | 0                | PCI master abort attention enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PCI Target Abort Attn   | 2    | RW     | 0                | PCI target abort attention enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Enable                  | 1    | RW     | 1                | This bit controls whether the MSI state machine is active or not. When set to 0, it completes the current operation and cleanly halts. Until it is completely halted, it remains one when read.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Reset                   | 0    | RW     | 0                | When this bit is set to 1, the MSI state machine is reset. This is a self-clearing bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                         |      |        |                  | Note: If not using Tagged Status mode, the driver should set 0x6000 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# 13.32.2 MSI Status Register (offset: 0x6004)

| Name             | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                      |
|------------------|------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved         | 31:5 | RO     | 0                | -                                                                                                                                                                                                                                                                                |
| PCI Parity Error | 4    | W2C    | 0                | PCI parity error status                                                                                                                                                                                                                                                          |
| PCI Master Abort | 3    | W2C    | 0                | PCI master abort status                                                                                                                                                                                                                                                          |
| PCI Target Abort | 2    | W2C    | 0                | PCI target abort status                                                                                                                                                                                                                                                          |
| Reserved         | 1    | RO     | 0                | -                                                                                                                                                                                                                                                                                |
| MSI PCI Request  | 0    | RW     | 0                | Reading this bit returns the current status of the request to PCI to send an MSI. If a value of 1 is read, then the request is currently asserted. Writing this bit with a value of one will cause the request to be asserted. Writing this bit with a value of 0 has no effect. |

## 13.33 DMA Completion Registers

All registers reset are core reset unless specified.

## 13.33.1 DMA Completion Mode Register (offset: 0x6400)

| Name     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                |
|----------|------|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved | 31:2 | RW     | _                | Reserved                                                                                                                                                                                                   |
| Enable   | 1    | RW     | 0                | This bit controls whether the DMA Completion state machine is active or not. When set to '0' it completes the current operation and cleanly halts. Until it is completely halted it remains '1' when read. |
| Reset    | 0    | RW     | 0                | When this bit is set to '1' the DMA Completion state machine is reset. This is a self-clearing bit.                                                                                                        |

# 13.34 GRC Registers

All registers reset are core reset unless specified.

### 13.34.1 Mode Control Register (offset: 0x6800)

| Name                              | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                   |
|-----------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pcie TL/DL/PL mapping bit         | 31   | RW     | 0                | Bit[31][22][29] remap PCIE core TL/DL/PL register to GRC space from 0x6400 to 0x67ff.  [31]:  0: Select lower 1 KB of each TL/DL/PL  1 Select higher 1 KB of each TL/DL/PI  [22][29]:  00: select TL register  01: select DL register  10: select PL register |
| Multicast enable                  | 30   | RW     | 0                | Multicast enable bit.                                                                                                                                                                                                                                         |
| Pcie TL/DL/PL mapping bit         | 29   | RW     | _                | -                                                                                                                                                                                                                                                             |
| Interrupt on Flow Attention       | 28   | RW     | 0                | Cause a host interrupt when an enabled flow attention occurs.                                                                                                                                                                                                 |
| Interrupt on DMA Attention        | 27   | RW     | 0                | Cause a host interrupt when an enabled DMA attention occurs.                                                                                                                                                                                                  |
| Interrupt on MAC Attention        | 26   | RW     | 0                | Cause a host interrupt when an enabled MAC attention occurs.                                                                                                                                                                                                  |
| Interrupt on RX RISC Attention    | 25   | RW     | 0                | Cause a host interrupt when an enabled RX-RISC attention occurs.                                                                                                                                                                                              |
| TXCP_ATTN_INT_EN                  | 24   | RO     | 0                | TXCP attention bit.                                                                                                                                                                                                                                           |
| Receive No Pseudo-header checksum | 23   | RW     | 0                | Do not include the pseudo-header in the TCP or UDP checksum calculations. To obtain the correct checksum, the driver must add the TCP/UDP checksum field to the pseudo-header checksum.                                                                       |
| Pcie TL/DL/PL mapping bit         | 22   | RO     | 0                | -                                                                                                                                                                                                                                                             |

| Name                           | Bits | Access           | Default<br>Value | Description                                                                                                                                                                                                                                            |
|--------------------------------|------|------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NVRAM Write Enable             | 21   | RW               | 0                | The host must set this bit before attempting to update the Flash or SEEPROM                                                                                                                                                                            |
|                                |      |                  |                  | This bit is only valid when set from GRC port 0. Setting/clearing of this bit from GRC port 1 does not affect NVRAM write access control. For BCM571X/BCM5720 family, it is recommended to use 0x7024[1] from all ports to control NVRAM write access. |
| Send No Pseudo-header checksum | 20   | RW               | 0                | Do not include the pseudo-header in the TCP or UDP checksum calculations. To obtain the correct checksum, the driver must seed the TCP/UDP checksum field with the pseudo-header checksum.                                                             |
| Time Sync Mode Enable          | 19   | RW               | 0                | Write 1 to this bit to enable Time Sync Mode.                                                                                                                                                                                                          |
| HTX2B Feature Enable (BCM5720) | 18   | RW               | 0                | Write 1 to enable TX-MAC to route HTX2B packets to the APE. Firmware may enable/disable this in flight with careful coordination.                                                                                                                      |
| Host Send BDs                  | 17   | RW               | 0                | Use host-based BD rings instead of NIC-based BD rings.                                                                                                                                                                                                 |
| Host Stack Up                  | 16   | RW               | 0                | The host stack is ready to receive data from the NIC.                                                                                                                                                                                                  |
| B2HRX Feature Enable           | 15   | RW               | 0                | Write 1 to enable DMA Engine to route B2HRX packets to PCle. Firmware may enable/disable this in flight with careful coordination.                                                                                                                     |
| Don't Interrupt on Receives    | 14   | RW               | 0                | Never cause an interrupt on receive return ring producer updates.                                                                                                                                                                                      |
| Don't Interrupt on Sends       | 13   | RW               | 0                | Never cause an interrupt on send BD ring producer updates.                                                                                                                                                                                             |
| DW_SYS_ATTN                    | 12   | RO               | 0                | WDMA attention bit.                                                                                                                                                                                                                                    |
| Allow Bad Frames               | 11   | RW               | 0                | The RX MAC forwards illegal frames to the NIC and marks them as such instead of discarding them. The frames are queued based on default class and interrupt distribution queue number.                                                                 |
| NO_CRC                         | 10   | RO               | 0                | -                                                                                                                                                                                                                                                      |
| No Frame Cracking              | 9    | RW               | 0                | Turn off all frame cracking functionality in both the read DMA engine and the MAC receive engine. On receive, the TCP/UDP checksum field is replaced by raw checksum for the whole frame except the Ethernet header.                                   |
|                                |      |                  |                  | On transmit, IP and TCP/UDP checksum generation is always disabled when this bit is set. Also, the raw checksum is calculated over the entire frame except the Ethernet header and CRC.                                                                |
| IOV Mode Enable                | 8    | RW               | 0                | When this bit is written 1, the chip enters IOV-MODE.                                                                                                                                                                                                  |
|                                |      |                  |                  | When this bit is written 0, the chip operates in legacy mode.                                                                                                                                                                                          |
|                                |      |                  |                  | This bit must only be configured during boot-up and must not be changed afterwards.                                                                                                                                                                    |
| Legacy                         | 7:0  |                  |                  | Defined by Legacy                                                                                                                                                                                                                                      |
| Byte Swap for B2HRX Data       | 7    | RW               | 0                | This bit must be 1 for proper B2HRX operation in case of Little-<br>Endian Host machines.                                                                                                                                                              |
| Word Swap for B2HRX Data       | 6    | RW               | 0                | This bit must be 1 for proper B2HRX operation in case of Little-<br>Endian Host machines.                                                                                                                                                              |
| Word Swap Data                 | 5    | Host-RW<br>NIC-R | 0                | Word swap data when DMAing it across the PCIE bus.                                                                                                                                                                                                     |
| Byte Swap Data                 | 4    | Host-RW<br>NIC-R | 0                | Byte swap data when DMAing it across the PCIE bus.                                                                                                                                                                                                     |
| FLR state                      | 3    | RO               | 0                | When this bit is set, it means PCIE is in FLR state for this MAC core.                                                                                                                                                                                 |
| Word Swap BD                   | 2    | Host-RW<br>NIC-R | 0                | Word swap BD structure when DMAing them across the PCIE bus.                                                                                                                                                                                           |
| Byte Swap BD                   | 1    | Host-RW<br>NIC-R | 0                | Byte swap BD structure when DMAing them across the PCIE bus.                                                                                                                                                                                           |

| Name     | Bits | Access | Default<br>Value | Description |
|----------|------|--------|------------------|-------------|
| Reserved | 0    | RO     | 0                | _           |

## 13.34.2 Miscellaneous Configuration Register (offset: 0x6804)

| Name                            | Bits  | Access | Default<br>Value | Description                                                                                                                      |
|---------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------|
| ID7                             | 31    | RO     | ID7              | Bond ID 7                                                                                                                        |
| ID6                             | 30    | RO     | ID6              | Bond ID 6                                                                                                                        |
| Disable GRC Reset on PCIE block | 29    | RW     | 0                | Setting this bit will prevent reset to PCIE block.                                                                               |
| ID5                             | 28    | RO     | ID5              | Bond ID 5                                                                                                                        |
| ID4                             | 27    | RO     | ID4              | Bond ID 4                                                                                                                        |
| Reserved                        | 26    | RW     | 0                | -                                                                                                                                |
| Reserved                        | 25    | RW     | 0                | -                                                                                                                                |
| Reserved                        | 24    | RW     | 0                | -                                                                                                                                |
| Reserved                        | 23    | RW     | 0                | -                                                                                                                                |
| Reserved                        | 22    | RW     | 0                | -                                                                                                                                |
| Reserved                        | 21    | RW     | 0                | -                                                                                                                                |
| Powerdown                       | 20    | RW     | 0                | Setting this bit will power down the device (power consumption is ~20 mW). This bit is cleared by PCI reset.                     |
| PME EN State                    | 19    | RO     | 1                | State of PME Enable for this device.                                                                                             |
| Power State                     | 18:17 | RO     | 0                | Indicates the current power state of the device.  00b: D0  01b: D1  02b: D2  03b: D3  This PowerState mirrors the PMSCR register |
| Bond ID                         | 16:13 | RO     | ID 3:0           | Bond ID                                                                                                                          |
| Reserved                        | 12:8  | RO     | 0                | -                                                                                                                                |
| Timer Prescaler                 | 7:1   | RW     | 1111111b         | Local Core clock frequency in MHz, minus 1, which should correspond to each advance of the timer. Reset to all 1.                |
| GRC Reset                       | 0     | RW     | 0                | Write 1 to this bit resets the CORE_CLK blocks in the device. This is a self-clearing bit.                                       |

## 13.34.3 Miscellaneous Local Control Register (offset: 0x6808)

The Miscellaneous Local Control register is used to control various functions within the device. All bits are set to zero (i.e. disabled) during reset.

| Name                     | Bits  | Access | Default<br>Value | Description                                              |
|--------------------------|-------|--------|------------------|----------------------------------------------------------|
| Enable Wake On Link Up   | 31    | RW     | 0                | When set, the chip drives the PME when the link is up.   |
| Enable Wake On Link Down | 30    | RW     | 0                | When set, the chip drives the PME when the link is down. |
| Disable Traffic LED fix  | 29    | RW     | 0                | Set to disable Traffic LED Fix.                          |
| Reserved                 | 28:27 | RO     | 0                | -                                                        |

| Name                    | Bits  | Access | Default<br>Value   | Description                                                                                                                                                                                                                                                                                            |
|-------------------------|-------|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PME Assert              | 26    | RW     | 0                  | When set, the PME Status bit in the PMSCR register is forced high. If PME Enable is also set, the PME signal will activate. This register bit is write-only and self-clearing after write.                                                                                                             |
| Reserved                | 25    | RO     | 0                  | -                                                                                                                                                                                                                                                                                                      |
| Auto SEEPROM Access     | 24    | RW     | 0                  | If set, access to serial EEPROM goes through the serial EEPROM address and data registers. Otherwise, serial EEPROM control register should be used.                                                                                                                                                   |
| APE_GPIO IN(6:0)        | 23:17 | RO     | APE GPIO           | APE GPIO Status                                                                                                                                                                                                                                                                                        |
|                         |       |        | default<br>setting | Holds the value of APE GPIO (6:0) pins                                                                                                                                                                                                                                                                 |
| GPIO(2:0) Output        | 16:14 | RW     | 0                  | Outputs which are defined by board level design.                                                                                                                                                                                                                                                       |
| GPIO(2:0) Output Enable | 13:11 | RW     | 0                  | When asserted, the device drives miscellaneous pin outputs.                                                                                                                                                                                                                                            |
| GPIO(2:0) Input         | 10:8  | RO     | 0                  | Input from bidirectional miscellaneous pin.                                                                                                                                                                                                                                                            |
| GPIO(3) Output          | 7     | RW     | 0                  | GPIO3 Output value.                                                                                                                                                                                                                                                                                    |
| GPIO(3) Output Enable   | 6     | RW     | 0                  | When set to 1, GPIO3 pin will be enabled as an output pin.                                                                                                                                                                                                                                             |
| GPIO(3) Input           | 5     | RW     | 0                  | Input value of GPIO3.                                                                                                                                                                                                                                                                                  |
| Reserved                | 4     | RO     | 0                  | -                                                                                                                                                                                                                                                                                                      |
| Interrupt on Attention  | 3     | RW     | 0                  | If set, the host will be interrupted when any of the attention bits in the CPU event register are asserted.                                                                                                                                                                                            |
| Set Interrupt           | 2     | WO     | 0                  | If Interrupt Mailbox 0 contains a nonzero value, setting this bit does nothing. If Interrupt Mailbox 0 is zero, then setting this bit will cause the internal unmasked interrupt state to be asserted.                                                                                                 |
|                         |       |        |                    | The external interrupt state (INTA pin) will also be asserted immediately if interrupts are not masked by the Mask Interrupts bit. If interrupts are masked, INTA will be asserted once interrupts are unmasked, so long as interrupts are not first cleared. This bit is not operational in MSI mode. |
| Clear Interrupt         | 1     | WO     | 0                  | This bit provides the same functionality as the Clear Interrupt bit in the Miscellaneous Host Control register. This bit is not operational in MSI mode.                                                                                                                                               |
| Interrupt State         | 0     | RO     | 0                  | This bit reflects the state of the PCI INTA pin. This bit is not operational in MSI mode.                                                                                                                                                                                                              |

### 13.34.4 Timer Register (offset: 0x680C)

The Timer register is a 32-bit free-running counter. This counter increments when the Prescale Counter hits the Timer Prescaler limit as specified by the Miscellaneous Configuration register. This counter is used by the CPU to keep track of relative time in microseconds. A write to the Timer register will load the counter value written.

| Name        | Bits |    | Default<br>Value | Description                 |
|-------------|------|----|------------------|-----------------------------|
| Timer Value | 31:0 | RW | 0                | 32-bit free-running counter |

## 13.34.5 RX-CPU Event Register (offset: 0x6810)

| Name                         | Bits | Access | Default<br>Value | Description                                            |
|------------------------------|------|--------|------------------|--------------------------------------------------------|
| SW Event 13                  | 31   | RO     | 0                | SW Event 13 is set; This bit is Flash Attention;       |
| SW Event 12                  | 30   | RO     | 0                | SW Event 12 is set; This bit is VPD Attention          |
| Timer                        | 29   | RW     | 0                | Timer Reference reached                                |
| SW Event 11                  | 28   | RW     | 0                | SW Event 11 is set                                     |
| Flow Attention               | 27   | RO     | 0                | Flow Attention                                         |
| RX CPU Attention             | 26   | RW     | 0                | RX CPU needs attention.                                |
| MAC Attention                | 25   | RO     | 0                | MAC needs attention.                                   |
| Reserved                     | 24   | RO     | 0                | _                                                      |
| SW Event 10                  | 23   | RW     | 0                | SW Event 10 is set.                                    |
| High Priority Mailbox        | 22   | RO     | 0                | First 32 Mailbox registers have been updated.          |
| Low Priority Mailbox         | 21   | RO     | 0                | Last 32 Mailbox registers have been updated.           |
| DMA Attention                | 20   | RO     | 0                | A DMA channel needs attention.                         |
| SW Event 9                   | 19   | RW     | 0                | SW Event 9 is set.                                     |
| High DMA RD                  | 18   | RO     | 0                | High Priority DMA read FTQ has stalled.                |
| High DMA WR                  | 17   | RO     | 0                | High Priority DMA write FTA has stalled.               |
| SW Event 8                   | 16   | RW     | 0                | SW Event 8 is set.                                     |
| Host Coalescing              | 15   | RO     | 0                | The host coalescing FTQ has stalled.                   |
| SW Event 7                   | 14   | RW     | 0                | SW Event 7 is set.                                     |
| Receive Data Comp (Post DMA) | 13   | RO     | 0                | Receive data completion FTQ has stalled.               |
| SW Event 6                   | 12   | RW     | 0                | SW Event 6 is set.                                     |
| RX SW Queue Event            | 11   | RO     | 0                | Receive Software Queue Event.                          |
| DMA RD                       | 10   | RO     | 0                | Normal Priority DMA read FTQ has stalled.              |
| DMA WR                       | 9    | RO     | 0                | Normal Priority DMA write FTQ has stalled.             |
| Read DMA Init (Pre DMA)      | 8    | RO     | 0                | Receive Data and Receive BD Initiator FTQ has stalled. |
| SW Event 5                   | 7    | RW     | 0                | SW Event 5 is set                                      |
| Recv BD Comp                 | 6    | RO     | 0                | Receive BD Completion FTQ has stalled.                 |
| SW Event 4                   | 5    | RW     | 0                | SW Event 4 is set                                      |
| Recv List Selector           | 4    | RO     | 0                | Receive List Selector is nonzero.                      |
| SW Event 3                   | 3    | RW     | 0                | SW Event 3 is set                                      |
| Recv List Placement          | 2    | RO     | 0                | Receive List Placement FTQ has stalled.                |
| SW Event 1                   | 1    | RW     | 0                | SW Event 1 is set                                      |
| SW Event 0                   | 0    | RW     | 0                | SW Event 0 is set                                      |

### 13.34.6 RX-CPU Timer Reference Register (offset: 0x6814)

The Timer Reference register allows the RX-RISC to receive an event when the free-running Timer register counts up to this value.

| Name                   | Bits | Access | Default<br>Value | Description                                                    |
|------------------------|------|--------|------------------|----------------------------------------------------------------|
| RX-CPU Timer Reference | 31:0 | RW     | 0                | RX-RISC Timer Event when time stamp = RX-RISC Timer Reference. |

#### 13.34.7 RX-CPU Semaphore Register (offset: 0x6818)

The RX-RISC Semaphore register allows access to both internal RISC processors to a hardware semaphore mechanism. Writes to the register indicates the preference to toggle the own/not own states of a single semaphore bit. Reads of this register provide a 1 if that register owns the semaphore, and a 0 otherwise. To obtain the semaphore, the normal operation is a loop containing a write 0 followed by a read. Exit the loop when the read returns nonzero. To release the semaphore,

| Name             | Bits |    | Default<br>Value | Description      |
|------------------|------|----|------------------|------------------|
| Reserved         | 31:1 | RO | 0                | -                |
| RX-CPU Semaphore | 0    | RW | 0                | RX-CPU Semaphore |

## 13.35 Serial EEPROM Address Register

This 32-bit register is used by the RISCs in conjunction with the Serial EEPROM Data Register to read and/or write serial EEPROM data. The address register specifies the address and the direction of the transfer. When the transfer is complete (for either a read or a write), the complete bit is set.

To use this register pair to read the serial EEPROM, set the address and ensure the read/write bit is set in the address register. Loop reading the address register until the complete bit is set. When it is read the data from the data register. Clear the complete bit by writing the bit. No other transfer will occur when the complete bit is set. The Device ID must be programmed to select the appropriate device (A2 must be 0 for 128K/256Kx8 device).

To use this register pair to write the serial EEPROM, place the data into the data register. Then write the address into the address register ensuring that the write bit is clear. Loop reading the address register until the complete bit is set. When it is, the write is complete. Clear the complete bit by writing the bit. No other transfer will occur when the complete bit is set. It is the responsibility of software to control the timing between successive read/write access to the serial EEPROM.

All registers reset are core reset unless specified.

#### 13.35.1 Serial EEPROM Delay Register (offset: 0x6848)

This 32-bit RW register specifies the delay between the EEPROM access in 15 ns interval and is used for VPD access. Since the requirement of back-to-back write for Serial EEPROMs is 10ms, firmware currently programs this register to 0xA2C2A.

#### 13.35.2 RX CPU Event Enable Register (offset: 0x684C)

Setting a bit in this register enables an interrupt to the CPU or the Event.

| Name                    | Bits | Access | Default<br>Value | Description                           |
|-------------------------|------|--------|------------------|---------------------------------------|
| Flash                   | 31   | RW     | 0                | -                                     |
| VPD                     | 30   | RW     | 0                | -                                     |
| Timer Reference Reached | 29   | RW     | 0                | -                                     |
| ROM                     | 28   | RW     | 0                | -                                     |
| HC Module               | 27   | RW     | 0                | -                                     |
| RX CPU Module           | 26   | RW     | 0                | -                                     |
| EMAC Module             | 25   | RW     | 0                | -                                     |
| Memory Map Enable Bit   | 24   | RW     | 0                | Set by hardware, cleared by software. |
| Reserved                | 23   | RW     | 0                | -                                     |
| High Priority Mailbox   | 22   | RW     | 0                | -                                     |
| Low Priority Mailbox    | 21   | RW     | 0                | -                                     |
| DMA                     | 20   | RW     | 0                | _                                     |
| Reserved                | 19   | RW     | 0                | -                                     |
| Reserved                | 18   | RW     | 0                | -                                     |
| Reserved                | 17   | RW     | 0                | -                                     |
| ASF Location 15         | 16   | RW     | 0                | -                                     |
| TPM Interrupt Enable    | 15   | RW     | 0                | -                                     |
| ASF Location 14         | 14   | RW     | 0                | -                                     |
| Reserved                | 13   | RW     | 0                | -                                     |

| Name                        | Bits | Access | Default<br>Value | Description |
|-----------------------------|------|--------|------------------|-------------|
| ASF Location 13             | 12   | RW     | 0                | -           |
| Unused SDI                  | 11   | RW     | 0                | -           |
| SDC (Post TCP segmentation) | 10   | RW     | 0                | -           |
| SDI (Pre TCP segmentation)  | 9    | RW     | 0                | -           |
| RDIQ FTQ (Received an ASF)  | 8    | RW     | 0                | -           |
| ASF Location 12             | 7    | RW     | 0                | -           |
| Reserved                    | 6    | RW     | 0                | -           |
| ASF Location 11             | 5    | RW     | 0                | -           |
| Reserved                    | 4    | RW     | 0                | _           |
| ASF Location 10             | 3    | RW     | 0                | -           |
| Reserved                    | 2    | RW     | 0                | -           |
| ASF Location 9              | 1    | RW     | 0                | -           |
| ASF Location 8              | 0    | RW     | 0                | _           |

# 13.36 Miscellaneous Control Registers

## 13.36.1 Miscellaneous Control Register (offset: 0x6890)

| Name              | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                      |
|-------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved          | 31    | RW     | 0                | -                                                                                                                                                                                                                                                                                                |
| Cq14161_fix_ena_n | 30    | RW     | 0                | This bit, when clear, enables the CQ14161 fix where the proper Bus Number & Device Number are returned in the completion prior to the initial Configuration Write Request.  0: Enable Fix  1: Disable Fix  This bit is reset by Hard_Reset (POR, Exit Low Power mode, Lost of Vmain while in D0) |
| Reserved          | 29:25 | RW     | 0                | -                                                                                                                                                                                                                                                                                                |
| MISC2 Bit         | 24    | RW     | 0                | Reserved RW bit that gets reset by Power-On-Reset.                                                                                                                                                                                                                                               |
| MISC 1 Bits       | 23:1  | RW     | 0                | Reserved RW bits that get reset by GRC Reset.                                                                                                                                                                                                                                                    |
| Reserved          | 0     | RO     | 0                | -                                                                                                                                                                                                                                                                                                |

# 13.36.2 Fast Boot Program Counter Register (offset: 0x6894)

| Name                     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fastboot Enable          | 31   | RW     | 0                | This bit is used by the CPU to keep track of whether or not there is valid phase 1 boot code stored in the RX MBUF. If the bit is set, then RXMBUF contains valid boot code. Otherwise, it is assumed that RXMBUF does not contain valid boot code. This bit is reset only by a power-on reset. The state of this bit has no effect on state machines within the device. It is used by the CPU to track boot codestatus. |
| Fastboot Program Counter | 30:0 | RW     | 0                | This field is used by the CPU to keep track of the location of the phase 1 boot code in RX MBUF. These bits behave identical to bit 31 in that they have no effect on state machine operation and they are cleared only by a power-on reset.                                                                                                                                                                             |

# 13.36.3 Power Management Debug Register (offset: 0x68A4)

Some of the bit in this register is initialized by hard\_reset and GRC Reset.

| Name                                 | Bits  | Access | Default<br>Value | Description                                                                                                                    |  |  |
|--------------------------------------|-------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|
| Powerdown Restart PCIE PLL<br>Enable | 31    | RW     | 0                | 1: Enable restart PCIE PLL when PCIE PLL is locked up in the powerdown mode, or IDDQ mode, or during POR, or any combinations. |  |  |
|                                      |       |        |                  | 0: Disable restart PCIE PLL in powerdown mode.                                                                                 |  |  |
|                                      |       |        |                  | This bit is NOT Self-Clear. Software need to generate a pulse by writing a 1 followed by 0 in order to restart the PLL.        |  |  |
|                                      |       |        |                  | It's for debug purpose.                                                                                                        |  |  |
| Normal Restart PCIE PLL Enable       | 30    | RW     | 0                | 1: Enable restart PCIE PLL in normal mode. Firmware needs to write 1 and then write 0 to restart it (pulse restart).           |  |  |
|                                      |       |        |                  | 0: Disable restart PCIE PLL in normal mode.                                                                                    |  |  |
|                                      |       |        |                  | This bit is NOT Self-Clear. Software need to generate a pulse by writing a 1 followed by 0 in order to restart the PLL.        |  |  |
|                                      |       |        |                  | It's for debugging purposes.                                                                                                   |  |  |
| Select Core Clock Override           | 29    | RW     | 0                | 1: Enable switching of core clock to be used for PCIE block clocks.                                                            |  |  |
|                                      |       |        |                  | 0: Disable switching of core clock to be used for PCIE block clocks.                                                           |  |  |
|                                      |       |        |                  | This bit is the same as bit 16 in the PCIE Data Link Layer Register 0x7D00.                                                    |  |  |
| Reserved                             | 28:18 | RO     | 0                | -                                                                                                                              |  |  |
| Reserved                             | 17    | RW     | 0                | _                                                                                                                              |  |  |
| PERST Override                       | 16    | RW     | 0                | This bit is used to override the PERSTN so that the internal CPU can access the PCIE register when Perstn is asserted.         |  |  |
|                                      |       |        |                  | 1: Override Perstn Reset                                                                                                       |  |  |
|                                      |       |        |                  | 0: No Override                                                                                                                 |  |  |
|                                      |       |        |                  | Reset by Hard Reset                                                                                                            |  |  |
| Reserved                             | 15:10 | RO     | 0                | _                                                                                                                              |  |  |
| irefselo                             | 9     | RO     | X                | PCIE Reference Select.                                                                                                         |  |  |
|                                      |       |        |                  | 0: PCIE 100 MHz Reference Clock                                                                                                |  |  |
|                                      |       |        |                  | 1: Local 25 MHz Crystal                                                                                                        |  |  |
| irxFastAcq                           | 8     | RO     | X                | PCIE PLL Fast Acquisition Select.                                                                                              |  |  |
|                                      |       |        |                  | 0: Disable Fast Acquisition                                                                                                    |  |  |
|                                      |       |        |                  | 1: Enable Fast Acquisition                                                                                                     |  |  |
| irxSeqStart                          | 7     | RO     | X                | PCIE RX Sequence Start                                                                                                         |  |  |
| ipllSeqStart                         | 6     | RO     | X                | PCIE PLL Sequence Start                                                                                                        |  |  |
| irxpowerdown                         | 5     | RO     | X                | RX Power Down Status                                                                                                           |  |  |
| itxpowerdown                         | 4     | RO     | X                | TX Power Down Status                                                                                                           |  |  |
| ipllpowerdown                        | 3     | RO     | X                | PLL Power Down Status                                                                                                          |  |  |
| Iclkreq_oe_I                         | 2     | RO     | X                | Clock Request Output Enable                                                                                                    |  |  |
| obsvElecIdle                         | 1     | RO     | Х                | Observe Electrical Idle Status                                                                                                 |  |  |
| PLLisUp                              | 0     | RO     | X                | PCIE PLL Status                                                                                                                |  |  |

## 13.36.4 5755ME Miscellaneous Control Register (offset: 0x68B0)

| Name                | Bits  | Access | Default<br>Value | Description                                                                                                                                                 |
|---------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved            | 31:19 | RW     | X                | _                                                                                                                                                           |
| EMAC Legacy Bug Fix | 18    | RW     | 0                | This bit when set enable the EMAC to receive packet without dropping it after receiving a short invalid packet size.  1: Enable Bug Fix  0: Disable Bug Fix |
| Reserved            | 17:0  | RW     | Χ                | -                                                                                                                                                           |

## 13.36.5 Memory TM control1 (offset: 0x68E0)

| Name                       | Bits  | Access | Default<br>Value | Description                |
|----------------------------|-------|--------|------------------|----------------------------|
| Reserved                   | 31:24 | RW     | 0x0              | _                          |
| Memory TM control retrybuf | 23:16 | RW     | 0x00             | TM control of retry buffer |
| Memory TM control txmbuf   | 15:8  | RW     | 0x00             | TM control for txmbuf      |
| Memory TM control rxmbuf   | 7:0   | RW     | 0x00             | TM control for rxmbuf      |

## 13.36.6 Memory TM control 2 (offset: 0x68E4)

| Name               | Bits  | Access | Default<br>Value | Description                             |
|--------------------|-------|--------|------------------|-----------------------------------------|
| Reserved           | 31:29 | RW     | 0x0              | -                                       |
| APE ROM tm         | 28:24 | RW     | 0x0              | TM control for APE ROM (mac0 only).     |
| APE SCPAD2 mem tm  | 23:20 | RW     | 0x0              | TM control for APE SCPAD 0 (mac0 only). |
| APE SCPAD1 mem tm  | 19:16 | RW     | 0x0              | TM control for APE SCPAD 0 (mac0 only). |
| APE SCPAD0 mem tm  | 15:12 | RW     | 0x0              | TM control for APE SCPAD 0 (mac0 only). |
| APE ARB mem tm     | 11:10 | RW     | 0x0              | TM control for APE ARB.                 |
| APE ATB mem tm     | 9:8   | RW     | 0x0              | TM control for APE ATB.                 |
| APE shared mem tmb | 7:4   | RW     | 0x0              | TMb control for APE shared mem.         |
| APE shared mem tma | 3:0   | RW     | 0x0              | TMa control for APE shared mem.         |

## 13.36.7 Mem TM control 3(offset: 0x68E8)

| Name                         | Bits | Access | Default<br>Value | Description               |
|------------------------------|------|--------|------------------|---------------------------|
| Reserved                     | 31:9 | RW     | 0x0              | -                         |
| Memory TM control boot rom   | 8:4  | RW     | 0x00             | TM control for rom        |
| Memory TM control scratchpad | 3:0  | RW     | 0x00             | TM control for scratchpad |

## 13.36.8 Expansion ROM Address Register (offset: 0x68EC)

| Name                       | Bits  | Access | Default<br>Value | Description                                              |
|----------------------------|-------|--------|------------------|----------------------------------------------------------|
| Expansion ROM Test bits    | 31:24 | RW     | 0                | Reserved–keep at 0 for normal operation.                 |
| Expansion ROM base address | 23:0  | RW     | 0                | Expansion ROM base address, expect to be d-word aligned. |

### 13.36.9 BCM5719/BCM5720 Registers

The registers in this section are available only for the BCM5719 and BCM5720.

#### 13.36.9.1 Mem TM Control 4 (offset: 0x68F8)

| Name                                 | Bits  | Access | Default<br>Value | Description                                    |
|--------------------------------------|-------|--------|------------------|------------------------------------------------|
| Reserved                             | 31:28 | RW     | 0x0              | Reserved                                       |
| WDMA FIFO tmb control                | 27:26 | RW     | 0x00             | TM control for WDMA engine memory.             |
| WDMA FIFO tma control                | 25:24 | RW     | 0x00             | TM control for WDMA engine memory.             |
| Non-LSO Ch3 RDMA<br>FIFO tmb control | 23:22 | RW     | 0x00             | TM control for Ch3 non-LSO RDMA engine memory. |
| Non-LSO Ch3 RDMA<br>FIFO tma control | 21:20 | RW     | 0x00             | TM control for Ch3 non-LSO RDMA engine memory. |
| Non-LSO Ch2 RDMA<br>FIFO tmb control | 19:18 | RW     | 0x00             | TM control for Ch2 non-LSO RDMA engine memory. |
| Non-LSO Ch2 RDMA<br>FIFO tma control | 17:16 | RW     | 0x00             | TM control for Ch2 non-LSO RDMA engine memory. |
| Non-LSO Ch1 RDMA<br>FIFO tmb control | 15:14 | RW     | 0x00             | TM control for Ch1 non-LSO RDMA engine memory. |
| Non-LSO Ch1 RDMA<br>FIFO tma control | 13:12 | RW     | 0x00             | TM control for Ch1 non-LSO RDMA engine memory. |
| Non-LSO Ch0 RDMA<br>FIFO tmb control | 11:10 | RW     | 0x00             | TM control for Ch0 non-LSO RDMA engine memory. |
| Non-LSO Ch0 RDMA<br>FIFO tma control | 9:8   | RW     | 0x00             | TM control for Ch0 non-LSO RDMA engine memory. |
| BD RDMA FIFO tmb control             | 7:6   | RW     | 0x00             | TM control for BD RDMA engine memory.          |
| BD RDMA FIFO tma control             | 5:4   | RW     | 0x00             | TM control for BD RDMA engine memory.          |
| LSO RDMA FIFO tmb control            | 3:2   | RW     | 0x00             | TM control for LSO RDMA engine.                |
| LSO RDMA FIFO tma control            | 1:0   | RW     | 0x00             | TM control for LSO RDMA engine.                |

#### 13.36.9.2 TPH Hint Register (Offset: 0x68FC)

This register can enable TLP Hint assertion and Processing Hint on each Host Bound DMA transaction classes individually.

| Name                     |           | Bits  | Acces | Default<br>Value | Description |
|--------------------------|-----------|-------|-------|------------------|-------------|
| Reserved                 |           | 31:28 | RW    | 0                | -           |
| MSI/MSI-X Vector Write   | Resvd     | 27    | RW0   | 0                | -           |
|                          | PH Value  | 26:25 | RW    | 10               | _           |
|                          | TH Enable | 24    | RW    | 0                | -           |
| Status Block Write       | Resvd     | 23    | RW    | 0                | -           |
|                          | PH Value  | 22:21 | RW    | 10               | _           |
|                          | TH Enable | 20    | RW    | 0                | -           |
| Receive Return BD Write  | Resvd     | 19    | RW    | 0                | -           |
|                          | PH Value  | 18:17 | RW    | 10               | -           |
|                          | TH Enable | 16    | RW    | 0                | -           |
| Packet Data Write        | Resvd     | 15    | RW    | 0                | -           |
|                          | PH Value  | 14:13 | RW    | 10               | _           |
|                          | TH Enable | 12    | RW    | 0                | -           |
| Receive Producer BD Read | Resvd     | 11    | RW    | 0                | -           |
|                          | PH Value  | 10:9  | RW    | 10               | -           |
|                          | TH Enable | 8     | RW    | 0                | -           |
| Send BD Read             | Resvd     | 7     | RW    | 0                | -           |
|                          | PH Value  | 6:5   | RW    | 10               | -           |
|                          | TH Enable | 4     | RW    | 0                | -           |
| Packet Data Read         | Resvd     | 3     | RW    | 0                | _           |
|                          | PH Value  | 2:1   | RW    | 10               | -           |
|                          | TH Enable | 0     | RW    | 0                | _           |

#### 13.36.9.3 EAV Ref Count Capture LSB Reg (offset: 0x6900)

The MSB and LSB registers are interface to the actual EAV Ref Counter hardware. The Counter value may be read via this pair anytime and even be overwritten by this pair anytime. While reading the pair, the hardware Counter does not stop, only its value is latched in this pair.

The only two legal sequences of accessing this pair is Read-LSB followed by Read-MSB and Write-LSB followed by Write-MSB.

| Name                             | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                   |
|----------------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAV Reference Count [lower half] | 31:3 | RW     | UUUU             | LSB of the EAV Reference Count–Reading this LSB latches a Count in this pair until the time the corresponding MSB is read.  Writing to this LSB latches the value in this pair and the subsequent write to the MSB transfers the 64-bit value to EAV Ref Counter and counting immediately resumes from there. |
| Reserved                         | 2:0  | RO     | 000              | [2:0] shall always be 000                                                                                                                                                                                                                                                                                     |

#### 13.36.9.4 EAV Ref Count Capture MSB Reg (offset: 0x6904)

| Name                | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                        |
|---------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAV Reference Count | 31:0 | RW     | UUUU             | MSB of the EAV Reference Count–See the pairing LSB register.                                                                                                                                                                                                                                                       |
| [Upper half]        |      |        |                  | Reading this register returns the MSB of the 64-bit EAV Ref count previously latched by performing an LSB read.  Writing to this MSB transfers the 64-bit value, this plus previously latched LSB, to EAV Ref Counter and counting immediately resumes from there.  Back to back writes to this MSB has no effect. |

#### 13.36.9.5 EAV Ref Clock Control Reg (offset: 0x6908)

This register controls the EAV Reference Counter and the TimeSync related GPIO pins. Each MAC's 1588 hardware owns a dedicated TimeSync\_GPIO pin which may be connected to any of its four Snap-shot/WatchDog hardware logic. If a MAC needs to use more pins beyond its TimeSync\_GPIO pin, it may use any or all of the four APE\_GPIO[3:0] pins. Note that these pins are shared among APE hardware and four MAC-1588 hardware. Therefore, a platform must design-in these pins and have individual BootCode or firmware configure this register and APE-GPIO register accordingly.

**NOTE:** Hardware behavior shall be indeterminate in case of conflicting or duplicate assignment of GPIO pins to the same resource. A platform MUST allocate its dedicated TimeSync\_GPIO pin first before using any pin from APE\_GPIO shared pool.

| Name                             | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                              |
|----------------------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                         | 31:30 | RO     | 00               | -                                                                                                                                                                                                                                                                                                        |
| APE_GPIO[3] Mapping              | 29:27 | RW     | 000              | Same as below.                                                                                                                                                                                                                                                                                           |
| APE_GPIO[2] Mapping              | 26:24 | RW     | 000              | Same as below.                                                                                                                                                                                                                                                                                           |
| APE_GPIO[1] Mapping              | 23:21 | RW     | 000              | Same as below.                                                                                                                                                                                                                                                                                           |
| APE_GPIO[0] Mapping              | 20:18 | RW     | 000              | An APE_GPIO[n] pin is mapped to 1588 input/output via this field:  000 => Do not use APE_GPIO[n] pin  001 => Reserved  010 => Reserved  100 => Use as Snap-Shot[0] Input Trigger  101 => Use as Snap-Shot[1] Input Trigger  110 => Use as Time Watchdog[0] Output  111 => Use as Time Watchdog[1] Output |
| TimeSync_GPIO Mapping            | 17:16 | RW     | 00               | The MAC/Port dedicated TimeSync_GPIO pin is mapped via this field:  00 => Use as Snap-Shot[0] Input Trigger  01 => Use as Snap-Shot[1] Input Trigger  10 => Use as Time Watchdog[0] Output  11 => Use as Time Watchdog[1] Output                                                                         |
| Reserved                         | 15:12 | RO     | 0x0              | -                                                                                                                                                                                                                                                                                                        |
| Reset on Network Link Down -> Up | 11    | RW     | 0                | _                                                                                                                                                                                                                                                                                                        |
| Reset on Network Link Up -> Down | 10    | RW     | 0                | _                                                                                                                                                                                                                                                                                                        |

| Name                          | Bits | Access | Default<br>Value | Description                               |
|-------------------------------|------|--------|------------------|-------------------------------------------|
| Reset on GRC Reset & PCIe FLR | 9    | RW     | 0                | Reset on GRC Reset pulse.                 |
| Reset on PCIe reset           | 8    | RW     | 0                | Reset on de-asserting edge of PCIe Reset. |
| Reserved                      | 7:3  | RO     | 0x0              | -                                         |
| Resume EAV Ref Count          | 2    | W1C    | 0                | -                                         |
| Stop EAV Ref Count            | 1    | RW     | 0                | -                                         |
| Reset EAV Ref Count           | 0    | W1C    | 0                | _                                         |

#### 13.36.9.6 EAV Ref Count Snapshot LSB[0] Reg (offset 0x6910)

This LSB & MSB pair captures the EAV Reference Count when externally triggered by the desired TimeSync/APE\_GPIO pin—a toggle serves a trigger. The only legal sequence of accessing this pair is Read-LSB followed by Read-MSB.

| Name                                      | Bits |    | Default<br>Value | Description                                                      |
|-------------------------------------------|------|----|------------------|------------------------------------------------------------------|
| EAV Reference Count Snapshot (lower half) | 31:0 | RO | U                | LSB of the EAV Reference Count as snapshot by Timesync/APE GPIO. |
|                                           |      |    |                  | [2:0] shall always be 000                                        |

#### 13.36.9.7 EAV Ref Count Snapshot MSB[0] Reg (offset: 0x6914)

| Name                      | Bits |    | Default<br>Value | Description                                                |
|---------------------------|------|----|------------------|------------------------------------------------------------|
| EAV Reference Count Snap- | 31:0 | RO | U                | MSB of the EAV Reference Count as snapshot by TimeSync/APE |
| shot (Upper half)         |      |    |                  | GPIO.                                                      |

#### 13.36.9.8 TX Time Watchdog LSB[0] Reg (offset: 0x6918)

| Name               | Bits |    | Default<br>Value | Description                                         |
|--------------------|------|----|------------------|-----------------------------------------------------|
| Watchdog LSB Value | 31:0 | RW | 0x0000           | See "TX Time Watchdog MSB[0] Reg (offset: 0x691C)". |

### 13.36.9.9 TX Time Watchdog MSB[0] Reg (offset: 0x691C)

| Name               | Bits | Access | Default<br>Value | Description                                                                                                                                                             |
|--------------------|------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable Lock Timer  | 31   | RW     | 0                | Write a 1 to enable Time Watchdog[0].                                                                                                                                   |
| Watchdog MSB Value | 30:0 | RW     | 0x00             | This, concatenated with the Watchdog[0] LSB value, constitutes a 63-bit value. Precision of the value is 1ns—which equates to the precision of the EAV Reference Count. |
|                    |      |        |                  | If bit[31] ==1, the desired Timesync/APE GPIO shall toggle as soon as EAV Reference Count[62:0] increments to match this 63-bit value.                                  |
|                    |      |        |                  | Setting this time value back in time will produce no toggle.                                                                                                            |

#### 13.36.9.10 TX Time Watchdog LSB[1] Reg (offset: 0x6920)

| Name               | Bits |    | Default<br>Value | Description                                                     |
|--------------------|------|----|------------------|-----------------------------------------------------------------|
| Watchdog LSB Value | 31:0 | RW | 0x0000           | See "TX Time Watchdog MSB[1] Reg (offset: 0x6924)" on page 431. |

#### 13.36.9.11 TX Time Watchdog MSB[1] Reg (offset: 0x6924)

| Name               | Bits | Access | Default<br>Value | Description                                                                                                                                                              |
|--------------------|------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable Lock Timer  | 31   | RW     | 0                | Write a 1 to enable Time Watchdog[0].                                                                                                                                    |
| Watchdog MSB Value | 30:0 | RW     | 0x00             | This, concatenated with the Watchdog[0] LSB value, constitutes a 63-bit value. Precision of the value is 1ns, which equates to the precision of the EAV Reference Count. |
|                    |      |        |                  | If bit[31] ==1, the required Timesync/APE GPIO toggles as soon as EAV Reference Count[62:0] increments to match this 63-bit value.                                       |
|                    |      |        |                  | Setting this time value back in time produces no toggle.                                                                                                                 |

#### 13.36.9.12 EAV Ref Corrector Reg [Offset 0x6928)

| Name              | Bits  | Access | Default<br>Value | Description                                                                                                                                                          |
|-------------------|-------|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Correction Enable | 31    | RW     | 0                | Write a 1 to Enable the Correction feature.                                                                                                                          |
| Correction Sense  | 30    | RW     | 0                | If 0, the correction is an addition.                                                                                                                                 |
|                   |       |        |                  | If 1, the correction is a subtraction.                                                                                                                               |
| Reserved          | 29:24 | RO     | 0x00             | Reserved                                                                                                                                                             |
| Correction Value  | 23:0  | RW     | 0x000001         | This value is accumulated in an accumulator every EAV REF CLK tick until it overflows–upon which the EAV REF COUNT is corrected by a 8ns unit & the acc is reloaded. |
|                   |       |        |                  | A 0x0 value is not permissible.                                                                                                                                      |

#### 13.36.9.13 EAV Ref Count Snapshot LSB[1] Reg (Offset 0x6930)

This LSB & MSB pair captures the EAV Reference Count when externally triggered by the desired TimeSync/APE\_GPIO pin; a toggle serves a trigger. The only legal sequence of accessing this pair is Read-LSB followed by Read-MSB.

| Name                      | Bits | Access | Default<br>Value | Description                                             |
|---------------------------|------|--------|------------------|---------------------------------------------------------|
| EAV Reference Count Snap- | 31:0 | RO     | U                | LSB of the EAV Reference Count as snapshot by TimeSync/ |
| shot                      |      |        |                  | APE_GPIO.                                               |
| [lower half]              |      |        |                  | [2:0] shall always be 000                               |

## 13.36.9.14 EAV Ref Count Snapshot MSB[1] Reg [Offset 0x6934]

| Name                      | Bits | Access | Default<br>Value | Description                                              |
|---------------------------|------|--------|------------------|----------------------------------------------------------|
| EAV Reference Count Snap- | 31:0 | RO     | U                | MSB of the EAV Reference Count as snap-shot by TimeSync/ |
| shot                      |      |        |                  | APE_GPIO.                                                |
| [Upper half]              |      |        |                  |                                                          |

# 13.37 Non-Volatile Memory (NVM) Interface Registers

## 13.37.1 NVM Command Register (0x7000)

| Name                              | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                   |
|-----------------------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Policy Error                      | 31:28 | RO     | 0                | Reports Address Lockout Policy Error violations                                                                                                                                                                                                                               |
| Atmel page size setting           | 27    | RO     | 0                | ·                                                                                                                                                                                                                                                                             |
| Reserved                          | 26:20 | RO     | 0                | -                                                                                                                                                                                                                                                                             |
| Reserved-WRSR                     | 19    | RO     | 0                | The write status register command bit. Set '1' will make the flash interface state machine generate wrsr_comd (0x1) to the flash device to set the status register of the flash device to be written with sr data. For SST25VF512 only.                                       |
| Reserved-EWSR                     | 18    | RO     | 0                | The enable write status register command bit. Set '1' will make the flash interface state machine generate ewsr_cmd (0x50) to the flash device to set the status register for the flash device to be write enabled. For SST25VF512 only.                                      |
| Reserved–Write Disable<br>Command | 17    | RO     | 0                | The write disable command bit. Set '1' will make the flash interface state machine generate a write disable command cycle to the flash device to clear the write enable bit in the device status register. This command is used for devices with a write protection function. |
| Reserved–Write Enable<br>Command  | 16    | RO     | 0                | The write enable command bit. Set '1' will make the flash interface state machine generate a write enable command cycle to the flash device to set the write enable bit in the device status register. This command is used for devices with a write protection function.     |
| Reserved                          | 15:11 | RO     | 0                | -                                                                                                                                                                                                                                                                             |
| Atmel power of 2 page size config | 10    | RW     | 0                | Program the page size of Atmel D device to be power of 2. Please note, a power cycle must be issued for this configuration to take effect                                                                                                                                     |
| Atmel page size read              | 9     | RW     | 0                | Read Atmel page size setting, the result is posted in bit 27 of the command register. Please note, issuing this command will effect the content of the read register (0x7010)                                                                                                 |
| Last                              | 8     | RW     | 0                | When this bit is set, the next command sequence is interpreted as<br>the last one of a burst and any cleanup work is done. This means<br>that the buffer is written to flash memory if needed on a write                                                                      |
| First                             | 7     | RW     | 0                | This bit is passed to the SEE_FSM or SPI_FSM if the pass_mode bit is set                                                                                                                                                                                                      |
| Erase                             | 6     | RW     | 0                | The erase command bit.  Set high to execute an erase. This bit is ignored if the wr is clear.                                                                                                                                                                                 |
| Wr                                | 5     | RW     | 0                | The write/not read command bit. Set to execute write or erase.                                                                                                                                                                                                                |
| Doit                              | 4     | RW     | 0                | Command from software to start the defined command. The done bit must be clear before setting this bit. This bit is self clearing and will remain set while the command is active.                                                                                            |
| Done                              | 3     | WTC    | 0                | Sequence completion bit that is asserted when the command requested by assertion of the doit bit has completed.                                                                                                                                                               |
|                                   |       |        |                  | The done bit will be cleared while the command is in progress. The done bit will stay asserted until doit is reasserted or the done bit is cleared by writing a 1 to the done bit. The done bit is the FLSH_ATTN signal.                                                      |

| Name     | Bits | Access | Default<br>Value | Description                                                                 |
|----------|------|--------|------------------|-----------------------------------------------------------------------------|
| Reserved | 2:1  | RO     | 0                | _                                                                           |
| Reset    | 0    | RW     |                  | When set, the entire NVM state machine is reset. This bit is self clearing. |

#### 13.37.2 NVM Write Register (offset: 0x7008)

| Name       | Bits | Access | Default<br>Value | Description                                                     |
|------------|------|--------|------------------|-----------------------------------------------------------------|
| Write Data | 31:0 | RW     | 0                | 32bits of write data are used when write commands are executed. |

#### 13.37.3 NVM Address Register (offset: 0x700C)

| Name     | Bits  |    | Default<br>Value | Description                                                                |
|----------|-------|----|------------------|----------------------------------------------------------------------------|
| Reserved | 31:24 | RO | 0                | -                                                                          |
| Address  | 23:0  | RW | 0                | The 24 bit address for a read or write operation (must be 4 byte aligned). |

#### 13.37.4 NVM Read Register (offset: 0x7010)

| Name      | Bits | Access | Default<br>Value | Description                                                   |
|-----------|------|--------|------------------|---------------------------------------------------------------|
| Read Data | 31:0 | RO     | 0                | 32bits of read data are used when read commands are executed. |

#### 13.37.5 NVM Config 1 Register (offset: 0x7014)

| Name               | Bits  | Access                           | Default Value | Description                                                                                                                                                                                                                                                                                                             |
|--------------------|-------|----------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SEE_CLK_DIV Enable | 31    | 0                                | RW            | This bit enables 0x7014[21:11] as the SEE_CLK_DIV count for EPROM clock generation.                                                                                                                                                                                                                                     |
|                    |       |                                  |               | 1 = Enable                                                                                                                                                                                                                                                                                                              |
|                    |       |                                  |               | 0 = Disable                                                                                                                                                                                                                                                                                                             |
| Page Size          | 30:28 | Depends<br>on flash<br>strapping | RW            | These bits indicate the page size of the attached flash device. They are set automatically depending on the chosen flash as indicated by the strapping option pins.  Page sizes are as follows:  000b: 256 bytes  001b: 512 bytes  010b: 1024 bytes  011b: 2048 bytes  100b: 4096 bytes  110b: reserved  111b: reserved |
| Reserved           | 27    | RO                               |               | _                                                                                                                                                                                                                                                                                                                       |

| Name                     | Bits  | Access | Default Value         | Description                                                                                                                                                                                     |
|--------------------------|-------|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved–Safe Erase      | 26    | RO     | 0                     | _                                                                                                                                                                                               |
| Flash Size-strap bit 3   | 25    | RO     | Pin                   | -                                                                                                                                                                                               |
| Protect Mode-strap bit 2 | 24    | RO     | pin                   | _                                                                                                                                                                                               |
| Strap bit 5              | 23    | RO     | pin                   | _                                                                                                                                                                                               |
| Strap bit 4              | 22    | RO     | pin                   | -                                                                                                                                                                                               |
| SEE_CLK_DIV              | 21:11 | RW     | 16                    | This field is a divisor used to create all 1x times for all SEEPROM interface I/O pin timing definitions. A value of 0 means that an SCL transitions at a minimum of each CORE_CLK rising edge. |
|                          |       |        |                       | The equation to calculate the clock freq. for SCL is:                                                                                                                                           |
|                          |       |        |                       | CORE_CLK / ((SEE_CLK_DIV + 1) * 4)                                                                                                                                                              |
| SPI_CLK_DIV              | 10:7  | RW     | 4                     | This field is a divisor used to create all 1x times for all Flash interface I/O pin timing definitions. A divisor of 0 means that an SCK transitions at a minimum of each CORE_CLK rising edge. |
|                          |       |        |                       | The equation to calculate the clock freq. for SCK is:                                                                                                                                           |
|                          |       |        |                       | CORE_CLK / ((SPI_CLK_DIV + 1) * 2)                                                                                                                                                              |
| Status                   | 6:4   | RW     | 0 if flash_<br>mode.  | This field represents the bit offset in the status command response to interpret as the ready flag.                                                                                             |
|                          |       |        | 7 if buffer_<br>mode. |                                                                                                                                                                                                 |
|                          |       |        | X other-wise          |                                                                                                                                                                                                 |
| Reserved-Bitbang mode    | 3     | RO     | 0                     | _                                                                                                                                                                                               |
| Reserved-Pass mode       | 2     | RO     | 0                     | -                                                                                                                                                                                               |
| Buffer mode              | 1     | RW     | Pin                   | Enable SSRAM Buffered Interface mode.                                                                                                                                                           |
| Flash mode               | 0     | RW     | Pin                   | Enable Flash Interface mode.                                                                                                                                                                    |

## 13.37.6 NVM Config 2 Register (offset: 0x7018)

This register is reset by POR only.

| Name           | Bits  | Access | Default Value                                                | Description                                                                                                                                     |
|----------------|-------|--------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved       | 31:24 | RO     | 0                                                            | -                                                                                                                                               |
| Status Command | 23:16 | RW     | 0x05 if pin strap = ST<br>0xD7 if pin strap =<br>Atmel       | This is the Flash status register read command.                                                                                                 |
| Dummy          | 15:8  | RW     | X                                                            | -                                                                                                                                               |
| Erase Command  | 7:0   | RW     | 0x81 if pin strap =<br>Atmel<br>0xDB if pin strap =<br>STMxx | This is the Flash page erase command. <b>NOTE:</b> ST25xx does not support page erase, therefore the corresponding command is for sector erase. |

#### 13.37.7 NVM Config 3 Register (offset: 0x701C)

This register is reset by POR only.

| Name                            | Bits  | Access | Default Value                                                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------|-------|--------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read Command                    | 31:24 | RW     | 0x0B if AT26DFXX<br>0xE8 if AT45DBXX<br>non D<br>0x03 if AT45DBXX D<br>0x03 if STM25PEXX<br>0x03 if STM45PEXX | This is the Flash/SEEPROM read command. Following this command, any number of bytes may be read up to the end of the flash memory. For SEEPROM (flash mode = 0), this is SEEPROM read command. Bits(26:25) are address bits A1 and A0 of SEEPROM. User should modify those two bits based on the value of A1 and                                                                                                                                       |
| Reserved–Buffer Write Command   | 23:16 | RO     | 0                                                                                                             | A0 assigned to this SEEPROM device.  -                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Write Command                   | 15:8  | RW     | 0x82 if AT26DFXX<br>0x82 if AT45DBXX<br>0x0A if STM25PEXX<br>0x0A if STM45PEXX                                | Command to write a series of bytes into a selected page in the Flash device. Note: this write command wraps around to the beginning of the page after the internal address counter in the Flash device reaches the end of the page.  For SEEPROM (flash_mode = 0), this is SEEPROM write command. Bits[10:9] are address bits A1 and A0 of SEEPROM. User should modify those two bits based on the value of A1 and A0 assigned to this SEEPROM device. |
| Reserved–Buffer Read<br>Command | 7:0   | RO     | 0                                                                                                             | _                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 13.37.8 Software Arbitration Register (offset: 0x7020)

With this Flash Controller, software entity must win arbitration before accessing the NVRAM.

| Name     | Bits  | Access | Default<br>Value | Description                                          |
|----------|-------|--------|------------------|------------------------------------------------------|
| Reserved | 31:24 | RO     | 0                | -                                                    |
| REQ5     | 23    | RO     | 0                | Software request bit 5.                              |
|          |       |        |                  | 1 in this bit indicates that the request5 is active. |
| ARB_WON5 | 22    | RO     | 0                | Arbitration won bit 5 (see bit 8, ARB_WON0).         |
| REQ_CLR5 | 21    | WO     | X                | Write 1 to clear REQ5 bit.                           |
| REQ_SET5 | 20    | WO     | X                | Write 1 to set REQ5 bit.                             |
| REQ4     | 19    | RO     | 0                | Software request bit 4.                              |
|          |       |        |                  | 1 in this bit indicates that the request4 is active. |
| ARB_WON4 | 18    | RO     | 0                | Arbitration won bit 4(see bit 8, ARB_WON0)           |
| REQ_CLR4 | 17    | WO     | X                | Write 1 to clear REQ4 bit                            |
| REQ_SET4 | 16    | WO     | X                | Write 1 to set REQ4 bit                              |
| REQ3     | 15    | RO     | 0                | Software request bit3                                |
|          |       |        |                  | 1 in this bit indicates that the request5 is active. |
| REQ2     | 14    | RO     | 0                | Software request bit2.                               |
|          |       |        |                  | 1 in this bit indicates that the request5 is active. |
| REQ1     | 13    | RO     | 0                | Software request bit1.                               |
|          |       |        |                  | 1 in this bit indicates that the request5 is active. |

| Name     | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                       |
|----------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REQ0     | 12   | RO     | 0                | Software request bit 0.                                                                                                                                                                                                                                                                                                                           |
|          |      |        |                  | When Req_set0 bit is set, this bit will be set.                                                                                                                                                                                                                                                                                                   |
| ARB_WON3 | 11   | RO     | 0                | Arbitration won bit 3 (see Bit 8, ARB_WON0)                                                                                                                                                                                                                                                                                                       |
| ARB_WON2 | 10   | RO     | 0                | Arbitration won bit 2 (see Bit 8, ARB_WON0)                                                                                                                                                                                                                                                                                                       |
| ARB_WON1 | 9    | RO     | 0                | Arbitration won bit 1 (see Bit 8, ARB_WON0)                                                                                                                                                                                                                                                                                                       |
| ARB_WON0 | 8    | RO     | 0                | When req0 arbitration is won, this bit will be read as 1. When an operation is complete, then Req_clr0 must be written to clear bit. At that point, the next high priority arb bit will be set if requested. At any time, only one of the ARB_WON[5:0] bits will be read as 1.  ARB 0 has the highest priority, and ARB5 has the lowest priority. |
| REQ_CLR3 | 7    | WO     | Х                | Write 1 to this bit to clear REQ3 bit.                                                                                                                                                                                                                                                                                                            |
| REQ_CLR2 | 6    | WO     | Х                | Write 1 to this bit to clear REQ2 bit.                                                                                                                                                                                                                                                                                                            |
| REQ_CLR1 | 5    | WO     | Х                | Write 1 to this bit to clear REQ1 bit.                                                                                                                                                                                                                                                                                                            |
| REQ_CLR0 | 4    | WO     | Х                | Write 1 to this bit to clear REQ0 bit.                                                                                                                                                                                                                                                                                                            |
| REQ_SET3 | 3    | WO     | Х                | Write 1 to this bit to set REQ3 bit.                                                                                                                                                                                                                                                                                                              |
| REQ_SET2 | 2    | WO     | Х                | Write 1 to this bit to set REQ2 bit.                                                                                                                                                                                                                                                                                                              |
| REQ_SET1 | 1    | WO     | Х                | Write 1 to this bit to set REQ1 bit.                                                                                                                                                                                                                                                                                                              |
| REQ_SET0 | 0    | WO     | Х                | Set software arbitration request bit 0.                                                                                                                                                                                                                                                                                                           |
|          |      |        |                  | This bit is set by writing 1.                                                                                                                                                                                                                                                                                                                     |

#### 13.37.9 NVM Access Register (offset: 0x7024)

| Name                      | Bits | Access | Default<br>Value | Description                                                                                                                                                                                                                     |
|---------------------------|------|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                  | 31:5 | RO     | 0                | -                                                                                                                                                                                                                               |
| Disable Auto EEPROM reset | 4    | RW     | 1'b0             | This bit controls the nvm state machine to issue EEPROM reset.  1'b0: Issue EEROM reset sequence before any EPROM RW access right after a hardware or software reset.  1'b1: EEPROM reset sequence is not issued automatically. |
| EPROM SDA_OE mode         | 3    | RW     | 1'b1             | This bit controls EPROM SDA_OE generation.                                                                                                                                                                                      |
| Ate_mode                  | 2    | RW     | 0                | When 1, the EEPROM Data in and data out are on 2 different pins so that we don't need to worry about the turnaround issues.                                                                                                     |
| NVM Access Write Enable   | 1    | RW     | 0                | When 1, allows the NVRAM write command to be issued even if the NVRAM write enable bit21 of the mode control register 0x6800.                                                                                                   |
| NVM Access Enable         | 0    | RW     | 0                | When 0, prevents write access to all other NVRAM registers, except for the Software arbitration register.                                                                                                                       |

#### 13.37.10 NVM Write1 Register (offset: 0x7028)

| Name                  | Bits  | Access | Default<br>Value | Description                                                                                                                                                                                                                   |
|-----------------------|-------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved              | 31-16 | _      | _                | -                                                                                                                                                                                                                             |
| Write Disable Command | 15-8  | RW     | 0x4h             | Flash write disable command when device with protection function is used. This command will be issued by the flash interface state machine through SPI interface.  To flash device, and make the flash device write-disabled. |
| Write Enable Command  | 7-0   | RW     | 0x6h             | Flash write enable command when device with protection function is used. This command will be issued by the flash interface state machine through SPI interface.                                                              |
|                       |       |        |                  | To flash device, and make the flash device write-enabled.                                                                                                                                                                     |
|                       |       |        |                  | Arbitration Watchdog Timer Register (offset: 0x702C).                                                                                                                                                                         |

#### 13.37.11 Arbitration Watchdog Timer Register (offset: 0x702C)

| Name     | Bits  | Access | Default<br>Value | Description |
|----------|-------|--------|------------------|-------------|
| Reserved | 31-0  | RO     | 1                | -           |
| Reserved | 27-24 | RO     | 0                | -           |
| Reserved | 23:8  | RW     | 0x1000000        | -           |
| Reserved | 7     |        | 0                | -           |
| Reserved | 6     | RW     | 0                | -           |
| Reserved | 5     | RW     | 1                | -           |
| Reserved | 4-0   | RO     | 0                | _           |

# 13.37.12 NVM Auto-Sense Status Register (offset: 0x7038)

| Name                      | Bits  | Access | Default<br>Value | Description                                       |
|---------------------------|-------|--------|------------------|---------------------------------------------------|
|                           |       |        |                  | Description                                       |
| Reserved                  | 31:21 | RO     | 0                | -                                                 |
| Auto Detected Device ID   | 20:16 | RO     | 0x1F             | AT45DB011D: 5'b0_0100;                            |
|                           |       |        |                  | AT45DB021D: 5'b0_0011;                            |
|                           |       |        |                  | AT45DB041D: 5'b0_0000;                            |
|                           |       |        |                  | STM25PE10: 5'b0_1011;                             |
|                           |       |        |                  | STM25PE20: 5'b0_1010;                             |
|                           |       |        |                  | STM25PE40: 5'b0_1000;                             |
|                           |       |        |                  | STM45PE10: 5'b0_1100;                             |
|                           |       |        |                  | STM45PE20: 5'b0_1101;                             |
|                           |       |        |                  | STM45PE40: 5'b0_1110;                             |
|                           |       |        |                  | Unsupported AT26: 5'b1_0000;                      |
|                           |       |        |                  | Unsupported AT45: 5'b1_0001;                      |
|                           |       |        |                  | Unsupported ST25: 5'b1_1000;                      |
|                           |       |        |                  | Unsupported ST45: 5'b1_1100                       |
|                           |       |        |                  | Device Unknown: 5'b1_1111;                        |
| Reserved                  | 15:13 | RO     | 0                | -                                                 |
| Auto-config State         | 12:8  | RO     | 0                | Auto Config FSM state.                            |
| Reserved                  | 7:6   | RO     | 0                | -                                                 |
| Auto Config Successful    | 5     | RO     | 0                | Auto config is successful.                        |
| Auto Config Enable        | 4     | RO     | 0                | Auto config feature is enabled through pin strap. |
| Reserved-Auto_conf_states | 3:1   | RO     | 0                | The auto-sense FSM state.                         |
| Auto_config_busy          | 0     | RO     | 0                | 1: auto-config FSM is busy                        |
|                           |       |        |                  | 0: auto-config is complete                        |

# **Chapter 14: Transceiver Registers**

#### 14.1 Purpose

This section describes the MII registers of the integrated 10/100/1000T PHY transceiver. The access to the transceiver registers is provided indirectly through the MII Communication register (see "MII Communication Register (offset: 0x44C)" on page 278) of the MAC. The integrated transceiver contains the set of registers shown in the tables below.

#### 14.2 BCM571X/BCM5720 Family MII Bus PHY Addressing

| Port 0 |             | Port 1 |             |  |
|--------|-------------|--------|-------------|--|
| Block  | PHY Address | Block  | PHY Address |  |
| GPHY   | 0x01        | GPHY   | 0x02        |  |

#### Table 104: BCM5718

| Po                | rt 0 | Port 1 |             |  |
|-------------------|------|--------|-------------|--|
| Block PHY Address |      | Block  | PHY Address |  |
| GPHY              | 0x01 | GPHY   | 0x02        |  |
| SERDES            | 0x08 | SERDES | 0x09        |  |

#### Table 105: BCM5719

| Port 0 Port 1 |             | rt 1              | Port 2 |                   | Port 3 |        |             |
|---------------|-------------|-------------------|--------|-------------------|--------|--------|-------------|
| Block         | PHY Address | Block PHY Address |        | Block PHY Address |        | Block  | PHY Address |
| GPHY          | 0x01        | GPHY              | 0x02   | GPHY              | 0x03   | GPHY   | 0x04        |
| SERDES        | 0x08        | SERDES            | 0x09   | SERDES            | 0x0A   | SERDES | 0x0B        |

#### Table 106: BCM5720

| Po                  | rt 0 | Port 1 |             |  |
|---------------------|------|--------|-------------|--|
| Block PHY Address I |      | Block  | PHY Address |  |
| GPHY                | 0x01 | GPHY   | 0x02        |  |
| SERDES              | 0x08 | SERDES | 0x09        |  |

#### 14.3 Register Field Access Type

| RW = read/write                      | H = forced high    |
|--------------------------------------|--------------------|
| RO = read only                       | L = forced low     |
| LH = latches high value (until read) | SC = self-clearing |
| LL = latches low value (until read)  | CR = clear on read |

# 14.4 Transceiver Register Map

| Address | Name                                             |  |  |  |  |  |
|---------|--------------------------------------------------|--|--|--|--|--|
| 00h     | MII_Control_Register                             |  |  |  |  |  |
| 01h     | MII_Status_Register                              |  |  |  |  |  |
| 02h     | PHY_Identifier_MSB_Register                      |  |  |  |  |  |
| 03h     | PHY_Identifier_LSB_Register                      |  |  |  |  |  |
| 04h     | Auto_Negot_Advertisement_Register                |  |  |  |  |  |
| 05h     | Auto_Negot_Link_Partner_Ability_Base_Pg_Register |  |  |  |  |  |
| 06h     | Auto_Negot_Expansion_Register                    |  |  |  |  |  |
| 07h     | Auto_Negot_Next_Page_Transmit_Register           |  |  |  |  |  |
| 08h     | Auto_Negot_Link_Partner_Ability_Nxt_Pg_Register  |  |  |  |  |  |
| 09h     | 1000Base_T_Control_Register                      |  |  |  |  |  |
| 0Ah     | 1000Base_T_Status_Register                       |  |  |  |  |  |
| 0Bh-0Eh | Reserved_by_IEEE                                 |  |  |  |  |  |
| 0Fh     | IEEE_Extended_Status_Register                    |  |  |  |  |  |
| 10h     | PHY_Extended_Control_Register                    |  |  |  |  |  |
| 11h     | PHY_Extended_Status_Register                     |  |  |  |  |  |
| 12h     | Receive_Error_Counter_Register                   |  |  |  |  |  |
| 13h     | False_Carrier_Sense_Counter_Register             |  |  |  |  |  |
| 14h     | Local_Remote_Rcvr_NOT_OK_Counters_Register       |  |  |  |  |  |
| 15h     | DSP_Coefficient_Read_Write_Port_Register         |  |  |  |  |  |
| 16h     | DSP_Control_Register                             |  |  |  |  |  |
| 17h     | DSP_Coefficient_Address_Register                 |  |  |  |  |  |
| 18h     | Auxiliary_Control_Register                       |  |  |  |  |  |
|         | Shadow Registers:                                |  |  |  |  |  |
|         | 001 => 10 BASE-T                                 |  |  |  |  |  |
|         | 010 => Power Control                             |  |  |  |  |  |
|         | 011 => IP Phone                                  |  |  |  |  |  |
|         | 100 => Misc Test<br>101 => Misc Test 2           |  |  |  |  |  |
|         | 110 => Manual IP Phone seed                      |  |  |  |  |  |
|         | 111 => Misc Control                              |  |  |  |  |  |
| 19h     | Auxiliary_Status_Register                        |  |  |  |  |  |
| 1Ah     | Interrupt Status Register                        |  |  |  |  |  |
| 1Bh     | Interrupt_Mask_Register                          |  |  |  |  |  |
| ווטו    | Interrupt_mast_register                          |  |  |  |  |  |

| Address | Name                             |  |  |  |  |  |  |
|---------|----------------------------------|--|--|--|--|--|--|
| 1Ch     | Miscellaneous_Shadow_Registers:  |  |  |  |  |  |  |
|         | 00000 => Cabletron LED modes     |  |  |  |  |  |  |
|         | 00001 => DLL Control             |  |  |  |  |  |  |
|         | 00010 => Spare Control 1         |  |  |  |  |  |  |
|         | 00011 => Clock Aligner           |  |  |  |  |  |  |
|         | 00100 => Spare Control 2         |  |  |  |  |  |  |
|         | 00101 => Spare Control 3         |  |  |  |  |  |  |
|         | 00110 => TDR Control 1           |  |  |  |  |  |  |
|         | 00111 => TDR Control 2           |  |  |  |  |  |  |
|         | 01000 => Led Status              |  |  |  |  |  |  |
|         | 01001 => Led Control             |  |  |  |  |  |  |
|         | 01010 => Auto-Power Down         |  |  |  |  |  |  |
|         | 01011 => External Control 1      |  |  |  |  |  |  |
|         | 01100 => External Control 2      |  |  |  |  |  |  |
|         | 01101 => LED Selector 1          |  |  |  |  |  |  |
|         | 01110 => LED Selector 2          |  |  |  |  |  |  |
|         | 01111 => LED GPIO Control/Status |  |  |  |  |  |  |
|         | 10000 => Reserved                |  |  |  |  |  |  |
|         | 10001 => SerDes 100-FX Status    |  |  |  |  |  |  |
|         | 10010 => SerDes 100-FX Test      |  |  |  |  |  |  |
|         | 10011 => SerDes 100-FX Control   |  |  |  |  |  |  |
|         | 10100 => External SerDes Control |  |  |  |  |  |  |
|         | 10101 => SGMII Secondary Control |  |  |  |  |  |  |
|         | 10110 => Misc 1000X Control 2    |  |  |  |  |  |  |
|         | 10111 => Misc 1000X Control      |  |  |  |  |  |  |
|         | 11000 => Auto-Detect SGMII/GBIC  |  |  |  |  |  |  |
|         | 11001 => Test 1000X              |  |  |  |  |  |  |
|         | 11010 => Autoneg 1000X Debug     |  |  |  |  |  |  |
|         | 11011 => Auxiliary 1000X Control |  |  |  |  |  |  |
|         | 11100 => Auxiliary 1000X Status  |  |  |  |  |  |  |
|         | 11101 => Misc 1000X Status       |  |  |  |  |  |  |
|         | 11110 => Auto-Detect Medium      |  |  |  |  |  |  |
|         | 11111 => Mode Control            |  |  |  |  |  |  |
| 1Dh     | Master_Slave_Seed_Register       |  |  |  |  |  |  |
|         | Shadow Register:                 |  |  |  |  |  |  |
|         | 1 => HCD Status                  |  |  |  |  |  |  |
| 1Eh     | Test1_Register                   |  |  |  |  |  |  |
| 1Fh     | Test2_Register                   |  |  |  |  |  |  |

Figure 54: Copper PHY Register Mapping Table



# 14.5 00h-0Fh 10/100/1000T Register Map Detailed Description

To access the following registers, make sure that the Enable 1000BASE-X Register control (Register 1Ch, Shadow 11111, bit 0) = 0.

#### 14.5.1 00h: MII\_Control\_Register

| Bit | Name                   | RW | Default | Description                                    |
|-----|------------------------|----|---------|------------------------------------------------|
| 15  | RESET                  | RW | 0       | 1 = PHY Reset                                  |
|     |                        | SC |         | 0 = normal operation                           |
| 14  | LOOPBACK               | RW | 0       | 1 = loopback mode                              |
|     |                        |    |         | 0 = normal operation                           |
| 13  | SPEED_SELECT_LSB       | RW | 1       | 0.6, 0.13:                                     |
|     |                        |    |         | 11 = Reserved                                  |
|     |                        |    |         | 10 = 1000 Mbit/s                               |
|     |                        |    |         | 01 = 100 Mbit/s                                |
|     |                        |    |         | 00 = 10 Mbit/s                                 |
| 12  | AUTONEGOTIATION_ENABLE | RW | 1       | 1 = auto-negotiation enabled                   |
|     |                        |    |         | 0 = auto-negotiation disabled                  |
| 11  | POWER_DOWN             | RW | 0       | 1 = low power mode                             |
|     |                        |    |         | 0 = normal operation                           |
| 10  | ISOLATE                | RW | 0       | 1 = isolate PHY from MII                       |
|     |                        |    |         | 0 = normal operation                           |
| 9   | RESTART_AUTONEGOTIATIO | RW | 0       | 1 = restart auto-negotiation process           |
|     | N                      | SC |         | 0 = normal operation                           |
| 8   | DUPLEX_MODE            | RW | 1       | 1 = full duplex                                |
|     |                        |    |         | 0 = half duplex                                |
| 7   | COLLISION_TEST         | RW | 0       | 1 = collision test mode enabled                |
|     |                        |    |         | 0 = collision test mode disabled               |
| 6   | SPEED_SELECT_MSB       | RW | 0       | 0.6, 0.13:                                     |
|     |                        |    |         | 11 = Reserved                                  |
|     |                        |    |         | 10 = 1000 Mbit/s                               |
|     |                        |    |         | 01 = 100 Mbit/s                                |
|     |                        |    |         | 00 = 10 Mbit/s                                 |
| 5   | UNIDIRECTIONAL_ENABLE  | RW | 0       | When 0.12=0 AND 0.8=1:                         |
|     |                        |    |         | 1 = able to transmit packets when no link      |
|     |                        |    |         | 0 = requires link in order to transmit packets |
| 4:0 | RESERVED               | RW | 000000  | write as 0, ignore on read                     |

#### 14.5.2 01h: MII\_Status\_Register

| Bit | Name                   | RW   | Default | Description                           |
|-----|------------------------|------|---------|---------------------------------------|
| 15  | 100BASE_T4_CAPABLE     | RO   | 0       | 1 = 100BASE-T4 capable                |
|     |                        | L    |         | 0 = not 100BASE-T4 capable            |
| 14  | 100BASE_X_FULL_DUPLEX_ | RO H | 1       | 1 = 100BASE-X full duplex capable     |
|     | CAPABLE                |      |         | 0 = not 100BASE-X full duplex capable |

| Bit | Name                               | RW       | Default | Description                                                                                                                           |
|-----|------------------------------------|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------|
| 13  | 100BASE_X_HALF_DUPLEX_<br>CAPABLE  | RO H     | 1       | 1 = 100BASE-X half duplex capable 0 = not 100BASE-X half duplex capable                                                               |
| 12  | 10BASE_T_FULL_DPLEX_CAPABLE        | RO H     | 1       | 1 = 10BASE-T full duplex capable 0 = not 10BASE-T full duplex capable                                                                 |
| 11  | 10BASE_T_HALF_DPLEX_CAPABLE        | RO H     | 1       | 1 = 10BASE-T half duplex capable 0 = not 10BASE-T half duplex capable                                                                 |
| 10  | 100BASE_T2_FULL_DUPLEX_<br>CAPABLE | RO<br>L  | 0       | 1 = 100BASE-T2 full duplex capable 0 = not 100BASE-T2 full duplex capable                                                             |
| 9   | 100BASE_T2_HALF_DUPLEX_<br>CAPABLE | RO<br>L  | 0       | 1 = 100BASE-T2 half duplex capable 0 = not 100BASE-T2 half duplex capable                                                             |
| 8   | EXTENDED_STATUS                    | RO H     | 1       | 1 = extended status information in register 0Fh 0 = no extended status info in register 0Fh                                           |
| 7   | UNIDIRECTIONAL_CAPABLE             | RO       | 1       | 1 = capable of Unidirectional Transmit                                                                                                |
| 6   | MF_PREAMBLE_SUPPRESSION            | RO H     | 1       | 1 = PHY will accept management frames with preamble suppressed     0 = PHY will not accept management frames with preamble suppressed |
| 5   | AUTO_NEGOTIATION_COMPLETE          | RO       | 0       | 1 = auto-negotiation complete 0 = auto-negotiation in progress                                                                        |
| 4   | REMOTE_FAULT                       | RO<br>LH | 0       | 1 = remote fault detected 0 = no remote fault detected                                                                                |
| 3   | AUTO_NEGOTIATION_ABILITY           | RO H     | 1       | 1 = auto-negotiation capable 0 = not auto-negotiation capable                                                                         |
| 2   | LINK_STATUS                        | RO LL    | 0       | 1 = link pass<br>0 = link fail                                                                                                        |
| 1   | JABBER_DETECT                      | RO<br>LH | 0       | 1 = jabber condition detected 0 = no jabber condition detected                                                                        |
| 0   | EXTENDED_CAPABILITY                | RO H     | 1       | 1 = extended register capabilities supported 0 = basic register set capabilities only                                                 |

## 14.5.3 02h: PHY\_Identifier\_MSB\_Register

| Bit  | Name    | RW | Default | Description                                      |
|------|---------|----|---------|--------------------------------------------------|
| 15:0 | OUI_MSB | RO | 0362h   | Bits 3:18 of organizationally unique identifier. |

## 14.5.4 03h: PHY\_Identifier\_LSB\_Register

| Bit   | Name    | RW | Default   | Description                                       |
|-------|---------|----|-----------|---------------------------------------------------|
| 15:10 | OUI_LSB | RO | 010111    | Bits 19:24 of organizationally unique identifier. |
| 9:4   | MODEL   | RO | see chart | Device model number (metal programmable)          |
|       |         |    |           | 5717B0 = 100000                                   |
|       |         |    |           | 5717C0 = 110110                                   |
|       |         |    |           | 5718 = 100000                                     |
|       |         |    |           | 5719 = 100010                                     |
|       |         |    |           | 5720 = 110110                                     |

| Bit | Name     | RW | Default | Description                                 |
|-----|----------|----|---------|---------------------------------------------|
| 3:0 | REVISION | RO | 0000    | Device revision number (metal programmable) |

#### 14.5.5 04h: Auto\_Negot\_Advertisement\_Register

| Bit | Name                 | RW | Default | Description                                |
|-----|----------------------|----|---------|--------------------------------------------|
| 15  | NXT_PAGE             | RW | 0       | 1 = next page ability supported            |
|     |                      |    |         | 0 = next page ability not supported        |
| 14  | RESERVED             | RW | 0       | write as 0, ignore on read                 |
| 13  | REMOTE FAULT         | RW | 0       | 1 = advertise remote fault detected        |
|     |                      |    |         | 0 = advertise no remote fault detected     |
| 12  | RESERVED             | RW | 0       | write as 0, ignore on read                 |
| 11  | ASYMMETRIC_PAUSE     | RW | 0       | 1 = Advertise asymmetric pause             |
|     |                      |    |         | 0 = Advertise no asymmetric pause          |
| 10  | PAUSABLE             | RW | 1       | 1 = capable of full duplex Pause operation |
|     |                      |    |         | 0 = not capable of Pause operation         |
| 9   | 100BASET4_CAPABLE    | RW | 0       | 1 = 100BASE-T4 capable                     |
|     |                      |    |         | 0 = not 100BASE-T4 capable                 |
| 8   | 100BASETX_FULL_      | RW | 1       | 1 = 100BASE-TX full duplex capable         |
|     | DUPLEX_CAPABLE       |    |         | 0 = not 100BASE-TX full duplex capable     |
| 7   | 100BASETX_HALF_      | RW | 1       | 1 = 100BASE-TX capable                     |
|     | DUPLEX_CAPABLE       |    |         | 0 = not 100BASE-TX capable                 |
| 6   | 10BASET_FULL_DUPLEX_ | RW | 1       | 1 = 10BASE-T full duplex capable           |
|     | CAPABLE              |    |         | 0 = not 10BASE-T full duplex capable       |
| 5   | 10BASET_HALF_DUPLEX_ | RW | 1       | 1 = 10BASE-T half duplex capable           |
|     | CAPABLE              |    |         | 0 = not 10BASE-T half duplex capable       |
| 4:0 | PROTOCOL_SELECT      | RW | 00001   | 00001 = IEEE 802.3 CSMA/CD                 |

#### 14.5.6 05h: Auto\_Negot\_Link\_Partner\_Ability\_Base\_Pg\_Register

| Bit | Name                           | RW  | Default | Description                                      |
|-----|--------------------------------|-----|---------|--------------------------------------------------|
| 15  | NEXT_PAGE                      | RO  | 0       | 1 = link partner is next page able               |
|     |                                |     |         | 0 = link partner is not next page able           |
| 14  | ACKNOWLEDGE1                   | RO  | 0       | 1 = link partner has received link code word     |
|     |                                |     |         | 0 = link partner has not received link code word |
| 13  | REMOTE_FAULT                   | RO* | 0       | 1 = link partner has detected remote fault       |
|     |                                |     |         | 0 = link partner has not detected remote fault   |
| 12  | RESERVED                       | RO* | 0       | write as 0, ignore on read                       |
| 11  | LINK_PARTNER_ASYMMETRIC _PAUSE | RO* | 0       | link partner's asymmetric pause bit              |
| 10  | PAUSE_CAPABLE                  | RO* | 0       | 1 = link partner is capable of Pause operation   |
|     |                                |     |         | 0 = link partner not capable of Pause operation  |
| 9   | 100BASE_T4_CAPABLE             | RO* | 0       | 1 = link partner is 100BASE-T4 capable           |
|     |                                |     |         | 0 = link partner is not 100BASE-T4 capable       |

| Bit    | Name                                    | RW     | Default      | Description                                                                                               |
|--------|-----------------------------------------|--------|--------------|-----------------------------------------------------------------------------------------------------------|
| 8      | 100BASE_TX_FULL_DUPLEX_<br>CAPABLE      | RO*    | 0            | 1 = link partner is 100BASE-TX full duplex capable 0 = link partner is not 100BASE-TX full duplex capable |
| 7      | 100BASE_TX_HALF_DUPLEX_<br>CAPABLE      | RO*    | 0            | 1 = link partner is 100BASE-TX half duplex capable 0 = link partner is not 100BASE-TX half duplex capable |
| 6      | 10BASE_T_FULL_DUPLEX_CA<br>PABLE        | RO*    | 0            | 1 = link partner is 10BASE-T full duplex capable 0 = link partner is not 10BASE-T full duplex capable     |
| 5      | 10BASE_T_HALF_DUPLEX_CA RO* 0 PABLE     |        | 0            | 1 = link partner is 10BASE-T half duplex capable 0 = link partner is not 10BASE-T half duplex capable     |
| 4:0    | PROTOCOL_SELECTOR                       | RO*    | 00000        | link partner's protocol selector (see IEEE spec for encoding)                                             |
| * RW v | when "writeable link partner ability to | est mo | de" (reg 1Fh | bit 10) is set                                                                                            |

#### 14.5.7 06h: Auto\_Negot\_Expansion\_Register

| Bit  | Name                                | RW       | Default | Description                                                                                                           |
|------|-------------------------------------|----------|---------|-----------------------------------------------------------------------------------------------------------------------|
| 15:7 | RESERVED                            | RO       | 000h    | ignore on read                                                                                                        |
| 6    | NEXT_PAGE_RECEIVE_LOCATION_<br>ABLE | RO H     | 1       | 1 = register 6.5 determines next page receive location 0 = register 6.5 does not determine next page receive location |
| 5    | NEXT_PAGE_RECEIVE_LOCATION          | RO H     | 1       | <ul><li>1 = next pages stored in register 8</li><li>0 = next pages stored in register 5</li></ul>                     |
| 4    | PARALLEL_DETECTION_FAULT            | RO<br>LH | 0       | 1 = parallel detection fault<br>0 = no parallel detection fault                                                       |
| 3    | LINK_PARTNER_NEXT_PAGE_ABILITY      | RO       | 0       | <ul><li>1 = link partner is next page able</li><li>0 = link partner is not next page able</li></ul>                   |
| 2    | NEXT_PAGE_ABILITY                   | RO H     | 1       | 1 = local device is next page able 0 = local device is not next page able                                             |
| 1    | PAGE_RECEIVED                       | RO<br>LH | 0       | 1 = new link code word has been received 0 = new link code word has not been received                                 |
| 0    | LINK_PARTNER_AUTONEG_ABILITY        | RO       | 0       | <ul><li>1 = link partner is auto-negotiation able</li><li>0 = link partner is not auto-negotiation able</li></ul>     |

# 14.5.8 07h: Auto\_Negot\_Next\_Page\_Transmit\_Register (Software Controlled Next Pages)

| Bit  | Name          | RW | Default   | Description                                                          |
|------|---------------|----|-----------|----------------------------------------------------------------------|
| 15   | NXT_PG        | RW | 0         | 1 = additional next pages will follow                                |
|      |               |    |           | 0 = sending last page                                                |
| 14   | RESERVED      | RO | 0         | write as 0, ignore on read                                           |
| 13   | MESSAGE_PAGE  | RW | 1         | 1 = message page                                                     |
|      |               |    |           | 0 = unformatted page                                                 |
| 12   | ACKNOWLEDGE 2 | RW | 0         | 1 = will comply with message (not used during 1000BASE-T next pages) |
|      |               |    |           | 0 = cannot comply with message                                       |
| 11   | TOGGLE1       | RO | 0         | Toggled by arbitration state machine during next page exchange-write |
|      |               |    |           | as 0, ignore on read.                                                |
| 10:0 | CODE_FIELD    | RW | 000000001 | Message code field or unformatted code field                         |

#### 14.5.9 08h: Auto\_Negot\_Link\_Partner\_Ability\_Nxt\_Pg\_Register

| Bit    | Name                                                                         | RW      | Default    | Description                                                          |  |  |
|--------|------------------------------------------------------------------------------|---------|------------|----------------------------------------------------------------------|--|--|
| 15     | NEXT_PG                                                                      | RO      | 0          | 1 = additional next pages will follow                                |  |  |
|        |                                                                              |         |            | 0 = sending last page                                                |  |  |
| 14     | ACKNOWLEDGE3                                                                 | RO      | 0          | 1 = acknowledge                                                      |  |  |
|        |                                                                              |         |            | 0 = no acknowledge                                                   |  |  |
| 13     | MESSAGE_PG                                                                   | RO      | 0          | 1 = message page                                                     |  |  |
|        |                                                                              |         |            | 0 = unformatted page                                                 |  |  |
| 12     | ACKNOWLEDGE_2                                                                | RO      | 0          | 1 = will comply with message (not used during 1000BASE-T next pages) |  |  |
|        |                                                                              |         |            | 0 = cannot comply with message                                       |  |  |
| 11     | TOGGLE2                                                                      | RO      | 0          | 1 = sent 0 during previous Link Code Word                            |  |  |
|        |                                                                              |         |            | 0 = sent 1 during previous Link Code Word                            |  |  |
| 10:0   | 10:0 CODEFIELD RO* 0 Message code field or unformatted code field            |         |            |                                                                      |  |  |
| * RW v | * RW when "writeable link partner ability test mode" (reg 1Fh bit 10) is set |         |            |                                                                      |  |  |
| Whe    | n reg 1Fh bit 8 is set, the link                                             | partner | random see | ed can be written in bits 10:0 (write only)                          |  |  |

#### 14.5.10 09h: 1000Base\_T\_Control\_Register

| Bit     | Name                                   | RW     | Default              | Description                                       |
|---------|----------------------------------------|--------|----------------------|---------------------------------------------------|
| 15:13   | TEST_MODE                              | RW     | 000                  | 1xx = Test Mode 4                                 |
|         |                                        |        |                      | 011 = Test Mode 3                                 |
|         |                                        |        |                      | 010 = Test Mode 2                                 |
|         |                                        |        |                      | 001 = Test Mode 1                                 |
|         |                                        |        |                      | 000 = Normal Operation                            |
| 12      | MASTER_SLAVE_CONFIG_                   | RW     | 0                    | 1 = enable Primary/Secondary manual config value  |
|         | ENABLE                                 |        |                      | 0 = disable Primary/Secondary manual config value |
|         | (#)                                    |        |                      |                                                   |
| 11      | MASTER_SLAVE_CONFIG_                   | RW     | 0                    | 1 = configure PHY as Primary when 9.12 is set     |
|         | VALUE                                  |        |                      | 0 = configure PHY as Secondary when 9.12 is set   |
|         | (#)                                    |        |                      |                                                   |
| 10      | REPEATER_DTE                           | RW     | 0                    | 1 = Repeater/switch device port                   |
|         | (#)                                    |        |                      | 0 = DTE device port                               |
| 9       | ADV_1000BASE_T_FULL_                   | RW     | 0                    | 1 = Advertise 1000BASE-T full duplex capable      |
|         | DUPLEX                                 |        |                      | 0 = Advertise not 1000BASE-T full duplex capable  |
|         | (#)                                    |        |                      |                                                   |
| 8       | ADV_1000BASE_T_HALF_                   | RW     | 0                    | 1 = Advertise 1000BASE-T half duplex capable      |
|         | DUPLEX                                 |        |                      | 0 = Advertise not 1000BASE-T half duplex capable  |
|         | (#)                                    |        |                      |                                                   |
| 7:0     | RESERVED                               | RW     | 00000000             | write as 0, ignore on read                        |
| # Regis | sters updated with pin defaults on ris | ing ed | ge of restart autone | g pin (tied to gnd at top level).                 |

#### 14.5.11 0Ah: 1000Base\_T\_Status\_Register

| Bit     | Name                                | RW       | Default         | Description                                            |
|---------|-------------------------------------|----------|-----------------|--------------------------------------------------------|
| 15      | MASTER_SLAVE_CONFIG_FAUL            | RO       | 0               | 1 = Primary/Secondary configuration fault detected     |
|         | Т                                   | LH       |                 | 0 = no Primary/Secondary configuration fault detected  |
|         |                                     | (#)      |                 | (cleared by restart_an, an_complete or reg read)       |
| 14      | MASTER_SLAVE_CONFIG_RESO            | RO       | 0               | 1 = local PHY configured as Primary                    |
|         | LUTION                              |          |                 | 0 = local PHY configured as Secondary                  |
| 13      | LOCAL_RECEIVER_STATUS               | RO       | 0               | 1 = local receiver status OK                           |
|         |                                     |          |                 | 0 = local receiver status not OK                       |
| 12      | REMOTE_RECEIVER_STATUS              | RO       | 0               | 1 = remote receiver status OK                          |
|         |                                     |          |                 | 0 = remote receiver status not OK                      |
| 11      | LINK_PARTNER_1000BASE-              | RO*      | 0               | 1 = link partner is 1000BASE-T full duplex capable     |
|         | T_FULL_DUPLEX_CAPABLE               |          |                 | 0 = link partner is not 1000BASE-T full duplex capable |
| 10      | LINK_PARTNER_1000BASE_T_H           | RO*      | 0               | 1 = link partner is 1000BASE-T half duplex capable     |
|         | ALF_DUPLEX_CAPABLE                  |          |                 | 0 = link partner is not 1000BASE-T half duplex capable |
| 9:8     | RESERVED                            | RO       | 00h             | ignore on read                                         |
| 7:0     | IDLE_ERROR_COUNT                    | RO<br>CR | 00h             | Number of idle errors since last read                  |
| (#)=not | LH & *=RW when "writeable link part | ner ab   | ility test mode | e" (reg 1Fh bit 10) is set                             |

#### 14.5.12 0Eh: BroadReach LRE Access Register

| Bit  | Name                                | RW | Default | Description                                                                                                                                         |
|------|-------------------------------------|----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:3 | RESERVED                            | RO | 000h    | Ignore on Read                                                                                                                                      |
| 2    | ENABLE LRE REGISTER ACCESS OVERRIDE | RW | 0       | = Allow access to BroadReach LRE Registers     = BroadReach LRE Registers enabled only by normal operation                                          |
| 1    | LRE REGISTER OVERRIDE<br>VALUE      | RW |         | 1 = Force Access to IEEE Registers (only available when 0E.2 = 1)<br>0 = Force Access to BroadReach LRE Registers (only available when<br>0E.2 = 1) |
| 0    | LRE REGISTER ACCESS STATUS          | RO | 0       | 1 = BroadReach LRE Registers are currently accessible 0 = IEEE Registers are currently accessible                                                   |

#### 14.5.13 0Fh: IEEE\_Extended\_Status\_Register

| Bit  | Name                               | RW   | Default | Description                                                                  |
|------|------------------------------------|------|---------|------------------------------------------------------------------------------|
| 15   | 1000BASE_X_FULL_DUPLEX_<br>CAPABLE | RO L | 0       | 1 = 1000BASE-X full duplex capable 0 = not 1000BASE-X full duplex capable    |
| 14   | 1000BASE_X_HALF_DUPLEX_<br>CAPABLE | RO L | 0       | 1 = 1000BASE-X half duplex capable 0 = not 1000BASE-X half duplex capable    |
| 13   | 1000BASE_T_FULL_DUPLEX_<br>CAPABLE | RO H | 1       | 1 = 1000BASE-T full duplex capable 0 = not 1000BASE-T full duplex capable    |
| 12   | 1000BASE_T_HALF_DUPLEX_<br>CAPABLE | RO H | 1       | 1 = 1000BASE-T half duplex capable<br>0 = not 1000BASE-T half duplex capable |
| 11:0 | RESERVED                           | RO   | 000h    | ignore on read                                                               |

# 14.6 10h-1Fh Register Map Detailed Description

## 14.6.1 10h: PHY\_Extended\_Control\_Register

| Bit | Name                                | RW    | Default | Description                                                   |
|-----|-------------------------------------|-------|---------|---------------------------------------------------------------|
| 15  | MAC_PHY_INTERFACE_MODE              | RW    | 0       | 1 = 10B interface mode                                        |
|     |                                     |       |         | 0 = GMII mode                                                 |
| 14  | DISABLE_AUTOMATIC_MDI_<br>CROSSOVER | RW    | 0       | 1 = automatic MDI crossover disabled                          |
|     |                                     |       |         | 0 = automatic MDI crossover enabled                           |
| 13  | TRANSMIT_DISABLE                    | RW    | 0       | 1 = force transmit output to high impedance                   |
|     |                                     |       |         | 0 = normal operation                                          |
| 12  | INTERRUPT_DISABLE                   | RW    | 0       | 1 = interrupts disabled 0 = interrupts enabled                |
| 11  | FORCE_INTERRUPT                     | RW    | 0       | 1 = force interrupt status to "active"                        |
|     |                                     |       |         | 0 = normal interrupt operation                                |
| 10  | BYPASS_ENCODER                      | RW    | 0       | 1 = bypass 4B5B encoder and decoder                           |
|     |                                     |       |         | 0 = normal operation                                          |
| 9   | BYPASS_SCRAMBLER                    | RW    | 0       | 1 = bypass scrambler and descrambler                          |
|     |                                     |       |         | 0 = normal operation                                          |
| 8   | BYPASS_NRZI_MLT3                    | RW    | 0       | 1 = bypass NRZI/MLT3 encoder and decoder                      |
|     |                                     |       |         | 0 = normal operation                                          |
| 7   | BYPASS_ALIGNMENT                    | RW    | 0       | 1 = bypass receive symbol alignment                           |
|     |                                     |       |         | 0 = normal operation                                          |
| 6   | RESET_SCRAMBLER                     | RW SC | 0       | 1 = reset scrambler to all 1's state                          |
|     |                                     |       |         | 0 = normal scrambler operation                                |
| 5   | ENABLE_LED_TRAFFIC_MODE             | RW    | 0       | 1 = LED traffic mode enabled                                  |
|     |                                     |       |         | 0 = LED traffic mode disabled                                 |
| 4   | FORCE_LEDS_ON                       | RW    | 0       | 1 = force all LED's into "ON" state                           |
|     |                                     |       |         | 0 = normal LED operation                                      |
| 3   | FORCE_LEDS_OFF                      | RW    | 0       | 1 = force all LED's into "OFF" state 0 = normal LED operation |
| 2   | BLOCK_TXEN_MODE                     | RW    | 0       | 1 = extend transmit IPG's to at least                         |
| 2   | BLOCK_TAEN_WODE                     | KVV   | O       | 4 nibbles in 100BASE-TX mode                                  |
|     |                                     |       |         | 0 = do not extend short transmit IPG's                        |
| 1   | UNIDIRECTIONAL_ENABLE               | RW    | 0       | 1 = able to transmit packets when no link                     |
|     |                                     |       |         | 0 = requires link in order to transmit packets                |
|     |                                     |       |         | Draggy kell                                                   |

| Bit | Name                          | RW | Default | Description                                                                         |
|-----|-------------------------------|----|---------|-------------------------------------------------------------------------------------|
| 0   | GMII_RGMII_FIFO_ELASTICITY[0] | RW | 0       | GMII/RGMII FIFO ELASTICITY<br>[1:0] in copper mode or RGMII<br>100fx on SerDes pads |
|     |                               |    |         | 11 = Support 20k byte packets (18k 1G+)                                             |
|     |                               |    |         | 10 = support 15k byte packets                                                       |
|     |                               |    |         | 01 = support 10k byte packets                                                       |
|     |                               |    |         | 00 = support 5k byte packets (w/ 200ppm offset)                                     |
|     |                               |    |         | MSB is located at expansion reg<br>46[14]                                           |

## 14.6.2 11h: PHY\_Extended\_Status\_Register (copper side only)

| Bit | Name                                        | R/W   | Default | Description                                                                                                                                         |
|-----|---------------------------------------------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | AUTONEG_BASE_PG_SELECTOR_FIELD_<br>MISMATCH | RO LH | 0       | 1 = link partner base page selector<br>field mismatched advertised selector<br>field since last read<br>0 = no mismatch detected since last<br>read |
| 14  | WIRESPEED_DOWNGRADE                         | RO    | 0       | 1 = autoneg advertising downgraded<br>0 = autoneg advertised as shown in<br>regs 04h & 09h                                                          |
| 13  | MDI_CROSSOVER_STATE                         | RO    | 0       | 1 = MDIX<br>0 = MDI                                                                                                                                 |
| 12  | INTERRUPT_STATUS                            | RO    | 0       | 1 = unmasked interrupt currently active 0 = interrupts clear                                                                                        |
| 11  | REMOTE_RECEIVER_STATUS                      | RO LL | 0       | 1 = remote receiver status OK<br>0 = remote receiver status not OK                                                                                  |
| 10  | LOCAL_RECEIVER_STATUS                       | RO LL | 0       | 1 = local receiver status OK<br>0 = local receiver status not OK                                                                                    |
| 9   | LOCKED                                      | RO    | 0       | 1 = descrambler locked<br>0 = descrambler unlocked                                                                                                  |
| 8   | LINK_STATUS                                 | RO    | 0       | 1 = link pass<br>0 = link fail                                                                                                                      |
| 7   | CRC_ERROR_DETECTED                          | RO LH | 0       | 1 = CRC error detected since last<br>read<br>0 = no CRC error detected since last<br>read                                                           |
| 6   | CARRIER_EXTENSION_ERROR_DETECTED            | RO LH | 0       | 1 = carrier ext. error detected since last read 0 = no carrier ext. error detected since last read                                                  |

| Bit | Name                             | R/W   | Default | Description                                       |
|-----|----------------------------------|-------|---------|---------------------------------------------------|
| 5   | BAD_SSD_DETECTED (FALSE CARRIER) | RO LH | 0       | 1 = bad SSD error detected since last read        |
|     |                                  |       |         | 0 = no bad SSD error detected since last read     |
| 4   | BAD_ESD_DETECTED (PREMATURE END) | RO LH | 0       | 1 = bad ESD error detected since last read        |
|     |                                  |       |         | 0 = no bad ESD error detected since last read     |
| 3   | RECEIVE_ERROR_DETECTED           | RO LH | 0       | 1 = receive coding error detected since last read |
|     |                                  |       |         | 0 = no receive error detected since last read     |
| 2   | TRANSMIT_ERROR_DETECTED          | RO LH | 0       | 1 = transmit error code detected since last read  |
|     |                                  |       |         | 0 = no transmit error detected since last read    |
| 1   | LOCK_ERROR_DETECTED              | RO LH | 0       | 1 = lock error detected since last read           |
|     |                                  |       |         | 0 = no lock error detected since last read        |
| 0   | MLT3_CODE_ERROR_DETECTED         | RO LH | 0       | 1 = MLT3 code error detected since last read      |
|     |                                  |       |         | 0 = no MLT3 error detected since last read        |

## 14.6.3 12h: Receive\_Error\_Counter\_Register

| Bit  | Name                  | RW    | Default | Description                                                                               |
|------|-----------------------|-------|---------|-------------------------------------------------------------------------------------------|
| 15:0 | RECEIVE_ERROR_COUNTER | RW CR |         | Number of non-collision packets with receive errors since last read. Freezes at FFFFh.    |
|      |                       |       |         | (Counts SerDes errors when register 1ch shadow "11011" bit 9 = 1 otherwise copper errors) |

## 14.6.4 13h: False\_Carrier\_Sense\_Counter\_Register

| Bit  | Name                                              | RW    | Default | Description                                                                                                                                                       |
|------|---------------------------------------------------|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | SERDES_BER_COUNTER                                | RO    | 00h     | Number of invalid code groups received while sync_status = 1 since last cleared.                                                                                  |
|      |                                                   |       |         | Cleared by writing expansion register 4D bit 15 = 1                                                                                                               |
| 7:0  | FALSE_CARRIER_SENSE_COUNTE R # (TX ERROR COUNTER) | RW CR | 00h     | Number of false carrier sense events since last read. Counts packets received with transmit error codes when TXERVIS bit in test register is set. Freezes at FFh. |
|      | ,                                                 |       |         | (Counts SerDes errors when register 1ch shadow "11011" bit 9 = 1 otherwise copper errors)                                                                         |

## 14.6.5 14h: Local\_Remote\_Receiver\_NOT\_OK\_Counters\_Register

| Bit  | Name                               | RW    | Default | Description                                                                                                                                                                                                |
|------|------------------------------------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | LOCAL_RECEIVER_NOT_OK_COUNTER      | RW CR | 00h     | number of times local receiver status was not OK since last read. Freezes at FFh.                                                                                                                          |
| 7:0  | REMOTE_RECEIVER_NOT_OK_<br>COUNTER | RW CR | 00h     | number of times remote receiver status was not OK since last read. Freezes at FFh.                                                                                                                         |
| 15:0 | CRC_ERROR_COUNTER                  | RW CR | 0000h   | when CRC error count visibility test mode is set, this reg becomes a 16 bit CRC error counter. Freezes at FFFFh. (Counts SerDes errors when register 1ch shadow "11011" bit 9 = 1 otherwise copper errors) |

Make 100BASE-TX local receiver status signal and front end reset that works more like 1000BASE-T (no drop in link unless maxwait\_timer expires). Use this counter to replace the watchdog timeout count used in 5203 PHY status register.

#### 14.6.6 18h: Auxiliary Control Register (Shadow Register Selector = "000")

| Bit   | Name                                     | RW  | Description                                                                  | Default |
|-------|------------------------------------------|-----|------------------------------------------------------------------------------|---------|
| 15    | EXTERNAL LOOPBACK                        | · · |                                                                              | 0       |
|       |                                          |     | 0 = normal operation                                                         |         |
| 14    | EXTENDED PACKET                          |     |                                                                              | 0       |
|       | LENGTH                                   |     | 0 = allow normal length Ethernet packets only                                |         |
| 13:12 | 2 EDGERATE CONTROL RW 00 = 4.0ns (1000T) |     | 00 = 4.0ns (1000T)                                                           | 00      |
|       | (1000T)                                  |     | 01 = 5.0ns (1000T)                                                           |         |
|       | (LSB or'ed with ER pin)                  |     | 10 = 3.0ns (1000T)                                                           |         |
|       |                                          |     | 11 = 0.0ns (1000T)                                                           |         |
| 11    | ENABLE SM_DSP CLOCK                      | RW  | 1 = Clock is enabled.                                                        | 0       |
|       |                                          |     | 0 = Clock is gated off.                                                      |         |
| 10    | TRANSMIT 6dB CODING                      | RW  | 1 = transmit using 6dB coding                                                | 1       |
|       |                                          |     | 0 = transmit using 3dB coding                                                |         |
| 9:8   | RECEIVE SLICING                          | RW  | 00 = normal Viterbi/DFE MLSE                                                 | 00      |
|       |                                          |     | 01 = 4D symbol by symbol slicing for 3 dB option                             |         |
|       |                                          |     | 10 = 3 level 1D symbol by symbol slicing                                     |         |
|       |                                          |     | 11 = 5 level 1D symbol by symbol slicing during SEND IDLE/DATA, 3 level else |         |
| 7     | DISABLE PARTIAL                          | RW  | 1 = transmitter partial response filter disabled                             | 0       |
|       | RESPONSE FILTER                          |     | 0 = transmitter partial response filter enabled                              |         |
| 6     | DISABLE INVERSE PRF                      | RW  | 1 = receiver inv. partial response filter disabled                           | 0       |
|       |                                          |     | (overrides Phy Control and other MII register settings if disabled)          |         |
|       |                                          |     | 0 = receiver inv. partial response filter enabled                            |         |
| 5:4   | EDGERATE CONTROL                         | RW  | 00 = 4.0 ns (100TX)                                                          | 00      |
|       | (100TX)                                  |     | 01 = 5.0 ns (100TX)                                                          |         |
|       | (LSB or'ed with ER pin)                  |     | 10 = 3.0 ns (100TX)                                                          |         |
|       |                                          |     | 11 = 0.0 ns (100TX)                                                          |         |
| 3     | DIAGNOSTIC MODE                          | RW  | 1 = When convergence fails, hold in failed state until cleared               | 0       |
|       |                                          |     | 0 = Normal operation, retrain on failure                                     |         |

| Bit | Name                     | RW | Description                                                                            | Default |
|-----|--------------------------|----|----------------------------------------------------------------------------------------|---------|
| 2:0 | SHADOW REGISTER          | RW | 000 = Normal operation                                                                 | 000     |
|     | SELECTOR                 |    | 001 = 10 BASE-T register                                                               |         |
|     | (These bits are written  |    | 010 = Power Control register                                                           |         |
|     | on all writes to 18h     |    | 011 = IP Phone register                                                                |         |
|     | regardless of the value) |    | 100 = Misc Test register 1                                                             |         |
|     |                          |    | 101 = Misc Test register 2                                                             |         |
|     |                          |    | 110 = Manual IP Phone Seed register                                                    |         |
|     |                          |    | 111 = Misc Control register                                                            |         |
|     |                          |    | Writes to the selected shadow register are done on a single cycle (no setup required). |         |
|     |                          |    | Reads are selected by first writing to register 18h, shadow 7, bits 14:12.             |         |

#### **Register Reads/Writes Description**

Write register 18h, bits [2:0] = 111 This selects the Miscellaneous Control register, shadow 7h.

All reads must be performed through the Miscellaneous Control register.

Bit 15 = 0 This allows only bits [14:12] and bits [2:0] to be written.

Bits [14:12] = zzz This selects shadow register zzz to be read.

Bits [11: 3] = <don't care> When bit 15 = 0, these bits are ignored.

Bits [2:0] = 111 This sets the Shadow Register Select to 111 (Miscellaneous Control register).

Read register 18h Data read back is the value from shadow register zzz.

#### **Register Writes Description**

Set Bits [15:3] = Preferred write values Bits [15:3] contain the desired bits to be written to.

Set Bits [2:0] = yyy This enables shadow register yyy to be written.

For shadow 7h, bit 15 must also be written.

```
PHY 0x18 Shadow 0x1 register read Procedure
int value;

phy_write(0x18, 0x1007); //switch to shadow 0x1

valu = phy_read(0x18);

PHY 0x18 Shadow 0x2 register write Procedure
int wdata;

phy_write(0x18, 0x2007); //switch to shadow 0x2

phy write(0x18, 0x2007); //switch to shadow 0x2
```

# 14.6.7 18h: 10BASE-T Register (Shadow Register Selector = "001")

| Bit | Name                             | RW | Description                                                                            | Default |
|-----|----------------------------------|----|----------------------------------------------------------------------------------------|---------|
| 15  | MANCHESTER CODE                  | RO | 1 = manchester code error (10BASE-T)                                                   | 0       |
|     | ERROR                            | LH | 0 = no manchester code error                                                           |         |
| 14  | EOF ERROR                        | RO | 1 = EOF detection error (10BASE-T)                                                     | 0       |
|     |                                  | LH | 0 = no EOF detection error                                                             |         |
| 13  | POLARITY ERROR                   | RO | 1 = channel polarity inverted                                                          | 0       |
|     |                                  |    | 0 = channel polarity correct                                                           |         |
| 12  | BLOCK RXDV                       | RW | 1 = block rxdv for 4 additional rxc cycles for ipg                                     | 0       |
|     | EXTENSION (IPG)                  |    | 0 = normal operation                                                                   |         |
| 11  | 10BT TXC INVERT MODE             | RW | 1 = invert TXC output                                                                  | 0       |
|     |                                  |    | 0 = normal operation                                                                   |         |
| 10  | CLASS A/B LINE DRIVER            | RW | 1 = select class A line driver                                                         | 0       |
|     | SELECT (CLASSB_BT)               |    | 0 = select class B line driver                                                         |         |
| 9:  | JABBER DISABLE                   | RW | 1 = Jabber function disabled                                                           | 0       |
|     |                                  |    | 0 = Jabber function enabled (half-duplex only)                                         |         |
| 8   | 10BT SIGNAL DETECT<br>AUTOSWITCH | RW | 1 = 10BT sigdet threshold auto drops during receive packets, improves CAT3 cable reach | 1       |
|     |                                  |    | 0 = 10BT sigdet threshold controlled by bit 7                                          |         |
| 7   | 10 BASE-T SIGNAL DETECT          | RW | 0 = high signal detect threshold                                                       | 0       |
|     | THRESHOLD                        |    | 1 = low signal detect threshold                                                        |         |
| 6   | 10BT ECHO MODE                   | RW | 1 = echo transmit data to receive data                                                 | 0       |
|     |                                  |    | 0 = normal operation                                                                   |         |
| 5   | SQE ENABLE MODE                  | RW | 1 = enable SQE                                                                         | 0       |
|     |                                  |    | 0 = disable SQE                                                                        |         |
| 4   | 10BASE-T NO DRIBBLE              | RW | 1 = correct 10BT dribble nibble                                                        | 0       |
|     |                                  |    | 0 = normal operation                                                                   |         |
| 3   | 10BASE-T POLARITY                | RW | 1 = 1 polarity error needed for 10BT polarity swap                                     | 0       |
|     | ERROR COUNT MAX                  |    | 0 = 7 polarity errors needed for 10BT polarity swap                                    |         |
| 2:0 | SHADOW REGISTER                  | RW | Writes to the selected shadow register are                                             | 001     |
|     | SELECTOR                         |    | done on a single cycle (no setup required).                                            |         |
|     |                                  |    | Reads are selected by first writing to register 18h, shadow 7, bits 14:12.             |         |

# 14.6.8 18h: Power/MII Control Register (Shadow Register Selector = "010")

| Bit  | Name                                            | RW | Description                                                                                                                                                       | Default |
|------|-------------------------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15:6 | Reserved                                        | _  | -                                                                                                                                                                 | _       |
| 5    | SUPER ISOLATE                                   | RW | 1 = isolate mode with no linkpulses transmitted 0 = normal operation                                                                                              | 0       |
| 4:3  | Reserved                                        | _  | _                                                                                                                                                                 | _       |
| 2:0  | SHADOW REGISTER<br>SELECTOR<br>(REFERENCE ONLY) | RW | Writes to the selected shadow register are done on a single cycle (no setup required). Reads are selected by first writing to register 18h, shadow 7, bits 14:12. | 010     |

#### 14.6.9 18h: IP Phone Register (Shadow Register Selector = "011")

| Bit   | Name                       | RW | Description                                                            | Default |
|-------|----------------------------|----|------------------------------------------------------------------------|---------|
| 15    | NON-STOP IP PHONE          | RW | 1 = IP status will always update                                       | 0       |
|       | DETECT MODE                |    | 0 = IP status will halt after detecting an IP PHONE                    |         |
| 14:10 | EXTENDED LINK PULSE        | RW | 00000 = normal link pulse width,                                       | 00000   |
|       | WIDTH COUNTER              |    | otherwise additional link pulse width in 50 ns increments              |         |
| 9     | ALTERNATE RANDOM           | RW | 1 = generate random seed on next received link pulse if                | 0       |
|       | SEED GENERATION            |    | flp_receive_idle is true 0 = normal operation                          |         |
|       |                            |    |                                                                        |         |
|       |                            |    | Writing this bit requires a RESTART of auto-negotiation.               |         |
| 8     | RESTART AUTO-              | RW | 1 = restart auto-negotiation                                           | 0       |
|       | NEGOTI ATION               | SC | 0 = normal operation                                                   |         |
| 7     | IP PHONE WINDOW MODE       | RW | 1 = enable IP Phone window detection mode                              | 0       |
|       |                            |    | 0 = normal operation                                                   |         |
| 6     | EXTENDED LINK PULSE        | RW | 1 = enable extended link pulse width transmission                      | 0       |
|       | WIDTH ENABLE               |    | 0 = normal operation                                                   |         |
| 5     | ENABLE IP PHONE            | RW | 1 = IP Phone detection enabled                                         | 0       |
|       | DETECTION                  |    | 0 = IP Phone detection disabled                                        |         |
| 4     | DISABLE BLOCK LINK10       | RW | Write:                                                                 | 0       |
|       | WINDOW MODE ON             |    | 1 = disable block link10 window mode                                   |         |
|       | WRITES,                    |    | 0 = enable block link10 window mode                                    |         |
|       |                            |    | (filters out received linkpulses for 2.5-5us after                     |         |
|       |                            |    | detecting a linkpulse; ip phone detection must be enabled)             |         |
|       |                            |    | Read:                                                                  |         |
|       |                            |    | 1 = link partner is not an IP PHONE                                    |         |
|       | IP PHONE MISMATCH ON READS |    | 0 = link partner is an IP PHONE if bit 3 set other wise not determined |         |

| Bit | Name                                                            | RW | Description                                                                                                                                                                                               | Default |
|-----|-----------------------------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 3   | DISABLE SWITCH ON/OFF<br>BLOCK LINK10 WINDOW<br>MODE ON WRITES, | RW | Write:  1 = block link10 window mode always on/off (controlled by bit 4)  0 = shut off block link10 window mode when IP MISMATCH detected. Restart nway_flp_rx block (ip phone detection must be enabled) | 0       |
|     | IP PHONE DETECTED ON READS                                      |    | Read: 1 = link partner is an IP PHONE 0 = link partner is not an IP PHONE if bit 4 set on read otherwise not determined                                                                                   |         |
| 2:0 | SHADOW REGISTER<br>SELECTOR<br>(REFERENCE ONLY)                 | RW | Writes to the selected shadow register are done on a single cycle (no setup required). Reads are selected by first writing to register 18h, shadow 7, bits 14:12.                                         | 011     |

# 14.6.10 18h: Misc Test Register 1 (Shadow Register Selector = "100")

| Bit | Name                                      | RW | Description                                                                                                                                                                                                                                     | Default |
|-----|-------------------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15  | REMOTE LOOPBACK<br>ENABLE                 | RW | 1 = enable loopback from MDI (cable end) receive packet, through pcs and back to MDI trans mit packet.  (only use in copper or fiber mode)  0 = disable loopback                                                                                | 0       |
| 14  | TDK FIX FNABI F                           | RW | 1 = TDK fix (extend EOP on transmit 10BT packets)                                                                                                                                                                                               | 1       |
| 13  | ENABLE DEDICATED 10BT<br>DLL BYPASS CLOCK | RW | 1 = 10BT dll bypass clock generated from tpin10 in dll bypass mode 0 = 10BT dll bypass clock generated from inverted xtali input in dll bypass mode (BASET, ADC10BT, PC10BT, CRS10BT, DAC10_100 test modes use tpin10; register value ignored). | 0       |
| 12  | BLOCK 10BT RESTART<br>AUTO-NEGOTIATION    | RW | 1 = prevent 10BT from restarting auto-negotiation in order to break<br>the link<br>0 = normal operation                                                                                                                                         | 0       |
| 11  | REMOTE LOOPBACK<br>TRISTATE               | RW | 1 = tristate the receive MII pins (CRS, RXDV, RXD, etc.) when<br>Remote Loopback is enabled (only use in copper or fiber mode)<br>0 = Remote Loopback packets appear on MII                                                                     | 0       |
| 10  | 10BT WAKEUP                               | RW | 1 = enable 10BT dac                                                                                                                                                                                                                             | 0       |
| 9   | 10BT POLARITY BYPASS                      | RW | 1 = enable polarity bypass<br>0 = normal operation                                                                                                                                                                                              | 0       |
| 8   | 10BT IDLE BYPASS                          | RW | 1 = enable idle bypass<br>0 = normal operation                                                                                                                                                                                                  | 0       |
| 7   | 10BT CLOCK RESET<br>ENABLE                | RW | 1 = clock reset controlled from tpin11 0 = normal operation                                                                                                                                                                                     | 0       |
| 6   | 10BT BYPASS ADC                           | RW | 1 = bypass 10BT adc<br>0 = normal operation                                                                                                                                                                                                     | 0       |
| 5   | 10BT BYPASS CRS                           | RW | 1 = bypass 10BT crs 0 = normal operation                                                                                                                                                                                                        | 0       |
| 4   | SWAP RXMDIX                               | RW | 1 = rx and tx operate on same pair<br>0 = normal operation                                                                                                                                                                                      | 0       |

| Bit | Name                                            | RW | Description                                                                                                                                                        | Default |
|-----|-------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 3   | HALFOUT                                         | RW | 1 = transmit half amplitude, all speeds 0 = normal operation also see exp req f9.1                                                                                 | 0       |
| 2:0 | SHADOW REGISTER<br>SELECTOR<br>(REFERENCE ONLY) | RW | Writes to the selected shadow register are done on a single cycle (no setup required).  Reads are selected by first writing to register 18h, shadow 7, bits 14:12. | 100     |

# 14.6.11 18h: Misc Test Register 2 (Shadow Register Selector = "101")

| Bit   | Name                   | RW | Description                                                                | Default |
|-------|------------------------|----|----------------------------------------------------------------------------|---------|
| 15    | COPPER ENERGY DETECT   | RW | 1 = override copper energy detect                                          | 0       |
|       | OVERRIDE               |    | 0 = normal operation                                                       |         |
| 14    | ADCFIFO_TX_FIX         | RW | 0 = enable adcFIFO fix for TX mode                                         | 0       |
| 13    | Class A/B DVT enable   | RW | 1 = enable, 0 = disable                                                    | 0       |
|       | (5478-A4/A5 and later) |    |                                                                            |         |
| 12    | CLASS A/B ENABLE       | RW | 1 = class AB txdac mode for 100tx speed                                    | 0       |
|       | (100tx speed)          |    | 0 = class A txdac mode                                                     |         |
|       |                        |    | See reg 18-2.15:13                                                         |         |
| 11:10 | ENC error scale        | RW | 00 = no scaling                                                            | 00      |
|       |                        |    | 01 = scaled by 0.5                                                         |         |
|       |                        |    | 10 = scaled by 0.25                                                        |         |
|       |                        |    | others: no scaling                                                         |         |
| 9     | SPARE                  | RW | write as 0, ignore on read                                                 | 0       |
| 8     | Disable Auto Encoding  | RW | 0 = Autoencoding correction enabled (overrides bits 6 and 7)               | 0       |
|       | Correction             |    | 1 = Autoencoding correction disabled                                       |         |
| 7     | Old PCS Encoding RX    | RW | 0 = Select IEEE compliant PCS encoding (for PCS receive)                   | 0       |
|       |                        |    | 1 = Select old PCS encoding (for PCS receive)                              |         |
| 6     | Old PCS Encoding TX    | RW | 0 = Select IEEE compliant PCS encoding (for PCS receive)                   | 0       |
|       |                        |    | 1 = Select old PCS encoding (for PCS receive)                              |         |
| 5     | Enable EC as NEXT      | RW | 1 = enable, 0 = disable                                                    | 0       |
| 4     | Enable force_mdix      | RW | 1 = enable, 0 = disable                                                    | 0       |
| 3     | En_PWRDNTDAC           | RW | 1 = enable, 0 = disable                                                    | 0       |
| 2:0   | SHADOW REGISTER        | RW | Writes to the selected shadow register are done on a single cycle          | 101     |
|       | SELECTOR               |    | (no setup required).                                                       |         |
|       | (REFERENCE ONLY)       |    | Reads are selected by first writing to register 18h, shadow 7, bits 14:12. |         |

#### 14.6.12 18h: Manual IP Phone Seed Register (Shadow Register Selector = "110")

| Bit  | Name                                            | RW | Description                                                                                                                                                                                                                                | Default |
|------|-------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15   | WRITABLE IP PHONE SEED                          | RW | 1 = use manual IP Phone seed                                                                                                                                                                                                               | 0       |
|      |                                                 |    | 0 = normal operation                                                                                                                                                                                                                       |         |
| 14   | SPARE                                           | RW | write as 0, ignore on read                                                                                                                                                                                                                 | 0       |
| 13:3 | LOCAL IP PHONE SEED                             | RW | returns the automatically generated ip phone random seed when bit 15 is cleared. Writable value used when bit 15 is set. The ip phone seed is a 14 bit value [13:0]. [2:0] cannot be read. [2:0] will always use "001" when bit 15 is set. | 00      |
| 2:0  | SHADOW REGISTER<br>SELECTOR<br>(REFERENCE ONLY) | RW | Writes to the selected shadow register are done on a single cycle (no setup required).  Reads are selected by first writing to register 18h, shadow 7, bits 14:12.                                                                         | 110     |

## 14.6.13 18h: Miscellaneous Control Register (Shadow Register Selector = "111")

| Bit   | Name                 | RW | Description                                                                               | Default |
|-------|----------------------|----|-------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE         | RW | 1 = write bits [8:3]                                                                      | 0       |
|       | (BITS [8:3])         | SC | 0 = only write bits [14:12]                                                               |         |
| 14:12 | SHADOW REGISTER READ | RW | 000 = shadow register 0 read select                                                       | 000     |
|       | SELECTOR             |    | 001 = shadow register 1 read select                                                       |         |
|       |                      |    |                                                                                           |         |
|       |                      |    | 111 = shadow register 7 read select                                                       |         |
| 11    | PACKET COUNTER MODE  | RW | 1 = count packets received                                                                | 0       |
|       |                      |    | 0 = count packets transmitted                                                             |         |
| 10    | BYPASS WIRESPEED     | RW | 1 = Link fail counter will clear as soon as link is up                                    | 1       |
|       | TIMER                |    | 0 = Link must be up for at least 2.5 seconds, otherwise link fail counter will increment. |         |
|       |                      |    | Can be set only if gphy port werespd_timer_disable = 0.                                   |         |
| 9     | FORCE AUTO MDIX MODE | RW | 1 = Auto-MDIX will operate when autoneg is                                                | 0       |
|       |                      |    | disabled via reg 0.12                                                                     |         |
|       |                      |    | 0 = Auto-MDIX is disabled when autoneg is                                                 |         |
|       |                      |    | disabled via reg 0.12                                                                     |         |
| 8     | RGMII TIMING MODE    | RW | 1 = clock delayed 90 degrees                                                              | 0       |
|       | (output delay only)  |    | 0 = clock and data aligned                                                                |         |
| 7     | RGMII MODE           | RW | 1 = use reduced GMII mode                                                                 | 0       |
|       |                      |    | 0 = normal GMII/MII operation                                                             |         |
| 6     | RGMII RXER MODE      | RW | 1 = mux rx_er with rx_dv for RGMII mode                                                   | 1       |
|       |                      |    | 0 = mux crs with rx_dv for RGMII mode                                                     |         |
| 5     | RGMII OUT-OF-BAND    | RW | 1 = send regular rx data during IPG                                                       | 1       |
|       | STATUS DISABLE       |    | 0 = send out-of-band status info in RGMII mode                                            |         |
| 4     | WIRESPEED ENABLE     | RW | 1 = enable wirespeed mode                                                                 | 0       |
|       |                      |    | 0 = normal operation                                                                      |         |
|       |                      |    | Note: Can be set only if gphy port wirespd_enable = 1.                                    |         |

| Bit     | Name                                                                         | RW | Description                                                                                                                                                        | Default |  |  |
|---------|------------------------------------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|
| 3       | MDIO ALL PHY<br>SELECT                                                       | RW | 1 = all phy selected during MDIO writes when<br>the phy address = "00000"<br>0 = normal operation                                                                  | 0       |  |  |
| 2:0     | SHADOW REGISTER<br>SELECTOR<br>(REFERENCE ONLY)                              | RW | Writes to the selected shadow register are done on a single cycle (no setup required).  Reads are selected by first writing to register 18h, shadow 7, bits 14:12. | 111     |  |  |
| Bit 7 a | Bit 7 affects mode of operation. Please consult 0.5 for further information. |    |                                                                                                                                                                    |         |  |  |

# 14.6.14 19h: Auxiliary Status Summary (Copper Side Only)

| Bit  | Name                    | RW | Description                                                     | Default                               |
|------|-------------------------|----|-----------------------------------------------------------------|---------------------------------------|
| 15   | AUTO-NEGOTIATION        | RO | 1 = auto-negotiation complete                                   | 0                                     |
|      | COMPLETE                |    | 0 = auto-negotiation in progress                                |                                       |
| 14   |                         | RO | 1 = entered auto-neg "link good check" state                    | 0                                     |
|      |                         | LH | 0 = state not entered since last read                           |                                       |
| 13   | AUTO-NEGOTIATION ACK    | RO | 1 = entered auto-neg "acknowledge detect" state                 | 0                                     |
|      | DETECT                  | LH | 0 = state not entered since last read                           |                                       |
| 12   | AUTO-NEGOTIATION        | RO | 1 = entered auto-neg "ability detect" state                     | 0                                     |
|      | ABILITY DETECT          | LH | 0 = state not entered since last read                           |                                       |
| 11   | AUTO-NEGOTIATION NEXT   | RO | 1 = entered auto-neg "next page wait" state                     | 0                                     |
|      | PAGE WAIT               | LH | 0 = state not entered since last read                           |                                       |
| 10:8 | AUTO-NEGOTIATION HCD    | RO | 111 = 1000BASE-T full duplex*                                   | 000                                   |
|      | (CURRENT OPERAT ING     |    | 110 = 1000BASE-T half duplex*                                   |                                       |
|      | SPEED AND DUPLEX        |    | 101 = 100BASE-TX full duplex*                                   |                                       |
|      | MODE)                   |    | 100 = 100BASE-T4                                                | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |
|      |                         |    | 011 = 100BASE-TX half duplex*                                   |                                       |
|      |                         |    | 010 = 10BASE-T full duplex*                                     |                                       |
|      |                         |    | 001 = 10BASE-T half duplex*                                     |                                       |
|      |                         |    | 000 = no highest common denominator (when auto-neg complete     |                                       |
|      |                         |    | = 1) or auto-negotiation not complete (when auto-neg complete = |                                       |
|      |                         |    | 0)                                                              | -                                     |
| 7    | PARALLEL DETECTION      | RO | 1 = parallel detection fault                                    | 0                                     |
|      | FAULT                   | LH | 0 = no parallel detection fault                                 |                                       |
| 6    | REMOTE FAULT            | RO | 1 = link partner has detected remote fault                      | 0                                     |
|      |                         |    | 0 = link partner has not detected remote fault                  |                                       |
| 5    | PAGE RECEIVED           | RO | 1 = new link code word has been received                        | 0                                     |
|      |                         | LH | 0 = new link code word has not been received                    |                                       |
| 4    | LINK PARTNER AUTO- NEG. | RO | 1 = link partner is auto-negotiation able                       | 0                                     |
|      | ABILITY                 |    | 0 = link partner is not auto-negotiation able                   |                                       |
| 3    | LINK PARTNER NEXT PAGE  | RO | 1 = link partner is next page able                              | 0                                     |
|      | ABILITY                 |    | 0 = link partner is not next page able                          |                                       |
| 2    | LINK STATUS             | RO | 1 = link pass                                                   | 0                                     |
|      |                         |    | 0 = link fail                                                   |                                       |
| 1    | PAUSE RESOLUTION -      | RO | 1 = enable pause receive                                        | 0                                     |
|      | RECEIVE DIR             |    | 0 = disable pause receive                                       |                                       |

| Bit | Name               | RW | Description                | Default |
|-----|--------------------|----|----------------------------|---------|
| 0   | PAUSE RESOLUTION - | RO | 1 = enable pause transmit  | 0       |
|     | TRANSMIT DIR       |    | 0 = disable pause transmit |         |

<sup>\*</sup> Indicates the negotiated HCD when auto-negotiation complete = 1. Indicates the manually selected speed and duplex mode when auto-negotiation enable = 0.

#### 14.6.15 1Ah: Interrupt Status Register (Copper Side Only)

| Bit | Name                  | RW | Description                                                        | Default |
|-----|-----------------------|----|--------------------------------------------------------------------|---------|
| 15  | IP STATUS CHANGE      | RO | 1 = IP status changed since last read                              | 0       |
|     | (register 1c shadow 5 | LH | 0 = interrupt cleared                                              |         |
|     | bit $5 = 0$ )         |    |                                                                    |         |
|     | SD/ENERGY             | RO | 1 = filtered fiber signal detect (via en10b pin) change or energy  | 0       |
|     | DETECT CHANGE         | LH | detect change since last read                                      |         |
|     | (register 1c shadow 5 |    | 0 = interrupt cleared                                              |         |
|     | bit 5 = 1)            |    |                                                                    |         |
| 14  | ILLEGAL PAIR SWAP     | RO | 1 = Illegal pair swap detected                                     | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 13  | MDIX STATUS CHANGE    | RO | 1 = MDIX status changed since last read (means that linkpulse or   | 0       |
|     |                       | LH | carrier was detected on a different pair than previously detected) |         |
|     |                       |    | 0 = interrupt cleared                                              |         |
| 12  | EXCEEDED HIGH         | RO | 1 = value in one or more counters is above 32k                     | 0       |
|     | COUNTER THRESH.       |    | 0 = all counters below 32k                                         |         |
| 11  | EXCEEDED LOW COUNTER  | RO | 1 = value in one or more counters is above 128                     | 0       |
|     | THRESH.               |    | 0 = all counters below 128                                         |         |
| 10  | AUTO-NEG. PAGE RX     | RO | 1 = page received since last read                                  | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 9   | HCD NO LINK           | RO | 1 = negotiated HCD did not establish link                          | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 8   | NO HCD                | RO | 1 = auto-negotiation returned HCD=none                             | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 7   | NEGOTIATED            | RO | 1 = auto-negotiation HCD is not supported by local PHY             | 0       |
|     | UNSUPPORTED HCD       | LH | 0 = interrupt cleared                                              |         |
| 6   | SCRAMBLER SYNC.       | RO | 1 = scrambler synchronization error occurred since last read       | 0       |
|     | ERROR                 | LH | 0 = interrupt cleared                                              |         |
| 5   | REMOTE RECEIVER       | RO | 1 = remote receiver status changed since last read                 | 0       |
|     | STATUS CHANGE         | LH | 0 = interrupt cleared                                              |         |
| 4   | LOCAL RECEIVER STATUS | RO | 1 = local receiver status changed since last read                  | 0       |
|     | CHANGE                | LH | 0 = interrupt cleared                                              |         |
| 3   | DUPLEX MODE CHANGE    | RO | 1 = duplex mode changed since last read                            | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 2   | LINK SPEED CHANGE     | RO | 1 = link speed changed since last read                             | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |
| 1   | LINK STATUS CHANGE    | RO | 1 = link status changed since last read                            | 0       |
|     |                       | LH | 0 = interrupt cleared                                              |         |

| Bit | Name      | RW | Description                            | Default |
|-----|-----------|----|----------------------------------------|---------|
| 0   | CRC ERROR | RO | 1 = CRC error occurred since last read | 0       |
|     |           | LH | 0 = interrupt cleared                  |         |

# 14.6.16 1Bh: Interrupt Mask Register

| Bit  | Name                  | RW | Description                                                                                                          | Default |
|------|-----------------------|----|----------------------------------------------------------------------------------------------------------------------|---------|
| 15:0 | INTERRUPT MASK VECTOR |    | 1 = interrupt masked (status bits still operate normally but do not generate interrupt output) 0 = interrupt enabled | FFFFh   |

#### 14.6.17 1Ch: Cabletron LED Register (Shadow Register Selector = "00h")

Reading from and writing to register 1Ch is through register 1Ch bits [15:10]. Bits [14:10] set the shadow of register 1Ch, and bit 15 enables the writing of bits [9:0]. Setting bit 15 allows writing to bits [9:0] of register 1Ch. To read register 1C shadow zzzzz, first set writes to register 1Ch with bit 15 = 0, and bits [14:10] to zzzzz. The subsequent register read from register 1Ch contains the shadow zzzzz register value.

```
PHY 0x1C Shadow 0x1 register read Procedure
int value;

phy_write(0x1C, 0x0400); //switch to shadow 0x1

value = phy_read(0x1C);

return value;

PHY 0x1C Shadow 0x2 register write Procedure
int wdata;

phy_write(0x1C, 0x0800); //switch to shadow 0x2

phy_write(0x1C, wdata | 0x8800 );
```

| Bit   | Name            | RW | Description                                  | Default |
|-------|-----------------|----|----------------------------------------------|---------|
| 15    | WRITE ENABLE    | RW | 1 = write bits [9:0]                         | 0       |
|       |                 |    | 0 = read bits [9:0]                          |         |
| 14:10 | SHADOW REGISTER | RW | Shadow Register Selector                     | 00000   |
|       | SELECTOR        |    | 00000 = shadow register 0 read/write select  |         |
|       |                 |    | 00001 = shadow register 1 read/write select  |         |
|       |                 |    |                                              |         |
|       |                 |    | 11111 = shadow register 31 read/write select |         |
| 9:8   | RESERVED        | RW | Write as 0, ignore on read                   | -       |

| Bit | Name          | RW | Description                                 | Default  |
|-----|---------------|----|---------------------------------------------|----------|
| 7:0 | CABLETRON LED | RW | [7] cabletron led select                    | 00000000 |
|     | REGISTER      |    | 1 = select cabletron 0= normal mode         |          |
|     |               |    | [6] online                                  |          |
|     |               |    | 1 = online 0 = offline                      |          |
|     |               |    | [5] tx enable                               |          |
|     |               |    | 1 = transmit enable 0 = transmit disable    |          |
|     |               |    | [4] rx enable                               |          |
|     |               |    | 1 = receive enable 0 = receive disable      |          |
|     |               |    | [3] link enable                             |          |
|     |               |    | 1 = link enable 0 = link disable            |          |
|     |               |    | [2] led mode                                |          |
|     |               |    | 1 = traffic mode 0 = normal mode            |          |
|     |               |    | [1] bypass internal yellow and blink clocks |          |
|     |               |    | 1 = enable external yellow and blink        |          |
|     |               |    | clocks, via tpin0 and tpin2, respectively.  |          |
|     |               |    | 0 = use internally generated clocks         |          |
|     |               |    | [0] spare                                   |          |

#### 14.6.18 1Ch: DLL Selection Register (Shadow Register Selector = "01h")

| Bit   | Name                            | RW | Description                                                                                                                                                       | Default |
|-------|---------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                    | RW | 1 = write bits [9:0]                                                                                                                                              | 0       |
|       |                                 |    | 0 = read bits [9:0]                                                                                                                                               |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR     | RW | Shadow Register Selector                                                                                                                                          | 00001   |
| 9:6   | RESERVED                        | RW | write as 0, ignore on read                                                                                                                                        | 000     |
| 5:0   | HIGH QUALITY CLOCK<br>TEST MODE | RW | xx000x = no clock<br>nn0010 = clk125<br>nn0011 = rxclk<br>nn01yy = rxiclk(yy), where yy = 0-3<br>nn1yyy = txiclk(yyy), where yyy = 0-7<br>nn = 0-3 for slice 1-4. | 0000    |
|       |                                 |    | test mode selection is from slice1.                                                                                                                               |         |

# 14.6.19 1Ch: Spare Control 1 Register (Shadow Register Selector = "02h")

| Bit   | Name                        | RW | Description                          | Default |
|-------|-----------------------------|----|--------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                 | 0       |
|       |                             |    | 0 = read bits [9:0]                  |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector             | 00010   |
| 9     | SD status                   | RO | 1= sd input active                   | 0       |
| 8     | FORCE SD ON                 | RW | 1= force sd on. disable sd pin input | 0       |
| 7     | INVERT SD PIN               | RW | 1 = invert sd pin                    | 0       |

| Bit | Name                           | RW | Description                                                                                                                                                                     | Default |
|-----|--------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 6   | CFC_INITFILTER ENABLE          | RW | 1 = enable cfc_initFilter signal to control clock gating of 1000t clocks. Do not gate off 1000t clocks wherever cfiltercntl is initializing the filter.                         | 0       |
| 5   | USE FILTERED SD                | RW | 1= enable filter on sd input pin                                                                                                                                                | 0       |
| 4   | 100FX MODE COPPER<br>PATH      | RW | 1 = enable 100BASE-FX on TRD+/- pins<br>0 = normal copper operation on MDI pairs                                                                                                | 0       |
| 3   | RESERVED                       | RW | write as 0, ignore on read                                                                                                                                                      | 0       |
| 2   | BICOLOR LINK SPEED LED<br>MODE | RW | 1 = enable Bicolor Link Speed led mode  LINKSPD[1:0] = speed  10 = 1000 base-t  01 = 100 base-t  11 = auto-negotiation, 10 base-t                                               | 0       |
| 1   | LOST TOKEN FIX DISABLE         | RW | When 0, enables lost token fix reset circuits                                                                                                                                   | 1       |
| 0   | LINK LED MODE                  | RW | 1 = enable Link LED mode: LINKSPD[1:0] = speed 00 = 1000 base-t 01 = 100 base-t 10 = 10 base-t 11 = auto-negotiation Secondary = active low link 0 = normal link/Secondary mode | 0       |

# 14.6.20 1Ch: Clock Alignment Control Register (Shadow Register Selector = "03h")

| Bit   | Name                                           | RW | Description                                                                            | Default |
|-------|------------------------------------------------|----|----------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                   | RW | 1 = write bits [9:0]                                                                   | 0       |
|       |                                                |    | 0 = read bits [9:0]                                                                    |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR                    | RW | Shadow Register Selector                                                               | 00011   |
| 9     | GTXCLK delay bypass disable (input delay only) | RW | 1 = do not bypass gtxclk delay<br>0 = bypass gtxclk delay                              | 0       |
| 8     | GMII CLOCK ALIGNMENT<br>STROBE                 | RW | Delay value is latched into selected GMII clock delay line on rising edge of this bit. | 0       |
| 7     | RXCLK ALIGNMENT<br>STROBE                      | RW | Delay value is latched into selected RX clock delay line on rising edge of this bit.   | 0       |

| Bit | Name                | RW | Description                        | Default |
|-----|---------------------|----|------------------------------------|---------|
| 6:4 | DELAY VALUE         | RW | RXCLK delay: reset = default delay | 000     |
|     |                     |    | 000 = +1 unit delay                |         |
|     |                     |    |                                    |         |
|     |                     |    | 111 = +8 units delay               |         |
|     |                     |    |                                    |         |
|     |                     |    | GMII clock delay:                  |         |
|     |                     |    | 110 = -1.0ns                       |         |
|     |                     |    | 111 = -0.5ns                       |         |
|     |                     |    | 000 = 0ns                          |         |
|     |                     |    | 001 = 0.5ns                        |         |
|     |                     |    | 010 = 1.0ns                        |         |
| 3:0 | DELAY LINE SELECTOR | RW | RXCLK strobe:                      | 0000    |
|     |                     |    | xx00 = std cell rxclk              |         |
|     |                     |    | xx01 = dfse rxclk                  |         |
|     |                     |    | xx10 = dfe rxclk                   |         |
|     |                     |    | xx11 = enc rxclk                   |         |
|     |                     |    | CNAU also de strate es             |         |
|     |                     |    | GMII clock strobe:                 |         |
|     |                     |    | 0111 = TBI gtx_clk                 |         |
|     |                     |    | 1000 = GMII gtx_clk                |         |
|     |                     |    | 1001 = RGMII gtx_clk               |         |
|     |                     |    | 1010 = GMII rx_clk                 |         |
|     |                     |    | 1011 = RGMII rx_clk                |         |
|     |                     |    | 1100 = TBI RBC0                    |         |
|     |                     |    | 1101 = TBI RBC1                    |         |

# 14.6.21 1Ch: Spare Control 2 Register (Shadow Register Selector = "04h")

| Bit   | Name                             | RW | Description                                                                            | Default |
|-------|----------------------------------|----|----------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                     | RW | 1 = write bits [9:0]                                                                   | 0       |
|       |                                  |    | 0 = read bits [9:0]                                                                    |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR      | RW | Shadow Register Selector                                                               | 00100   |
| 9     | SPARE                            | RW | Flop exists, but does not change any function.                                         | 0       |
| 8     | wirespeed retry disable          | RW | 1 = downgrade after 1 failed link attempt                                              | 0       |
|       | (fixed in 54980)                 |    | 0 = use wirespeed retry limit (1c-04.4:2)                                              |         |
| 7     | select tpout_rxd                 | RW | 1 = tpout_rxd port muxed to rxd                                                        | 0       |
|       |                                  |    | 0 = normal operation for rxd                                                           |         |
| 6     | DISABLE PHYA2                    | RW | 1 = internally disable phya2 input (consult Testability document for suggested usage). | 0       |
| 5     | enable rbc0/1 & txc/rxc tri sate | RW | 1 = enable tristating of rbc0/1 or txc/rxc                                             | 0       |
|       |                                  |    | 0 = rbc0/1 & txc/rxc not tristated.                                                    |         |
| 4:2   | WIRESPEED RETRY LIMIT            | RW | 000: downgrade after 2 failed link attempts                                            | 011     |
|       |                                  |    | 001: downgrade after 3 failed link attempts                                            |         |
|       |                                  |    |                                                                                        |         |
|       |                                  |    | 111: downgrade after 9 failed link attempts                                            |         |

| Bit | Name                         | RW | Description                                                                                                                                  | Default |
|-----|------------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 1   | ENERGY DETECT ON INTR<br>PIN |    | 1 = routes Energy Detect to interrupt signal. Use LED selectors (reg 1c shadow 01101 and 01110) to direct interrupt signal to an LED output. | 0       |
| 0   | testonbyte7_0                | RW | Controls value of gphy output port testonbyte7_0.<br>5478 1 = mux tpout[7:0] to led2[4:1], led1[4:1]                                         | 0       |

#### 14.6.22 1Ch: Spare Control 3 Register (Shadow Register Selector = "05h")

| Bit   | Name                                       | RW | Description                                                                                                                                                        | Default |
|-------|--------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                               | RW | 1 = write bits [9:0]<br>0 = read bits [9:0]                                                                                                                        | 0       |
| 14:10 | SHADOW REGISTER<br>SELECTOR                | RW | Shadow Register Selector                                                                                                                                           | 00101   |
| 9     | DLL lock enable during auto-<br>power down | RW | 1 = allow time for dll to lock before enabling clocks and analog components. Only applicable when dll is powered down during auto-power down (r1c.5 bit 1 is LOW). | 0       |
| 8     | txc/rxc disable during auto-<br>power down | RW | 1 = disable txc/rxc during auto-power down when there's no energy on the cable                                                                                     | 0       |
| 7     | 10BT CARRIER REJECT<br>FILTER ENABLE       | RW | 1 = enable 10BT 15 MHz Carrier Rejection Filter                                                                                                                    | 0       |
| 6     | TXC OFF ENABLE                             | RW | 1 = gates off TXC output in 1000T/1000-X/SGMII Secondary 1000 mode                                                                                                 | 0       |
| 5     | SD/energy detect change mux select         | RW | 1 = interrupt based on energy detection (copper energy detect change or filtered fiber signal detect change from input pin). 0 = normal ipphone interrupt selected | 0       |
| 4     | LOW POWER ENC DISABLE                      | RW | 1 = disable low power ENC mode                                                                                                                                     | 1       |
| 3     | DISABLE LOW POWER<br>10BASE-T LINK MODE    | RW | 1 = disable low power 10BASET link mode                                                                                                                            | 1       |
| 2     | SIGDET DEASSERT TIMER<br>LENGTHEN          | RW | 1 = 100TX Sigdet Deassert Timer = 40 us<br>0 = Sigdet Deassert Timer =1 us                                                                                         | 1       |
| 1     | AUTO-POWER DOWN DLL<br>OFF DISABLE         | RW | 1 = disable powering down of the dll during auto- power down. 0 = enable powering down of dll during auto-power down.                                              | 1       |
| 0     | CLK125 OUTPUT ENABLE                       | RW | 1 = enable CLK125 output<br>0 = disable CLK125 output                                                                                                              | 1       |

## 14.6.23 1Ch: TDR Control 1 Register (Shadow Register Selector = "06h"

| Bit   | Name                        | RW | Description                                                  | Default |
|-------|-----------------------------|----|--------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                                         | 0       |
|       |                             |    | 0 = read bits [9:0]                                          |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector                                     | 00110   |
| 9     | SPARE                       | RW | write as 0, ignore on read                                   | 0       |
| 8     | TDR LINK TIME OUT           | R  | tdr linkpulse time out status                                | 0       |
| 7:5   | TEST PULSE SIZE             | RW | size of test pulse in increments of 8 ns. minimum value = 1. | 001     |
| 4:3   | TX CHANNEL SEL              | RW | channel to transmit test pulse                               | 00      |

| Bit | Name           | RW | Description                  | Default |
|-----|----------------|----|------------------------------|---------|
| 2:1 | RX CHANNEL SEL | RW | channel to receive test data | 00      |
| 0   | TDR START/DONE | RW | write:                       | 0       |
|     |                | SC | 1: tdr start. self clearing  |         |
|     |                |    | read:                        |         |
|     |                |    | 1: tdr done status           |         |

#### 14.6.24 1Ch: TDR Control 2 Register (Shadow Register Selector = "07h")

| Bit   | Name                        | RW | Description                                            | Default |
|-------|-----------------------------|----|--------------------------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                                   | 0       |
|       |                             |    | 0 = read bits [9:0]                                    |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector                               | 00111   |
| 9:8   | SPARE                       | RW | write as 0, ignore on read                             | 00      |
| 7     | PHASE STATUS                | R  | phase status                                           | 0       |
| 6     | PHASE STATUS CLEAR          | RW | 1: clear phase status on bit 7                         | 0       |
| 5     | FASTTIMERS                  | RW | 1: enable fasttimers                                   | 0       |
| 4     | FEXT                        | RW | 1: enable fext mode                                    | 0       |
|       |                             |    | 0: disable fext mode                                   |         |
| 3     | MASTER                      | RW | 1: Primary mode                                        | 0       |
|       |                             |    | 0: Secondary mode                                      |         |
| 2     | EXTERNAL PHY NO AUTO-       | RW | 1: tdr test with external phy without auto-negotiation | 0       |
|       | NEG                         |    | 0: tdr test with external phy with auto-negotiation    |         |
| 1     | EXTERNAL PHY                | RW | 1: tdr test with external phy                          | 0       |
|       |                             |    | 0: tdr test as stand-alone phy                         |         |
| 0     | TDR MODE ENABLE             | RW | 1: enable tdr mode                                     | 0       |
|       |                             |    | 0: disable tdr mode                                    |         |

#### 14.6.25 1Ch: LED Status Register (Shadow Register Selector = "08h")

| Bit   | Name                        | RW | Description              | Default |
|-------|-----------------------------|----|--------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]     | 0       |
|       |                             |    | 0 = read bits [9:0]      |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector | 01000   |
| 9     | RESERVED                    | RO | ignore on read           | 0       |
| 8     | SLAVE_N                     | RO | (active low)             | _       |
| 7     | FDXLED_N                    | RO | (active low)             | _       |
| 6     | INTR_N                      | RO | (active low)             | _       |
| 5     | SPARE                       | RO | ignore on read           | _       |
| 4:3   | LINKSPD_N                   | RO | 11: no link              | _       |
|       |                             |    | 10: 10bt link            |         |
|       |                             |    | 01: 100tx link           |         |
|       |                             |    | 00: 1000t link           |         |

| Bit | Name         | RW | Description  | Default |
|-----|--------------|----|--------------|---------|
| 2   | TRANSMIT LED | RO | (active low) | _       |
| 1   | RECEIVE LED  | RO | (active low) | _       |
| 0   | QUALITY LED  | RO | (active low) | _       |

# 14.6.26 1Ch: Led Control Register (Shadow Register Selector = "09h")

| Bit   | Name                              | RW   | Description                                                                                  | Default |
|-------|-----------------------------------|------|----------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                      | RW   | 1 = write bits [9:0]                                                                         | 0       |
|       |                                   |      | 0 = read bits [9:0]                                                                          |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR       | RW   | Shadow Register Selector                                                                     | 01001   |
| 9     | Collision blink led mode          | RW   | 1 = blink fdxled when collision occurs                                                       | 0       |
|       |                                   |      | 0 = fdxled indicates duplex status only                                                      |         |
| 8     | Activity link led MSB             | RW   | See description for bit 4 below.                                                             | 0       |
| 7     | SPARE                             | RW   | write as 0, ignore on read                                                                   | 0       |
| 6     | external_serdes_inuse<br>led mode | RW   | 1= drive transmit led low when external SerDes is selected, inactive when not selected       | 0       |
|       |                                   |      | 0= normal operation                                                                          |         |
| 5     | Override GBIC LED mode            | RW   | 1 = LEDs not remapped in GBIC mode.                                                          | 0       |
|       |                                   |      | 0 = In GBIC mode LEDs mapped as follows.                                                     |         |
|       |                                   |      | LED1: RX_LOSS (copper link)                                                                  |         |
|       |                                   |      | LED2: RX (copper receive activity)                                                           |         |
|       |                                   |      | LED3: TX (copper transmit activity)                                                          |         |
| 4     | 4 (1 (1 1 1 1 1 0 0               | DIA  | LED4: LINK (both SerDes and copper are linked)                                               |         |
| 4     | Activity link led LSB             | RW   | Combined with bit 8 above.                                                                   | 0       |
|       |                                   |      | 11 = activity,linkspd[1:0] indicate 1000,100,10 link respectively, and blinks with activity. |         |
|       |                                   |      | 10 = linkspd[1:0] indicate encode link, and blinks when activity                             |         |
|       |                                   |      | 01 = active indicates link, and blinks when activity                                         |         |
|       |                                   |      | 00 = normal operation                                                                        |         |
|       |                                   |      | These bits overrides bit 3 below.                                                            |         |
| 3     | ACTIVITY LED                      | RW   | 1 = normal operation (activity led indicates transmit or receive                             | 1       |
|       | ENABLE                            |      | activity). 0 = activity led indicates receive activity only                                  |         |
| 2     | REMOTE FAULT LED                  | RW   | 1 = drive remote fault on quality led                                                        | 0       |
| 2     | ENABLE                            | KVV  | 0 = normal operation                                                                         | U       |
| 1:0   | LINK UTILIZATION LED              | RW   | 00 = normal operation                                                                        | 00      |
| 1.0   | SELECTOR (NORTEL LED)             | IXVV | 01 = transmit data on receive led                                                            | 00      |
|       |                                   |      | 10 = receive data on receive led                                                             |         |
|       |                                   |      | 11 = activity data on receive led                                                            |         |
|       |                                   |      | (This mode has higher priority than the activity led enable in bit 3.)                       |         |
|       |                                   |      | ( priority and all the deathly red oriable in bit o.)                                        |         |

# 14.6.27 1Ch: SGMII Secondary Register (Shadow Register Selector = "15h")

| Bit   | Name                                                                                                                                                  | RW       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Default |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                                                                                                                          | RW       | 1 = write bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0       |
|       |                                                                                                                                                       |          | 0 = read bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR                                                                                                                           | RW       | Shadow Register Selector                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10101   |
| 9     | SERDES LINK                                                                                                                                           | RO       | 1 = link up in fiber, SGMII,or GBIC modes<br>(when set in SGMII or GBIC mode, then both copper and SerDes<br>link must be valid).<br>0 = link down                                                                                                                                                                                                                                                                                                                                                        | 0       |
| 8     | SERDES DUPLEX                                                                                                                                         | RO       | <ul><li>1 = SerDes full-duplex</li><li>0 = SerDes half-duplex or auto-negotiating in progress</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                   | 1       |
| 7:6   | SERDES SPEED                                                                                                                                          | RO       | 10 = SerDes speed 1000 (SGMII 1000 or 1000X)<br>01 = SerDes speed 100 (SGMII 100 or 100fx)<br>00 = SerDes speed 10 (SGMII 10)                                                                                                                                                                                                                                                                                                                                                                             | 10      |
| 5     | SERDES LINK STATUS<br>CHANGE                                                                                                                          | RO<br>LH | 1 = link status change detected since last read 0 = link status change not detected since last read                                                                                                                                                                                                                                                                                                                                                                                                       | 0       |
| 4:3   | MODE SELECT                                                                                                                                           | RO       | 00 = copper<br>01 = fiber<br>10 = SGMII<br>11 = GBIC                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00000   |
| 2     | RGMII/MII -> SGMII SLAVE 10/100 TX FIFO FREQUENCY LOCK MODE  (forced high internally when => sgmii_slave_mode and not rgmii_mode and not remote_lpbk) | RW       | 1 = SGMII transmit FIFO will assume that the SerDes pll clock and the MAC transmit clock are frequency locked. This will essentially bypass the FIFO with the lowest possible latency in 10/100 speeds.  (useful for applications where the MAC is in RGMII mode and the PHY is in RGMII-> SGMII Secondary mode, and both the MAC and PHY are using the same crystal. When the MAC is in MII mode and the PHY is in MII->SGMII Secondary mode, then this bit should always be set.)  0 = normal operation | 00000   |
| 1     | SGMII SLAVE MODE<br>(register 1c shadow 1fh<br>bit [2:1] must be "01")                                                                                | RW       | 1 = enable MII/GMII/RGMII -> SGMII mode<br>(only secondary mode supported; useful for MAC RGMII to SGMII<br>conversions, which are attached to an external phy.)<br>0 = disable SGMII secondary mode                                                                                                                                                                                                                                                                                                      | 00000   |
| 0     | SGMII SLAVE AUTO-<br>DETECTION<br>(register 1c shadow 1fh<br>bit [2] must be 0)                                                                       | RW       | 1 = enable SGMII secondary auto-detection.     Switch between 1000-X and SGMII secondary modes based on SerDes received auto-negotiation code word.     0 = normal operation                                                                                                                                                                                                                                                                                                                              | 00000   |

# 14.6.28 1Ch: Misc 1000-X Control 2 Register (Shadow Register Selector = "16h")

| Bit   | Name                                                                    | RW       | Description                                                                                                                                                                                                                                                                                                                                                                                  | Default |
|-------|-------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                                            | WO       | 1 = write bits [9:7] if [6] = 1 or<br>write bits[5:0] if [6] = 0<br>0 = read bits [9:0]                                                                                                                                                                                                                                                                                                      | 0       |
| 14:10 | SHADOW REGISTER<br>SELECTOR                                             | RW       | Read will always return 0.  Shadow Register Selector  NOTE:  (If bit 8 of this register is set prior to writing this register, then the selector value written will not be stored.  To properly read the shadow registers, one must write bit 8 as a zero, then on a subsequent write set the desired shadow register to read.                                                               | 10110   |
| 9     | REMOTE COPPER MODE<br>(register 1c shadow 1fh<br>bits 2:1 must be "11") | RW       | <ul><li>1 = enable remote copper mode (used in backplane applications to attach a remote phy to a mac).</li><li>0 = normal operation</li></ul>                                                                                                                                                                                                                                               | 00      |
| 8     | ENABLE REMOTE ACCESS                                                    | RW       | 1 = Enable remote mac link partner to access local MDIO registers via SerDes autoneg next-page MDIO message pages. Bit [9] of this register must also be set.  Local MDIO access is blocked. All local MDIO read accesses will return the results of this register regardless of register address. The only local MDIO write access allowed is [9:7] of this register.  0 = normal operation | 00      |
| 7     | RESTART SERDES<br>AUTONEG                                               | RW<br>SC | On Writes: 1 = restart SerDes auto-negotiation. Bit [9] of this register must also be set. 0 = normal operation On Reads: 1 = "GBIC mode" (reg 1ch shadow 1f [2:1] = "11") and "remote copper mode" ([9] of this register = 1)                                                                                                                                                               | 0       |
| 6     | REGISTER WRITE<br>SELECTOR                                              | RW       | On Writes:  1 = write bits [9:7] when bit [15] is also set during a write cycle  0 = write bits [5:0] when bit [15] is also set during a write cycle  On Reads:  1 = "SerDes link" (reg 1ch shadow 15h[9] = 1) and  "remote_copper_mode" ([9] of this register = 1)                                                                                                                          | 0       |
| 5     | ENABLE AMPLITUDE<br>SIGNAL DETECT                                       | RW       | 1 = SerDes synchronization will fail if signal amplitude is not above a certain threshold.  (useful in applications that do not use a fiber module and the receiver may be floating.)  0 = normal operation                                                                                                                                                                                  | 1       |
| 4     | SNOOP MODE<br>(register 1c shadow 1fh<br>bits[2:1] must be "00")        | RW       | 1 = allow SerDes to act as snoop port. All receive traffic on copper pins will be forwarded to SGMII trans mit pins. 0 = disable snoop port                                                                                                                                                                                                                                                  | 0       |
| 3     | FILTER FORCED LINK                                                      | RW       | 1 = synchronization status must be valid for 10 ms before link will come up when auto-negotiation is disabled. 0 = normal operation                                                                                                                                                                                                                                                          | 1       |

| Bit | Name                                                                                                                                                                                                                                                                                                       | RW | Description                                                                                                                                                                                                                                        | Default |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 2   | DISABLE FALSE LINK                                                                                                                                                                                                                                                                                         | RW | 1 = do not allow xmit=data when auto-negotiation is disabled unless rudi=idle detected. Force xmit=idle if rudi=config. 0 = normal operation                                                                                                       | 1       |
| 1   | SERDES AUTO-NEGOTIATION PARALLEL DETECT ENABLE                                                                                                                                                                                                                                                             | RW | 1 = turn auto-negotiation on/off in order to link up with link partner.     Algorithm based on received code words     0 = disable parallel detection                                                                                              | 1       |
| 0   | FIFO ELASTICITY [1] for dig1000x_tx_fifo and dig1000x_rx_fifo Modes: (RGMII/GMII pads towards SerDes link partner) (RGMII pads to SGMII-secondary 10/ 100/1000 towards SerDes link partner) (10/100 SGMII transmit and receive) (1000 SGMII transmit from copper link partner towards SerDes link partner) | RW | dig1000x_tx_fifo and dig1000x_rx_fifo FIFO ELASTICITY [1:0]: 11 = support 20k byte packets 10 = support 15k byte packets 01 = support 10k byte packets 00 = support 5k byte packets (w/200 ppm offset)  LSB located at register 1ch shadow 1bh [1] | 0       |

## 14.6.29 1Ch: Misc 1000-X Control Register (Shadow Register Selector = "17h")

| Bit   | Name                                                             | RW | Description                                                                                                                                                                                                                                                                                                                                                                               | Default |
|-------|------------------------------------------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                                     | RW | 1 = write bits [9:0]<br>0 = read bits [9:0]                                                                                                                                                                                                                                                                                                                                               | 0       |
| 14:10 | SHADOW REGISTER<br>SELECTOR                                      | RW | Shadow Register Selector                                                                                                                                                                                                                                                                                                                                                                  | 10111   |
| 9     | QUALIFY DISABLE CARRIER EXTEND AND DISABLE TRRR WITH FULL-DUPLEX | RW | 1 = In full-duplex mode: disable carrier extension when reg 1ch shadow 1bh [6] = 1 and disable trrr generation when reg 1ch shadow 1bh [5] = 1 In half-duplex: always allow carrier extension and trrr generation regardless of reg 1ch shadow 1bh [6:5].  0 = Always disable carrier extension when reg 1ch shadow 1bh [6] = 1 and disable trrr generation when reg 1ch shadow 1bh [5] = | 0       |
| 8     | FIBER AUTO POWERDOWN WAKE UP TIME                                | RW | 1 = wake up for 250 ms before powering down Set to 1 when enabling fiber auto-power down or 100-fx auto- detection; register 1ch shadow "1eh" [4] and register 1ch shadow "13h" [2].  0 = wake up for 42 ms before powering down.                                                                                                                                                         | 0       |
| 7     | FIBER AUTO POWERDOWN SLEEP TIME                                  | RW | 1 = power down for 3 seconds before waking up 0 = power down for 5 seconds before waking up                                                                                                                                                                                                                                                                                               | 0       |
| 6     | SERDES TRANSMIT<br>DISABLE                                       | RW | 1 = force all SerDes transmit data to 0<br>0 = normal operation                                                                                                                                                                                                                                                                                                                           | 0       |

| Bit | Name                               | RW | Description                                                                                                     | Default |
|-----|------------------------------------|----|-----------------------------------------------------------------------------------------------------------------|---------|
| 5   | SIGNAL DETECT ENABLE               | RW | 1 = force synchronization to fail if signal detect is not active.  Disabled if register 1ch shadow 14h [1] = 1. | 1       |
|     |                                    |    | 0 = ignore signal detect pin                                                                                    |         |
| 4   | DISABLE GBIC UPDATES               | RW | 1 = use register 4 and 9 for copper auto-neg, register 4 for SerDes autoneg.                                    | 0       |
|     |                                    |    | Do not allow GBIC updates.                                                                                      |         |
|     |                                    |    | 0 = allow registers 4 and 9 to update in GBIC mode                                                              |         |
| 3   | FORCE XMIT=DATA                    | RW | 1 = force xmit=data regardless of state of receive channel                                                      | 0       |
|     |                                    |    | 0 = normal operation                                                                                            |         |
| 2   | DISABLE SERDES AMPLITUDE SWITCHING | RW | 1 = SerDes amplitude will be fixed to operate with fiber modules (1000x)                                        | 0       |
|     |                                    |    | 0 = normal operation (SGMII or 1000x amplitudes based on current mode of operation)                             |         |
| 1   | FIBER SUPER-ISOLATE                | RW | 1 = Fiber super-isolate                                                                                         | 0       |
| 0   | DISABLE 1000-X                     | RW | 1 = disable1000-X power-down from                                                                               | 0       |
|     | POWERDOWN                          |    | auto-medium detection and fiber auto-power down. (register 0 power-down not affected)                           |         |
|     |                                    |    | 0 = normal operation                                                                                            |         |

# 14.6.30 1Ch: Auto-Detect SGMII/GBIC Register (Shadow Register Selector = "18h")

| Bit   | Name                                                                        | RW       | Description                                                                                                                                                                                               | Default |
|-------|-----------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                                                | RW       | 1 = write bits [9:0]<br>0 = read bits [9:0]                                                                                                                                                               | 0       |
| 14:10 | SHADOW REGISTER<br>SELECTOR                                                 | RW       | Shadow Register Selector                                                                                                                                                                                  | 11000   |
| 9     | SERDES RESOLUTION<br>FAULT                                                  | RO       | 1 = selector field mismatch (link partner base page code word bit 0 mismatches local base page) 0 = no mismatch has occurred or auto-detect SGMII/GBIC mode is disabled                                   | 0       |
| 8     | XMIT=DATA<br>(SERDES only)                                                  | RO       | 1 = SerDes side is in the xmit=data state 0 = SerDes side is in the xmit=config or idle state                                                                                                             | 0       |
| 7     | FIBER SD (directly from pin, no inversion or filtering)                     | RO       | <ul><li>1 = fiber signal detect from pin is high</li><li>0 = fiber signal detect from pin is low</li></ul>                                                                                                | 0       |
| 6     | SD AMPLITUDE STATUS                                                         | RO       | <ul><li>1 = signal detect amplitude is above the minimum threshold</li><li>0 = signal detect amplitude is below the minimum threshold</li></ul>                                                           | 0       |
| 5     | SD AMPLITUDE STATUS<br>CHANGED                                              | RO<br>LH | <ul><li>1 = signal detect amplitude status has changed since last read</li><li>0 = signal detect amplitude status has not changed since last read</li></ul>                                               | 0       |
| 4     | ENABLE CRC FRAGMENT ERRORS                                                  | RW       | 1 = enable SerDes crc checker to count fragments as crc errors 0 = ignore fragments as crc errors                                                                                                         | 0       |
| 3     | MEDIA CONVERTER MODE<br>(register 1c shadow 1fh<br>bits [2:1] must be "11") | RW       | 1 = do not allow copper side to link up until fiber SD is set and SerDes synchronization is valid.  (fiber SD is not used when "select SD" in register 1ch shadow 14  [1] = 1)  0 = normal GBIC operation | 0       |

| Name                                     | RW                                                                                                                                                                                                                                                                    | Description                                                                                                                                                                                                                                                              | Default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GMII FIFO                                | RW                                                                                                                                                                                                                                                                    | GMII FIFO ELASTICITY [1:0] in SGMII/GBIC mode                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ELASTICITY [0]                           |                                                                                                                                                                                                                                                                       | 11 = Support 18k byte packets                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| in SGMII/GBIC mode                       |                                                                                                                                                                                                                                                                       | 10 = support 15k byte packets                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                          |                                                                                                                                                                                                                                                                       | 01 = support 10k byte packets                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| (1000T PCS transmit FIFO                 |                                                                                                                                                                                                                                                                       | 00 = support 5k byte packets (w/200 ppm offset)                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| in SGMII/GBIC mode:                      |                                                                                                                                                                                                                                                                       | MSB is located at expansion reg 46[15]                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| from SerDes to copper link partner)      |                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SGMII 10/100 RX FIFO FRE                 | RW                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                       | , ,                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| => sgmii_slave_mode and not remote_lpbk) |                                                                                                                                                                                                                                                                       | (useful for applications where the MAC/switch and PHY are using the same crystal)                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                          |                                                                                                                                                                                                                                                                       | 0 = normal operation                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AUTO-DETECT SGMII/ GBIC MODE             | RW                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          | GMII FIFO ELASTICITY [0] in SGMII/GBIC mode  (1000T PCS transmit FIFO in SGMII/GBIC mode: from SerDes to copper link partner) SGMII 10/100 RX FIFO FRE QUENCY LOCK MODE (forced high internally when => sgmii_slave_mode and not remote_lpbk)  AUTO-DETECT SGMII/GBIC | GMII FIFO ELASTICITY [0] in SGMII/GBIC mode  (1000T PCS transmit FIFO in SGMII/GBIC mode: from SerDes to copper link partner) SGMII 10/100 RX FIFO FRE QUENCY LOCK MODE (forced high internally when => sgmii_slave_mode and not remote_lpbk)  AUTO-DETECT SGMII/GBIC RW | GMII FIFO ELASTICITY [0] in SGMII/GBIC mode  11 = Support 18k byte packets 10 = support 15k byte packets 01 = support 10k byte packets 00 = support 5k byte packets (w/200 ppm offset) in SGMII/GBIC mode: from SerDes to copper link partner)  SGMII 10/100 RX FIFO FRE QUENCY LOCK MODE (forced high internally when => sgmii_slave_mode and not remote_lpbk)  RW GMII FIFO ELASTICITY [1:0] in SGMII/GBIC mode 11 = Support 18k byte packets 00 = support 5k byte packets (w/200 ppm offset) MSB is located at expansion reg 46[15]  RW 1 = SGMII RX FIFO will assume that the SerDes recovered clock and the local clock are frequency locked. This will essentially bypass the FIFO with the lowest possible latency in 10/100 speeds (useful for applications where the MAC/switch and PHY are using the same crystal) 0 = normal operation  AUTO-DETECT SGMII/GBIC RW 1 = enable auto-detection between SGMII and GBIC modes |

# 14.6.31 1Ch: Test 1000-X Register (Shadow Register Selector = "19h")

| Bit   | Name                                        | RW | Description                                                                                                       | Default |
|-------|---------------------------------------------|----|-------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                                | RW | 1 = write bits [9:0]                                                                                              | 0       |
|       |                                             |    | 0 = read bits [9:0]                                                                                               |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR                 | RW | Shadow Register Selector                                                                                          | 11001   |
| 9     | USE COPPER SPEED                            | RW | 1 = force dig1000x speed to copper speed                                                                          | 0       |
|       |                                             |    | (used to test FIFOs in 10/100 mode from GMII pins)                                                                |         |
|       |                                             |    | 0 = normal operation                                                                                              |         |
| 8     | DLL BYPASS CLOCK                            | RW | 1 = enable dll bypass clock (tpin 11)                                                                             | 0       |
|       | ENABLE                                      |    | 0 = disable dll bypass clock                                                                                      |         |
| 7     | TX FIFO SGMII 10/100                        | RW | 3 71                                                                                                              | 0       |
|       | EARLY PREAMBLE MODE =>                      |    | order to reduce latency in half-duplex.                                                                           |         |
|       |                                             |    | (TX FIFO)                                                                                                         |         |
|       | towards SerDes link partner                 |    | 0 = normal operation                                                                                              |         |
| 6     | RX FIFO SGMII 10/100<br>EARLY PREAMBLE MODE | RW | 1 = enable transmitting early preamble in SGMII 10/ 100 mode in order to reduce latency in half-duplex (RX FIFO). | 0       |
|       | =>                                          |    | 0 = normal operation                                                                                              |         |
|       | towards copper link partner                 |    | o – normai operation                                                                                              |         |
| 5     | BLOCK TXEN MODE                             | RW | 1 = block txen for 7 bytes after end of packet in 1000-X mode, 6.5                                                | 0       |
|       | FOR dig1000x tx fifo =>                     |    | bytes in SGMII 10/100.                                                                                            |         |
|       | towards SerDes link partner                 |    | 0 = normal operation                                                                                              |         |
| 4     | RESERVED                                    | RW | write as 0, ignore on read                                                                                        | 0       |
| 3     | FORCE TXFIFO ON                             | RW | 1 = force TXFIFO to be always active in 1000X                                                                     | 0       |
|       | (dig1000x_tx_fifo)                          |    | 0 = normal operation                                                                                              |         |
|       | towards SerDes link partner                 |    |                                                                                                                   |         |
| 2     | BYPASS PCS RECEIVE                          | RW | 1 = bypass pcs receive                                                                                            | 0       |
|       |                                             |    | 0 = normal operation                                                                                              |         |

| Bit | Name         | RW | Description                          | Default |
|-----|--------------|----|--------------------------------------|---------|
| 1   | BYPASS PCS   | RW | 1 = bypass pcs transmit              | 0       |
|     | TRANSMIT     |    | 0 = normal operation                 |         |
| 0   | ZERO COMMA   | RW | 1 = force comma detect phase to zero | 0       |
|     | DETECT PHASE |    | 0 = normal operation                 |         |

## 14.6.32 1Ch: Autoneg 1000-X Debug Register (Shadow Register Selector = "1ah")

| Bit   | Name                        | RW | Description                                                         | Default |
|-------|-----------------------------|----|---------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                                                | 0       |
|       |                             |    | 0 = read bits [9:0]                                                 |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector                                            | 11010   |
| 9     | CONSISTENCY                 | RO | 1 = consistency mismatch occurred since last read                   | 0       |
|       | MISMATCH                    | LH | 0 = no consistency mismatch occurred since last read                |         |
| 8     | RUDI INVALID                | RO | 1 = rudi invalid detected since last read                           | 0       |
|       |                             | LH | 0 = no rudi invalid detected since last read                        |         |
| 7     | SYNC_STATUS DETECTED        | RO | 1 = sync_status detected since last read                            | 0       |
|       |                             | LH | 0 = no sync_status detected since last read                         |         |
| 6     | LINK WENT DOWN FROM         | RO | 1 = a valid link went down due to a loss of                         | 0       |
|       | LOSS OF SYNC                | LH | synchronization for over 10 ms.                                     |         |
|       |                             |    | 0 = failure condition has not been detected since last read         |         |
| 5     | IDLE DETECT STATE           | RO | 1 = idle detect state entered since last read                       | 0       |
|       |                             | LH | 0 = idle detect state has not been entered since last read          |         |
| 4     | COMPLETE                    | RO | 1 = complete acknowledge state entered since last read              | 0       |
|       | ACKNOWLEDGE STATE           | LH | 0 = complete acknowledge state has not been entered since last read |         |
| 3     | ACKNOWLEDGE                 | RO | 1 = acknowledge detect state entered since last read                | 0       |
|       | DETECT STATE                | LH | 0 = acknowledge detect state has not been entered since last read   |         |
| 2     | ABILITY DETECT STATE        | RO | 1 = ability detect state entered since last read                    | 0       |
|       |                             | LH | 0 = ability detect state has not been entered since last read       |         |
| 1     | ERROR STATE                 | RO | 1 = error state entered since last read                             | 0       |
|       | (reg 1ch shadow 27 [3] = 1) | LH | 0 = error state has not been entered since last read                |         |
|       | SYNC_STATUS FAILED          | RO | 1 = sync_status failed since last read                              | 0       |
|       | (reg 1ch shadow 27 [3] = 0) | LH | 0 = sync_status has not failed since last read                      |         |
| 0     | AN_ENABLE STATE             | RO | 1 = an_enable state entered since last read                         | 0       |
|       |                             | LH | 0 = an_enable state has not been entered since last read            |         |

# 14.6.33 1Ch: Auxiliary 1000-X Control Register (Shadow Register Selector = "1bh")

| Bit | Name                        | RW | Description              | Default |
|-----|-----------------------------|----|--------------------------|---------|
| 15  | WRITE ENABLE                | RW | 1 = write bits [9:0]     | 0       |
|     |                             |    | 0 = read bits [9:0]      |         |
| _   | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector | 11011   |

| Bit | Name                                                                   | RW | Description                                                                                                                                       | Default |
|-----|------------------------------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 9   | USE SERDES MODE                                                        | RW | 1 = use registers 12-14h for SerDes data                                                                                                          | 0       |
|     | COUNTERS                                                               |    | 0 = normal operation                                                                                                                              |         |
| 8   | AUTONEG FAST                                                           | RW | 1 = speed up link_timer for test vectors                                                                                                          | 0       |
|     | TIMERS                                                                 |    | (1.6 us SGMII; 9.84 us IEEE)                                                                                                                      |         |
|     |                                                                        |    | 0 = normal operation                                                                                                                              |         |
| 7   | JAM FALSE CARRIER<br>MODE                                              | RW | 1 = Transmit packet on SerDes pins with txen, txer, txd=55h for duration of false carrier received on copper pins in SGMII/GBIC half-duplex mode. | 1       |
|     | DICABLE CARRIER                                                        | DW | 0 = ignore false carriers in SGMII/GBIC mode                                                                                                      | 0       |
| 6   | DISABLE CARRIER                                                        | RW | 1 = force rxer, rxd to zeros in TRR+extend state                                                                                                  | 0       |
|     | EXTEND                                                                 |    | (pcs receive state)                                                                                                                               |         |
|     |                                                                        |    | 0 = normal operation                                                                                                                              |         |
| 5   | DISABLE TRRR                                                           | RW | 1 = bypass extend_by_1 state (pcs transmit state) 0 = normal operation                                                                            | 0       |
| 4   | DISABLE REMOTE FAULT SENSING                                           | RW | 1 = disable automatic remote fault sensing of autoneg resolution errors and offline errors.                                                       | 0       |
|     |                                                                        |    | (offline errors occur in GBIC mode when the copper link is down)                                                                                  |         |
|     |                                                                        |    | 0 = normal operation                                                                                                                              |         |
| 3   | AUTONEG ERROR TIMER<br>ENABLE                                          | RW | 1 = enable autoneg error timer (error state entered when error timer expires in ability_detect, acknowledge_detect, or idle_detect state)         | 0       |
|     |                                                                        |    | 0 = normal operation                                                                                                                              |         |
| 2   | COMMA DETECT                                                           | RW | 1 = enable comma detection                                                                                                                        | 1       |
|     | ENABLE                                                                 |    | 0 = disable comma detection                                                                                                                       |         |
| 1   | FIFO ELASTICITY [0] for                                                | RW | dig1000x_tx_fifo and dig1000x_rx_fifo                                                                                                             | 0       |
|     | dig1000x_tx_fifo and                                                   |    | FIFO ELASTICITY [1:0]:                                                                                                                            |         |
|     | dig1000x_rx_fifo                                                       |    | 11 = support 20k byte packets                                                                                                                     |         |
|     | Modes:                                                                 |    | 10 = support 15k byte packets                                                                                                                     |         |
|     | (RGMII/GMII 1000x towards                                              |    | 01 = support 10k byte packets                                                                                                                     |         |
|     | SerDes link partner)                                                   |    | 00 = support 5k byte packets (w/200 ppm offset)                                                                                                   |         |
|     | (RGMII to SGMII-slave 10/<br>100/ 1000 towards SerDes<br>link partner) |    | MSB located at a register 1ch shadow 16h [0]                                                                                                      |         |
|     | (10/100 SGMII transmit and receive)                                    |    |                                                                                                                                                   |         |
|     | (1000 SGMII transmit from                                              |    |                                                                                                                                                   |         |
|     | copper link partner towards SerDes link partner)                       |    |                                                                                                                                                   |         |
|     | FIFO ELASTICITY [0] for                                                |    |                                                                                                                                                   |         |
|     | dig1000x_tx_fifo and                                                   |    |                                                                                                                                                   |         |
|     | dig1000x_rx_fifo (1000-X                                               |    |                                                                                                                                                   |         |
|     | PCS transmit, 10/100 SGMII                                             |    |                                                                                                                                                   |         |
|     | transmit and receive, 1000                                             |    |                                                                                                                                                   |         |
|     | SGMII transmit from copper link partner towards SerDes                 |    |                                                                                                                                                   |         |
|     | MAC)                                                                   |    |                                                                                                                                                   |         |
| 0   | DISABLE CRC                                                            | RW | 1 = disable crc checker (clock gated-off to save power)                                                                                           | 1       |
|     | CHECKER                                                                |    | 0 = enable crc checker                                                                                                                            |         |
|     | J. ILOIKLIK                                                            |    | O STIGNED OF OFFICERO                                                                                                                             |         |

# 14.6.34 1Ch: Auxiliary 1000-X Status Register (Shadow Register Selector = "1ch")

| Bit   | Name                        | RW | Description                                                                      | Default |
|-------|-----------------------------|----|----------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                                                             | 0       |
|       |                             |    | 0 = read bits [9:0]                                                              |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector                                                         | 11100   |
| 9     | SERDES LINK STATUS          | RO | 1 = link status change has occurred since last read                              | 0       |
|       | CHANGE                      | LH | 0 = link status change has not occurred since last read                          |         |
| 8     | SGMII SELECTOR              | RO | 1 = SGMII selector mismatch in SGMII mode                                        | 0       |
|       | MISMATCH                    |    | 0 = Fiber, copper, GBIC mode, or SGMII                                           |         |
|       |                             |    | selector does not mismatch, or autoneg disabled                                  |         |
| 7     | AUTONEG                     | RO | 1 = autoneg hcd is none (no common half or full duplex abilities)                | 0       |
|       | RESOLUTION ERROR            |    | 0 = SGMII mode, or autoneg disabled, or no resolution error                      |         |
| 6:5   | LINK PARTNER                | RO | 1000-X register 5 [13:12]                                                        | 00      |
|       | REMOTE FAULT                |    |                                                                                  |         |
| 4     | AUTONEG PAGE                | RO | 1 = page has been received since last read                                       | 0       |
|       | RECEIVED                    | LH | 0 = page has not been received since last read                                   |         |
| 3     | CURRENT OPERATING           | RO | 1 = phy is operating in full-duplex mode                                         | 0       |
|       | DUPLEX MODE                 |    | 0 = phy is operating in half-duplex mode (or auto-negotiation has not completed) |         |
| 2     | SERDES LINK                 | RO | 1 = link is up for SerDes applications                                           | 0       |
|       |                             |    | (SGMII or GBIC mode => both SerDes and copper must have link                     |         |
|       |                             |    | for this bit to be set)                                                          |         |
|       |                             |    | 0 = link is down for SerDes applications                                         |         |
| 1     | PAUSE RESOLUTION-           | RO | 1 = enable pause receive                                                         | 0       |
|       | RECEIVE SIDE                |    | 0 = disable pause receive                                                        |         |
| 0     | PAUSE RESOLUTION-           | RO | 1 = enable pause transmit                                                        | 0       |
|       | TRANSMIT SIDE               |    | 0 = disable pause transmit                                                       |         |

## 14.6.35 1Ch: Misc 1000-X Status Register (Shadow Register Selector = "1dh")

| Bit   | Name                              | RW       | Description                                                                                                                                                                                       | Default |
|-------|-----------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                      | RW       | 1 = write bits [9:0]                                                                                                                                                                              | 0       |
|       |                                   |          | 0 = read bits [9:0]                                                                                                                                                                               |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR       | RW       | Shadow Register Selector                                                                                                                                                                          | 11101   |
| 9     | TX FIFO ERROR                     | RO<br>LH | 1 = transmit FIFO error since last read 0 = no transmit FIFO error since last read                                                                                                                | 0       |
| 8     | RX FIFO ERROR                     | RO<br>LH | 1 = receive FIFO error since last read 0 = no receive FIFO error since last read                                                                                                                  | 0       |
| 7     | BAD FIFO POINTER                  | RO<br>LH | 1 = FIFO pointer all zeros since last read 0 = bad FIFO pointer has not occurred since last read                                                                                                  | 0       |
| 6     | FALSE CARRIER JAMMED<br>(TX SIDE) | RO<br>LH | 1 = false carrier detected on copper receiver and jammed in SGMII/GBIC mode to SerDes transmitter since last read 0 = no false carrier jammed or mode is disabled via register 1ch shadow 1bh [7] | 0       |
| 5     | FALSE CARRIER DETECTED (RX SIDE)  | RO<br>LH | 1 = false carrier detected on SerDes receiver since last read 0 = no false carriers detected since last read                                                                                      | 0       |
| 4     | CRC ERROR<br>DETECTED             | RO<br>LH | 1 = crc error detected since last read 0 = no crc error detected since last read or mode is disabled via register 1ch shadow 1bh [0]                                                              | 0       |
| 3     | TRANSMIT ERROR<br>DETECTED        | RO<br>LH | 1 = transmit error code detected since last read (rx_data_error state in pcs receive) 0 = no transmit error code detected since last read                                                         | 0       |
| 2     | RECEIVE ERROR<br>DETECTED         | RO<br>LH | 1 = receive error since last read (early_end state in pcs receive) 0 = no receive error since last read                                                                                           | 0       |
| 1     | CARRIER EXTEND<br>ERROR DETECTED  | RO<br>LH | 1 = carrier extend error since last read (extend_err state in pcs receive) 0 = no carrier extend error since last read                                                                            | 0       |
| 0     | EARLY END EXTENSION DETECTED      | RO<br>LH | 1 = early end extension since last read (early_end_ext state in pcs receive) 0 = no early end extension since last read                                                                           | 0       |

## 14.6.36 1Ch: Auto-Detect Medium Register (Shadow Register Selector = "1eh")

| Bit   | Name                         | RW | Description                                                                                                                                | Default |
|-------|------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                 | RW | 1 = write bits [9:0]<br>0 = read bits [9:0]                                                                                                | 0       |
| 14:10 | SHADOW REGISTER<br>SELECTOR  | RW | Shadow Register Selector                                                                                                                   | 11110   |
| 9     | 2ND SERDES<br>AUTO-DETECTION | RW | 1 = enable dual SerDes auto-detect medium<br>(switch between SGMII->fiber and SGMII->copper)<br>0 = disable dual SerDes auto-detect medium | 0       |
| 8     | INVERT FIBER SD FROM<br>PIN  | RW | 1 = invert fiber sd from pin (active low pin) 0 = normal operation (active high pin)                                                       | 0       |

| Bit | Name                                            | RW | Description                                                                                                               | Default |
|-----|-------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------|---------|
| 7   | FIBER IN-USE LED<br>MODE                        | RW | 1 = drive transmit led active low when fiber is selected, inactive when copper selected                                   | 0       |
|     |                                                 |    | 0 = normal transmit led operation                                                                                         |         |
| 6   | FIBER LED MODE                                  | RW | 1 = use fiber transmit, receive, and link for leds whenever fiber mode is selected via register 1ch shadow 1fh bits [2:1] | 0       |
|     |                                                 |    | 0 = always use copper transmit, receive, and link for leds regardless of the mode selected                                |         |
| 5   | QUALIFY FIBER SD WITH<br>SYNC_STATUS/100FX LINK | RW | 1 = fiber signal detect from pin is ANDed with sync_status in 1000-x and link in 100-fx mode.                             | 1       |
|     |                                                 |    | (Used only for auto-detect medium and dual SerDes auto-detection.)                                                        |         |
|     |                                                 |    | 0 = normal operation                                                                                                      |         |
| 4   | FIBER AUTO-POWER                                | RW | 1 = power-down fiber when signal detect                                                                                   | 0       |
|     | DOWN MODE                                       |    | is inactive (wake-up for 42ms every 5 seconds to transmit code                                                            |         |
|     | (register 1c shadow 1fh                         |    | words; see register 1ch shadow 17h [8:7] for different time options).                                                     |         |
|     | bit 2 must be 0 unless a fiber                  |    | 0 = normal operation                                                                                                      |         |
|     | module is used in media converter mode)         |    |                                                                                                                           |         |
| 3   | SIGNAL DETECT ENABLE                            | RW | 1 = force signal detect enable to 1 in auto-detect medium block.                                                          | 0       |
|     | OVERRIDE                                        |    | Used for test purposes only!                                                                                              |         |
|     |                                                 |    | 0 = normal operation                                                                                                      |         |
| 2   | AUTO-DETECT                                     | RW | 1 = fiber selected when no medium active                                                                                  | 0       |
|     | MEDIUM DEFAULT                                  |    | 0 = copper selected when no medium active                                                                                 |         |
| 1   | AUTO-DETECT                                     | RW | 1 = fiber selected when both medium active                                                                                | 1       |
|     | MEDIUM PRIORITY                                 |    | 0 = copper selected when both medium active                                                                               |         |
| 0   | AUTO-DETECT                                     | RW | 1 = enable auto-detect medium                                                                                             | 0       |
|     | MEDIUM ENABLE                                   |    | (switch between GMII/RGMII->copper or                                                                                     |         |
|     |                                                 |    | GMII/RGMII->fiber)                                                                                                        |         |
|     |                                                 |    | 0 = disable auto-detect medium                                                                                            |         |

# 14.6.37 1Ch: Mode Control Register (Shadow Register Selector = "1fh")

| Bit   | Name                        | RW | Description                                                                      | Default |
|-------|-----------------------------|----|----------------------------------------------------------------------------------|---------|
| 15    | WRITE ENABLE                | RW | 1 = write bits [9:0]                                                             | 0       |
|       |                             |    | 0 = read bits [9:0]                                                              |         |
| 14:10 | SHADOW REGISTER<br>SELECTOR | RW | Shadow Register Selector                                                         | 11111   |
| 9     | DUAL SERDES CAPABLE         | RO | 1 = chip supports SGMII->fiber mode                                              | 0       |
|       |                             |    | 0 = chip does not support SGMII->fiber mode                                      |         |
| 8     | MODE SELECT CHANGE          | RO | 1 = mode select change since last read                                           | 0       |
|       |                             | LH | 0 = no mode select change since last read                                        |         |
| 7     | COPPER LINK                 | RO | 1 = link up on copper side (copper, SGMII, or GBIC mode)                         | 0       |
|       |                             |    | 0 = link down                                                                    |         |
| 6     | SERDES LINK                 | RO | 1 = link up in fiber, SGMII,or GBIC modes                                        | 0       |
|       |                             |    | (when set in SGMII or GBIC mode, then both copper and SerDes link must be valid) |         |
|       |                             |    | 0 = link down                                                                    |         |

| Bit | Name                         | RW | Description                                     | Default |
|-----|------------------------------|----|-------------------------------------------------|---------|
| 5   | COPPER ENERGY                | RO | 1 = copper energy detected                      | 0       |
|     | DETECT                       |    | 0 = no copper energy detected                   |         |
| 4   | FIBER SIGNAL                 | RO | 1 = fiber signal detect from pin and code group | 0       |
|     | DETECT and                   |    | synchronization (filtered).                     |         |
|     | SYNC_STATUS (filtered)       |    | (In 100-FX mode use link status instead of      |         |
|     | (reg 1ch shadow 1eh [5] = 1) |    | synchronization)                                |         |
|     |                              |    | 0 = no fiber signal detect from pin             |         |
| 3   | SERDES CAPABLE               | RO | 1 = SerDes capable device                       | 0       |
|     |                              |    | 0 = not SerDes capable device                   |         |
| 2:1 | MODE SELECT                  | RW | 00 = copper-qsgmii                              | 0       |
|     |                              |    | 01 = fiber-qsgmii                               |         |
|     |                              |    | 10 = SGMII-copper                               |         |
|     |                              |    | 11 = GBIC                                       |         |
| 0   | ENABLE 1000-X                | RW | 1 = select 1000-X regs 0-0fh                    | 0       |
|     | REGISTERS                    |    | 0 = select copper regs 0-0fh                    |         |

# 14.6.38 1Dh: Primary/Secondary Seed Register (Bit 15 = 0)

| Bit    | Name                                                                                                   | RW       | Description                                                                                                                                                                                                                                                                                                | Default |
|--------|--------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15     | ENABLE SHADOW REGISTER Writes to the selected register are done on a single cycle (no setup required). | RW       | 1 = select shadow register 0 = normal operation                                                                                                                                                                                                                                                            | 0       |
| 14     | MASTER/SLAVE SEED<br>MATCH                                                                             | RO<br>LH | 1 = Seeds match 0 = Seeds don't match (Value not latched when bit9 in reg 1Fh is set)                                                                                                                                                                                                                      | 0       |
| 13     | LINK PARTNER REPEATER/<br>DTE BIT                                                                      | RO*      | 1 = link partner is a repeater/switch device port 0 = link partner is a DTE device port                                                                                                                                                                                                                    | 0       |
| 12     | LINK PARTNER MANUAL M/<br>S CONFIG VALUE                                                               | RO*      | 1 = link partner is configured as Primary 0 = link partner is configured as Secondary                                                                                                                                                                                                                      | 0       |
| 11     | LINK PARTNER MANUAL M/<br>S CONFIG ENABLE                                                              | RO*      | 1 = link partner manual Primary/Secondary configuration enabled<br>0 = link partner manual Primary/Secondary configuration disabled                                                                                                                                                                        | 0       |
| 10:0   | LOCAL MASTER/SLAVE<br>SEED VALUE                                                                       | RW       | Returns the automatically generated Primary/Secondary random seed when bits 9 and 11 in reg 1Fh are cleared. Writeable value is used for Primary/Secondary seed when bit 11 in reg 1Fh is set and the link partner base page is received; writable value is used immediately when bit 9 in reg 1Fh is set. | 000h    |
| * RW \ | when "writeable link partner abil                                                                      | ity test | mode" (reg 1Fh bit 10) is set                                                                                                                                                                                                                                                                              |         |

# 14.6.39 1Dh: HCD Status Register (Bit 15 = 1)

| Bit    | Name                                                                                                   | RW       | Description                                                                                  | Default |
|--------|--------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------|---------|
| 15     | ENABLE SHADOW REGISTER Writes to the selected register are done on a single cycle (no setup required). | RW       | 1 = select shadow register<br>0 = normal operation                                           | 0       |
| 14     | WIRESPEED DISABLE<br>GIGABIT ADVERTISING                                                               | RO       | 1 = disable advertising Gigabit<br>0 = advertise Gigabit based on register 9                 | 0       |
| 13     | WIRESPEED DISABLE<br>100TX ADVERTISING                                                                 | RO       | 1 = disable advertising 100tx<br>0 = advertise 100tx based on register 4                     | 0       |
| 12     | WIRESPEED DOWN GRADE                                                                                   | RO<br>LH | 1 = wirespeed downgrade occurred since last read 0 = wirespeed downgrade cleared             | 0       |
| 11     | * HCD 1000T FDX                                                                                        | RO<br>LH | 1 = Gigabit full-duplex hcd occurred since last read 0 = hcd cleared                         | 0       |
| 10     | * HCD 1000T                                                                                            | RO<br>LH | 1 = Gigabit half-duplex hcd occurred since last read 0 = hcd cleared                         | 0       |
| 9      | * HCD 100T FDX                                                                                         | RO<br>LH | 1 = 100tx full-duplex hcd occurred since last read 0 = hcd cleared                           | 0       |
| 8      | * HCD 100T                                                                                             | RO<br>LH | 1 = 100tx half-duplex hcd occurred since last read 0 = hcd cleared                           | 0       |
| 7      | * HCD 10T FDX                                                                                          | RO<br>LH | 1 = 10base-t full-duplex hcd occurred since last read 0 = hcd cleared                        | 0       |
| 6      | * HCD 10T                                                                                              | RO<br>LH | 1 = 10base-t half-duplex hcd occurred since last read 0 = hcd cleared                        | 0       |
| 5      | * HCD 1000T FDX<br>(Link never came up)                                                                | RO<br>LH | 1 = Gigabit full-duplex hcd and link never came up occurred since last read 0 = hcd cleared  | 0       |
| 4      | * HCD 1000T<br>(Link never came up)                                                                    | RO<br>LH | 1 = Gigabit half-duplex hcd and link never came up occurred since last read 0 = hcd cleared  | 0       |
| 3      | * HCD 100T FDX<br>(Link never came up)                                                                 | RO<br>LH | 1 = 100tx full-duplex hcd and link never came up occurred since last read 0 = hcd cleared    | 0       |
| 2      | * HCD 100T<br>(Link never came up)                                                                     | RO<br>LH | 1 = 100tx half-duplex hcd and link never came up occurred since last read 0 = hcd cleared    | 0       |
| 1      | * HCD 10T FDX<br>(Link never came up)                                                                  | RO<br>LH | 1 = 10base-t full-duplex hcd and link never came up occurred since last read 0 = hcd cleared | 0       |
| 0      | * HCD 10T<br>(Link never came up)                                                                      | RO<br>LH | 1 = 10base-t half-duplex hcd and link never came up occurred since last read 0 = hcd cleared | 0       |
| * Bits | ⊥<br>[12:0] also cleared on restarting                                                                 | or disa  |                                                                                              |         |

## 14.6.40 1Eh: Test1\_Register

| Bit | Name                           | RW | Description                                                                                                                                      | Default |
|-----|--------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15  | CRC ERROR COUNT<br>VISIBILITY  | RW | 1 = receiver NOT_OK counters merged into one 16 bit counter to count CRC errors instead                                                          | 0       |
|     |                                |    | (crc errors will only be counted after this bit                                                                                                  |         |
|     |                                |    | is set!)                                                                                                                                         |         |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 14  | TRANSMIT ERROR CODE VISIBILITY | RW | 1 = false carrier sense counter counts packets received with transmit error codes instead                                                        | 0       |
|     |                                |    | (errors will only be counted after this bit is set!)                                                                                             |         |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 13  | COUNTER TEST MODE              | RW | 1 = forces counters into test mode                                                                                                               | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 12  | FORCE LINK                     | RW | 1 = force link state machine into pass state                                                                                                     | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 11  | FORCE LOCK                     | RW | 1 = force descrambler in to locked state                                                                                                         | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 10  | SCRAMBLER TEST                 | RW | 1 = speed up descrambler unlock detect timer                                                                                                     | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 9   | EXTERNAL LINK                  | RW | 1 = use tpin11 input as link status                                                                                                              | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 8   | FAST TIMERS                    | RW | 1 = timers are sped up for LSI test                                                                                                              | 0       |
|     |                                |    | 0 = normal operation                                                                                                                             |         |
| 7   | MANUAL SWAP MDI STATE          | RW | 1 = Swap                                                                                                                                         | 0       |
|     |                                |    | 0 = off                                                                                                                                          |         |
| 6   | RECEIVE WATCHDOG               | RW | 1 = watchdog timer disabled                                                                                                                      | 0       |
|     | TIMER DISABLE                  |    | 0 = reset receive PMD when descrambler can't lock within 730us of link or lock                                                                   |         |
|     |                                |    | loss.                                                                                                                                            |         |
| 5   | DISABLE POLARITY               | RW | 1 = disable 1000BASE-T polarity encoding                                                                                                         | 0       |
|     | ENCODE                         |    | 0 = normal operation                                                                                                                             |         |
| 4   |                                | RW | 1 = use software trim setting                                                                                                                    | 0       |
|     | SETTING (MAIN DAC)             |    | 0 = use hardware trim setting                                                                                                                    |         |
|     |                                |    | Notes:                                                                                                                                           |         |
|     |                                |    | 1) register settings from slice1, slice8 are used to control main dac                                                                            |         |
|     |                                |    | 2) register settings from slice2, slice7 are used to control hybrid dac                                                                          |         |
| 3:0 | TRIM[3:0] (MAIN DAC)           | RW | Software trim setting                                                                                                                            | 0       |
|     |                                |    | Notes:                                                                                                                                           |         |
|     |                                |    | 1) only slice1, slice8 register setting are used.                                                                                                |         |
|     |                                |    | 2) Main dac value going to BIAS block (when enable software trim setting = 0) is fuse_in(main dac)+011(default)+software trim setting (main dac) |         |

## 14.6.41 1Fh: Test2\_Register

| Bit   | Name                                                                                                                                      | RW | Description                                                                                                                                                            | Default |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15:13 | TEST SELECT AUTONEG<br>FSM                                                                                                                | RW | 000 = ARB<br>001 = RX1000<br>010 = RX<br>011 = TX1000<br>100 = TX<br>101 = BASET LINK                                                                                  | 000     |
| 12    | TEST AUTO-NEG TIMER                                                                                                                       | RW | 1 = auto-negotiation timer test mode<br>0 = normal operation                                                                                                           | 0       |
| 11    | TEST MASTER/SLAVE<br>SEED                                                                                                                 | RW | 1 = use MDIO programmable Primary/Secondary seed 0 = normal operation                                                                                                  | 0       |
| 10    | WRITEABLE LINK PARTNER<br>ABILITY                                                                                                         | RW | 1 = link partner advertised ability may be overwritten by MII management 0 = normal operation                                                                          | 0       |
| 9     | FORCE HCD                                                                                                                                 | RW | 1 = force auto-negotiation HCD resolution<br>(hcd can only be checked in register 19h bits [10:8]; hcd status<br>register will not be updated)<br>0 = normal operation | 0       |
| 8     | WRITEABLE LINK PARTNER<br>M/S SEED                                                                                                        | RW | 1 = link partner Primary/Secondary seed may be overwritten by MII management 0 = normal operation                                                                      | 0       |
| 7     | TRANSMIT 10B MODE                                                                                                                         | RW | 1 = force GMII transmit into 10B mode 0 = use normal mode bit                                                                                                          | 0       |
| 6     | RECEIVE 10B MODE                                                                                                                          | RW | 1 = force GMII receive into 10B mode 0 = use normal mode bit                                                                                                           | 0       |
| 5     | BYPASS TRANSMIT FIFO modes: (RGMII 10/100/1000 copper) (SGMII 1000 towards copper link partner) (RGMII 100fx towards SerDes link partner) | RW | 1 = transmit FIFO bypassed<br>0 = normal operation                                                                                                                     | 0       |
| 4     | SAME SCRAMBLER SEEDS                                                                                                                      | RW | <ul><li>1 = receive scrambler uses transmit seed</li><li>0 = normal operation</li></ul>                                                                                | 0       |
| 3     | JITTER TEST MODE                                                                                                                          | RW | 1 = jitter test mode<br>0 = normal operation                                                                                                                           | 0       |
| 2     | TEST ATMP COUNTER                                                                                                                         | RW | 1 = force Primary Secondary seed attempt counter into test mode 0 = normal mode                                                                                        | 0       |
| 1     | LATENCY MEASURE                                                                                                                           | RW | 1 = send special short packet to measure receive latency on remote PHY (hold high) 0 = normal operation                                                                | 0       |
| 0     | DISABLE ACTIVE HYBRID                                                                                                                     | RW | 1 = active hybrid disabled 0 = active hybrid enabled                                                                                                                   | 0       |

## 14.7 SerDes PHY Register Definitions

The PHY registers are broken into two blocks:

- Block 0 is for IEEE and non-IEEE controls.
- Blocks 0, 2 and 3 are non-IEEE blocks, where the analog section or the SerDes is controlled.

To access block 0, 2 or 3, write to the block number into the Block Address register at address 0x1F (reserved on each block).

#### 14.7.1 Register Map

| Address | Block | Register Name                | Description                                                             |
|---------|-------|------------------------------|-------------------------------------------------------------------------|
| 00h     | 0     | MII CONTROL                  | MII Control Register                                                    |
| 01h     | 0     | MII STATUS                   | MII Status Register                                                     |
| 02h     | 0     | PHY ID MSB                   | PHY_Identifier_MSB_Register                                             |
| 03h     | 0     | PHY ID LSB                   | PHY_Identifier_LSB_Register                                             |
| 04h     | 0     | AUTONEGADV                   | Auto-Negotiation advertisement register                                 |
| 05h     | 0     | AUTONEG LINK PARTNER ABILITY | Auto-Negotiation Link Partner Ability                                   |
| 06h     | 0     | AUTONEGEXPANSION             | Auto-Negotiation Expansion register                                     |
| 07h-0Eh | 0     | _                            | Reserved                                                                |
| 0Fh     | 0     | EXTENDEDSTATUS               | Extended Status register                                                |
| 10h     | 0     | 1000XCONTROL1                | 1000XControl 1 register                                                 |
| 11h     | 0     | 1000XCONTROL2                | 1000XControl 2 register                                                 |
| 12h     | 0     | 1000XCONTROL3                | 1000XControl 3 register                                                 |
| 14h     | 0     | 1000XSTATUS1                 | 1000XStatus 1 register                                                  |
| 15h     | 0     | 1000XSTATUS2                 | 1000XStatus 2 register                                                  |
| 16h     | 0     | 1000XSTATUS3                 | 1000XStatus 3 register                                                  |
| 17h     | 0     | _                            | Reserved                                                                |
| 18h     | 0     | GE_PRBS_CONTROL              | Enable PRBS test mode                                                   |
| 19h     | 0     | GE_PRBS_STATUS               | PRBS test mode status                                                   |
| 1Ah–1Eh | 0     | -                            | Reserved                                                                |
| 10h     | 2     | FXCONTROL1                   | 100FX Enabling Control register                                         |
| 11h     | 2     | FXCONTROL2                   | 100FX Extended Packet Size register                                     |
| 12h     | 2     | FXCONTROL3                   | 100FX Control register                                                  |
| 13h     | 2     | FXSTATUS1                    | 100FX Link Status register                                              |
| 14h-1Eh | 2     | _                            | Reserved                                                                |
| 10h     | 3     | ANALOG_TX1                   | Analog transmitter output for the SerDes when it is in SGMII mode.      |
| 11h     | 3     | ANALOG_TX2                   | Analog transmitter2 output for the SerDes when it is in SGMII mode.     |
| 12h     | 3     | ANALOG_TXAMP                 | Analog transmitter output for the SerDes when it is in FX (Fiber) mode. |
| 13h     | 3     | ANALOG_RX1                   | Controlling the SerDes receiver                                         |
| 14h     | 3     | ANALOG_RX2                   | 100FX Test Mode                                                         |
| 18h     | 3     | ANALOG_PLL                   | Controlling the GE PLL circuitry                                        |
| 1Fh     | -     | BLOCKADDRESS                 | Block address register                                                  |

Figure 55: SerDes PHY Register Map



#### 14.7.2 MII Control

Register Description: MII Control Register.

Register Offset: 0x0 at Block 0

| Bits | Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW | Description                                                                                    | Default |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------------------------------------------------------------------------------------|---------|
| 15   | RST_SW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW | PHY Reset                                                                                      | 0       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Normal Operation                                                                           |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Reset                                                                                      |         |
| 14   | LOOPBACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW | Local loopback, data is looping back at the PHY before going out to the wire                   | . 0     |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Normal operation                                                                           |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Loopback enable                                                                            |         |
| 13   | SPD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW | Bit[0] of manual Speed[1:0] in SGMII mode only. This field is ignored in                       | 0x0     |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1000Base-X operation.                                                                          |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1X = 1000 Mbps                                                                                 |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 01 = 100 Mbps                                                                                  |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 00 = 10 Mbps                                                                                   |         |
| 12   | AN_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW | Auto-negotiation enable                                                                        | 1       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Disable                                                                                    |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Enable AN                                                                                  |         |
| 11   | PWRDN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW | Power down GE SerDes                                                                           | 0       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Normal operation                                                                           |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Power-down the SerDes PHY                                                                  |         |
| 10   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RO | Reserved write 0, ignore read                                                                  | 0       |
| 9    | RESTART_AN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW | Restart Auto-negotiation process                                                               | 0       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Normal operation                                                                           |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Restart AN                                                                                 |         |
| 8    | FDX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RW | Duplex mode                                                                                    | 0       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Half duplex                                                                                |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Full duplex                                                                                |         |
| 7    | COL_TEST_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW | Collision test enable                                                                          | 0       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 0 = Normal operation                                                                           |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1 = Collision test                                                                             |         |
| 6    | SPD[1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW | Bit[1] of manual Speed[1:0] in SGMII mode only. This field is ignored in 1000Base-X operation. | 1       |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 1X = 1000 Mbps                                                                                 |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 01 = 100 Mbps                                                                                  |         |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    | 00 = 10 Mbps                                                                                   |         |
| 5:0  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RO | Reserved write 0, ignore read.                                                                 | 0x0     |
|      | The state of the s |    |                                                                                                |         |

#### **14.7.3 MII Status**

Register Description: MII Status Register.

Register Offset: 0x1 at Block 0

| Bits | Name              | RW | Description                                                                       | Default |
|------|-------------------|----|-----------------------------------------------------------------------------------|---------|
| 15   | 100BASE_T4        | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 100Base-T4 capable.                                                           |         |
| 14   | 100BASEX_FDX      | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 100BASE-X full-duplex capable.                                                |         |
| 13   | 100BASEX_HDX      | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 100BASE-X half-duplex capable.                                                |         |
| 12   | 10BASET_FDX       | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 10BASE-T full-duplex capable.                                                 |         |
| 11   | 10BASET_HDX       | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 10BASE-T half-duplex capable.                                                 |         |
| 10   | 10BASET2_FDX      | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 10BASE-T2 full-duplex capable.                                                |         |
| 9    | 10BASET2_HDX      | RO | 0 = Incapable.                                                                    | 0       |
|      |                   |    | 1 = 10BASE-T2 half-duplex capable.                                                |         |
| 8    | EXT_STATUS        | RO | 0 = No extended status.                                                           | 1       |
|      |                   |    | 1 = Extended status in register 0x0F.                                             |         |
| 7    | RESERVED          | RO | Reserved write 0, ignore read.                                                    | 0       |
| 6    | MF_PREAMBLE_SUPPR | RO | 0 = PHY does not accept management frames with preamble suppressed.               | 1       |
|      | ESSION            |    | 1 = PHY accepts management frames with preamble suppressed.                       |         |
| 5    | AN_COMPLETE       | RO | Auto-negotiation complete.                                                        | 0       |
|      |                   |    | 0 = Incomplete.                                                                   |         |
|      |                   |    | 1 = AN complete.                                                                  |         |
| 4    | RF                | RO | Remote fault.                                                                     | 0       |
|      |                   |    | 0 = No fault detected.                                                            |         |
|      |                   |    | 1 = Remote fault detected.                                                        |         |
| 3    | AN_ABILITY        | RO | Auto-negotiation ability.                                                         | 1       |
|      |                   |    | 0 = Incapable of AN.                                                              |         |
|      |                   |    | 1 = AN capable.                                                                   |         |
| 2    | LINK_STATUS       | RO | Link status.                                                                      | 0       |
|      |                   |    | 0 = Link fail.                                                                    |         |
| _    |                   |    | 1 = Good link.                                                                    |         |
| 1    | JABBER_DETECT     | RO | Jabber detect                                                                     | 0       |
|      |                   |    | 0 = Not detected                                                                  |         |
| 0    | EVT CADADULTY     | DC | 1 = Jabber detected                                                               | 1       |
| 0    | EXT_CAPABILITY    | RO | Extended capability                                                               | 1       |
|      |                   |    | 0 = Supports basic register set only 1 = Extended register capabilities supported |         |
|      |                   |    | i – Exterided register capabilities supported                                     |         |

| Bits | Name    | RW | Description                                     | Default |
|------|---------|----|-------------------------------------------------|---------|
| 15:0 | OUI_MSB | RO | Bits 3:18 of organizationally unique identifier | 0143h   |

| Bits  | Name    | RW | Description                                     | Default |
|-------|---------|----|-------------------------------------------------|---------|
| 15:10 | OUI_MSB | RO | Bits 3:18 of organizationally unique identifier | 101111  |

| Bits | Name     | RW | Description            | Default |
|------|----------|----|------------------------|---------|
| 9:4  | MODEL    | RO | Device Model number    | 111111  |
| 3:0  | REVISION | RO | Device revision number | 0000    |

#### 14.7.4 AUTONEGADV

Register Description: Auto-negotiation capability register.

Register Offset: 0x4 at Block 0

| Bits  | Name     | RW | Description                                                       | Default |
|-------|----------|----|-------------------------------------------------------------------|---------|
| 15    | NEXT_PG  | RO | Next page                                                         | 0       |
| 14    | RESERVED | RO | Reserved write 0, ignore read                                     | 0       |
| 13:12 | RF       | RW | Remote fault                                                      | 0x0     |
|       |          |    | 2'b00 = No fault                                                  |         |
|       |          |    | 2'b01 = Link failure                                              |         |
|       |          |    | 2'b10 = Offline                                                   |         |
|       |          |    | 2'b11 = Auto-negotiation error                                    |         |
| 11:9  | RESERVED | RO | Reserved write 0, ignore read                                     | 0x0     |
| 8:7   | PAUSE    | RW | Pause                                                             | 0x0     |
|       |          |    | 2'b00 = No pause                                                  |         |
|       |          |    | 2'b01 = Asymmetric pause                                          |         |
|       |          |    | 2'b10 = Asymmetric pause towards link partner                     |         |
|       |          |    | 2'b11 = Both symmetric and asymmetric pause, towards local device |         |
| 6     | HDX      | RW | Half-duplex                                                       | 1       |
|       |          |    | 0 = Do not advertise half-duplex                                  |         |
|       |          |    | 1 = Advertise half-duplex                                         |         |
| 5     | FDX      | RW | Full-duplex                                                       | 1       |
|       |          |    | 0 = Do not advertise full-duplex                                  |         |
|       |          |    | 1 = Advertise full-duplex                                         |         |
| 4:0   | RESERVED | RO | Reserved write 0, ignore read.                                    | 0x0     |

## 14.7.5 AUTONEG Link Partner Ability

**Register Description:** Auto-negotiation link partner ability register.

Register Offset: 0x5 at Block 0.

| Bits  | Name    | RW | Description                                      | Default |
|-------|---------|----|--------------------------------------------------|---------|
| 15    | NEXT_PG | RO | Next page                                        | 0       |
| 14    | ACK     | RO | 0 = Link partner has not received link code word | 0       |
|       |         |    | 1 = Link partner has received link code word     |         |
| 13:12 | RF      | RO | Remote fault                                     | 0x0     |
|       |         |    | 2'b00 = No fault                                 |         |
|       |         |    | 2'b01 = Link failure                             |         |
|       |         |    | 2'b10 = Offline                                  |         |
|       |         |    | 2'b11 = Auto-negotiation error                   |         |

| Bits | Name     | RW | Description                                                       | Default |
|------|----------|----|-------------------------------------------------------------------|---------|
| 11:9 | RESERVED | RO | Reserved write 0, ignore read                                     | 0x0     |
| 8:7  | PAUSE    | RO | Pause                                                             | 0x0     |
|      |          |    | 2'b00 = No pause                                                  |         |
|      |          |    | 2'b01 = Symmetric pause                                           |         |
|      |          |    | 2'b10 = Asymmetric pause towards link partner                     |         |
|      |          |    | 2'b11 = Both symmetric and asymmetric pause, towards local device |         |
| 6    | HDX      | RO | Half-duplex                                                       | 0       |
|      |          |    | 0 = Do not advertise half-duplex                                  |         |
|      |          |    | 1 = Advertise half-duplex                                         |         |
| 5    | FDX      | RO | Full-duplex                                                       | 0       |
|      |          |    | 0 = Do not advertise full-duplex                                  |         |
|      |          |    | 1 = Advertise full-duplex                                         |         |
| 4:1  | RESERVED | RO | Reserved write 0, ignore read.                                    | 0x0     |
| 0    | SGMII    | RO | SGMII mode                                                        | 0       |
|      |          |    | 0 = Fiber mode                                                    |         |
|      |          |    | 1 = SGMII mode                                                    |         |

When the link partner is in SGMII mode (bit-0 = 1), then:

Bit[15] = Link

Bit[14] = Acknowledge

Bit[13] = Duplex

Bit[11:10] = Speed

The other bits are reserved and should be zero.

#### 14.7.6 AUTONEGEXPANSION

**Register Description:** Auto-negotiation expansion register.

Register Offset: 0x6 at Block 0

| Bits | Name       | RW | Description                                   | Default |
|------|------------|----|-----------------------------------------------|---------|
| 15:3 | RESERVED   | RO | Reserved                                      | 0x000   |
| 2    | NP_ABILITY | RO | Next page ability                             | 0       |
|      |            |    | 0 = Local device is not next page capable.    |         |
|      |            |    | 1 = Local device is next page capable.        |         |
| 1    | PG_REC     | RO | Page received                                 | 0       |
|      |            |    | 0 = New link code word has not been received. |         |
|      |            |    | 1 = Received new link code word.              |         |
| 0    | RESERVED   | RO | Reserved write 0, ignore read.                | 0       |

#### 14.7.7 EXTENDEDSTATUS

Register Description: Extended status register.

Register Offset: 0xF at Block 0

| Bits | Name          | RW | Description                                                                    | Default |
|------|---------------|----|--------------------------------------------------------------------------------|---------|
| 15   | 1000BASEX_FDX | RO | 0 = 1000Base-X full duplex not capable. 1 = 1000Base-X full duplex capable.    | 1       |
| 14   | 1000BASEX_HDX | RO | 0 = 1000Base-X half duplex not capable.<br>1 = 1000Base-X half duplex capable. | 1       |
| 13   | 1000BASET_FDX | RO | 0 = 1000Base-T full duplex not capable. 1 = 1000Base-T full duplex capable.    | 0       |
| 12   | 1000BASET_HDX | RO | 0 = 1000Base-T half duplex not capable. 1 = 1000Base-T half duplex capable.    | 0       |
| 11:0 | RESERVED      | RO | Reserved write 0, ignore read.                                                 | 0x000   |

#### 14.7.8 1000XCONTROL1

Register Description: 1000X Control1 Register.

Register Offset: 0x10 at Block 0

| Bits | Name                        | RW | Description                                                                                                                | Default |
|------|-----------------------------|----|----------------------------------------------------------------------------------------------------------------------------|---------|
| 15   | RESERVED                    | RO | Reserved write 0, ignore read                                                                                              | 0       |
| 14   | DIS_SD_FILTER               | RW | 0 = Filter signal detect from pin before using for synchronization.                                                        | 0       |
|      |                             |    | 1 = Disable filter for signal detect.                                                                                      |         |
| 13   | MSTR_MDIO_PHY_SEL           | RW | 0 = Normal operation.                                                                                                      | 0       |
|      |                             |    | 1 = All MDIO write accesses to PHY address "00000" will write this PHY in addition to its own PHY address.                 |         |
| 12   | SERDES_TX_AMPL_OV<br>ERRIDE | RW | 0 = If SGMII mode, use analog txCntrl Reg. (reg. 3*10h and reg. 3*11h), if fiber mode, use analog txAmp Reg. (reg. 3*12h). | 0       |
|      |                             |    | 1 = Use analog txCntrl Reg. (reg. 3*10h and reg. 3*11h).                                                                   |         |
| 11   | SEL_RX_PKTS_FOR_C           | RW | 0 = Select CRC errors for 0*17h counter.                                                                                   | 0       |
|      | NTS                         |    | 1 = Select received packets for 0*17h counter.                                                                             |         |
| 10   | REMOTE_LOOPBACK             | RW | 0 = Normal operation.                                                                                                      | 0       |
|      |                             |    | 1 = Enable remote loopback (operates in 10/100/1000) speed.                                                                |         |
| 9    | ZERO_COMMA_DET_P            | RW | 0 = Normal operation.                                                                                                      | 0       |
|      | HASE                        |    | 1 = Force comma detector phase to zero.                                                                                    |         |
| 8    | COMMA_DET_EN                | RW | 0 = Disable comma detection.                                                                                               | 1       |
|      |                             |    | 1 = Enable comma detection.                                                                                                |         |
| 7    | CRC_CHECKER_DIS             | RW | 0 = Enable CRC checker.                                                                                                    | 1       |
|      |                             |    | 1 = Disable CRC checker by gating the clock to save power.                                                                 |         |
| 6    | DISABLE_PLL_PWRDW           | RW | 0 = PLL will be powered down when register 0.11 is set.                                                                    | 0       |
|      | N                           |    | 1 = PLL will never be powered down. (use this when the mac/switch uses the pll_clk125 output).                             |         |

| Bits | Name             | RW | Description                                                                                                                                                      | Default |
|------|------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 5    | SGMII_MSTR_MODE  | RW | 0 = Normal operation.                                                                                                                                            | 1       |
|      |                  |    | 1 = SGMII mode operates in "PHY mode". If auto-neg is enabled, then the local device will send out the following auto-neg code word:                             |         |
|      |                  |    | [15] = 1                                                                                                                                                         |         |
|      |                  |    | [14] = ACK                                                                                                                                                       |         |
|      |                  |    | [13] = 0                                                                                                                                                         |         |
|      |                  |    | [12] = Register 0.8                                                                                                                                              |         |
|      |                  |    | [11] = Register 0.6                                                                                                                                              |         |
|      |                  |    | [10] = Register 0.13                                                                                                                                             |         |
|      |                  |    | [9:0] = "0000000001"                                                                                                                                             |         |
|      |                  |    | To disable the link, set register 0.11 = 1.                                                                                                                      |         |
|      |                  |    | To enable the link, set register 0.11 = 0.                                                                                                                       |         |
| 4    | AUTODET_EN       | RW | 0 = Disable auto detection (fiber or SGMII mode is set according to bit 0 of this register.)                                                                     | 0       |
|      |                  |    | 1 = Enable auto-detection (fiber and SGMII mode will switch each time a auto-<br>negotiation page is received with the wrong selector field in bit 0.)           |         |
| 3    | INVERT_SIG_DET   | RW | 0 = Use signal detect from pin.                                                                                                                                  | 1       |
|      |                  |    | 1 = Invert signal detect from pin.                                                                                                                               |         |
| 2    | SIGNAL_DETECT_EN | RW | 0 = Ignore signal detect from pin.                                                                                                                               | 1       |
|      |                  |    | 1 = Signal detect from pin must be set in order to achieve synchronization. In SGMII, the signal detect is always ignored regardless of the setting of this bit. |         |
| 1    | TBI_INTERFACE    | RW | 0 = GMII interface                                                                                                                                               | 1       |
|      |                  |    | 1 = Ten bit interface.                                                                                                                                           |         |
| 0    | FIBER_MODE_1000X | RW | 0 = SGMII mode                                                                                                                                                   | 1       |
|      | _                |    | 1 = Fiber mode (1000X)                                                                                                                                           |         |

#### 14.7.9 1000XCONTROL2

Register Description: 1000X Control2 Register.

Register Offset: 0x11 at Block 0

| Bits | Name               | RW | Description                                                                                                                                                                            | Default |
|------|--------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15   | DIS_EXTEND_FDX     | RW | 0 = Normal operation                                                                                                                                                                   | 0       |
|      |                    |    | 1 = In full duplex mode, disable carrier extension in pcs receive when bit[7] of this register is set and disable TRRR generation in pcs transmit when bit[8] of this register is set. |         |
| 14   | CLR_BER_CNTR       | RW | 0 = Normal operation                                                                                                                                                                   | 0       |
|      |                    |    | 1 = Clear bit-error-rate counter (register 0*17h bits[15:8])                                                                                                                           |         |
| 13   | TX_IDLE_JAM_SEQ_TE | RW | Register 0*1dh bits[9:0] will override k28.5 for stage 5 (17Ch).                                                                                                                       | 0       |
|      | ST                 |    | Register 0*1eh bits[9:0] will override D16.2 for stage 6 (289h).                                                                                                                       |         |
|      |                    |    | 0 = Normal operation.                                                                                                                                                                  |         |
|      |                    |    | 1 = Enable 16-stage 10-bit idle transmit test sequence to SerDes transmitter.                                                                                                          |         |
| 12   | TX_PKT_SEQ_TEST    | RW | Stage 1-4, 13-16 = idle.                                                                                                                                                               | 0       |
|      |                    |    | Stage 5-12 = data packet.                                                                                                                                                              |         |
|      |                    |    | 0 = Normal operation.                                                                                                                                                                  |         |
|      |                    |    | 1 = Enable 16-stage 10-bit idle transmit test sequence to SerDes transmitter.                                                                                                          |         |

| Bits | Name                         | RW  | Description                                                                                                                                                    | Default |
|------|------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 11   | TEST_CNTR                    | RW  | 0 = Normal operation.                                                                                                                                          | 0       |
|      |                              |     | 1 = Increment bits[7:0] of register 0*17h counter for each clock cycle.                                                                                        |         |
| 10   | BYPASS_PCS_TX                | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      |                              |     | 1 = Bypass pcs transmit operation                                                                                                                              |         |
| 9    | BYPASS_PCS_RX                | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      |                              |     | 1 = Bypass pcs receive operation                                                                                                                               |         |
| 8    | DISABLE_TRRR_GEN             | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      |                              |     | 1 = Disable TRRR generation in pcs transmit                                                                                                                    |         |
| 7    | DISABLE_CARRIER_EX           | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      | TEND                         |     | 1 = Disable carrier extension in pcs receive                                                                                                                   |         |
| 6    | AUTONEG_FAST_TIME            | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      | RS                           |     | 1 = Speed up timers during auto-negotiation for testing                                                                                                        |         |
| 5    | FORCE_XMIT_DATA_O            | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      | N_TXSIDE                     |     | 1 = Allow packets to be transmitted regardless of the condition of the link or                                                                                 |         |
|      |                              |     | synchronization                                                                                                                                                |         |
| 4    |                              | RW  | 0 = Automatically detect remote faults and send remote fault status to link partner                                                                            | 0       |
|      | ENSING                       |     | via auto-negotiation when fiber mode is selected.                                                                                                              |         |
|      |                              |     | (SGMII does not support remote faults)                                                                                                                         |         |
| ^    | ENABLE ALITONEO ED           | DIA | 1 = Disable automatic sensing of remote faults, such as auto-negotiation error                                                                                 | 0       |
| 3    | ENABLE_AUTONEG_ER<br>R TIMER | RW  | 0 = Normal operation                                                                                                                                           | 0       |
|      | IX_TIMEIX                    |     | 1 = Enable auto-negotiation error timer. Error occurs when timer expires in ability-detect, ack-detect, or idle-detect. When the error occurs, config words of |         |
|      |                              |     | all zeros are sent until an ability match occurs, then the autoneg-enable state is                                                                             |         |
|      |                              |     | entered.                                                                                                                                                       |         |
| 2    | FILTER_FORCE_LINK            | RW  | 0 = Normal operation                                                                                                                                           | 1       |
|      |                              |     | 1 = Sync-status must be set for a solid 10ms before a valid link will be                                                                                       |         |
|      |                              |     | established when auto-negotiation is disabled. (This is useful in fiber                                                                                        |         |
|      |                              |     | applications where the user does not have the signal detect pin connected to the fiber module and auto-negotiation is turned off.)                             |         |
| 1    | DISABLE_FALSE_LINK           | RW  | 0 = Normal operation                                                                                                                                           | 1       |
| ı    | DISABLE_FALSE_LINK           | KVV | 1 = Do not allow link to be established when auto-negotiation is disabled and                                                                                  | '       |
|      |                              |     | receiving auto-negotiation code words. The link will only be established in this                                                                               |         |
|      |                              |     | case after idles are received. (This bit does not need to be set, if bit 0 below is                                                                            |         |
|      |                              |     | set.)                                                                                                                                                          |         |
| 0    | ENABLE_PARALLEL_DE           | RW  | 0 = Disable parallel detection                                                                                                                                 | 1       |
|      | TECTION                      |     | 1 = Enable parallel detection. (This will turn auto-negotiation on and off as                                                                                  |         |
|      |                              |     | needed to properly link up with the link partner. The idles and auto-negotiation                                                                               |         |
|      |                              |     | code words received from the link partner are used to make this decision)                                                                                      |         |

#### 14.7.10 1000XCONTROL3

Register Description: 1000X Control3 Register.

Register Offset: 0x12 at Block 0

| Bits | Name                    | RW | Description                                                                                                                                                                                                                                                                                   | Default |
|------|-------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15   | DISABLE_PKT_ALIGNMENT   | RW | 0 = Normal operation.     1 = Disable packet misalignment by carrier extend and removing preamble.                                                                                                                                                                                            | 0       |
| 14   | RXFIFO_GMII_RST         | RW | <ul><li>0 = Normal operation.</li><li>1 = Reset receive FIFO and data_out_1000. FIFO will remain in reset until this bit is cleared with a software write.</li></ul>                                                                                                                          | 0       |
| 13   | DISABLE_TX_CRS          | RW | <ul><li>0 = Normal operation.</li><li>1 = Disable generating crs from transmitting in half-duplex mode. Only receiving will generate crs.</li></ul>                                                                                                                                           | 1       |
| 12   | INVERT_EXT_PHY_CRS      | RW | 0 = Use "receive crs from PHY" pin. 1 = Invert "receive crs from PHY" pin                                                                                                                                                                                                                     | 1       |
| 11   | EXT_PHY_CRS_MODE        | RW | 0 = Normal operation. 1 = Use external pin for the PHYs "receive only" crs output. (Useful in SGMII 10/100 half-duplex applications in order to reduce the collision domain latency. Requires a PHY, which generates a "receive only" crs output to a pin.)                                   | 1       |
| 10   | JAM_FALSE_CARRIER_MODE  | RW | <ul><li>0 = Normal operation.</li><li>1 = Change false carriers received into packets with preamble only.</li><li>(Not necessary if MAC uses crs to determine collision)</li></ul>                                                                                                            | 0       |
| 9    | BLOCK_TXEN_MODE         | RW | 0 = Normal operation.<br>1 = Block txen when necessary to guarantee an ipg of at least 6.5 bytes in 10/100 mode, 7 bytes in 1000 mode.                                                                                                                                                        | 0       |
| 8    | FORCE_TXFIFO_ON         | RW | 0 = Normal operation. 1 = Force transmit FIFO to free-run in Gigabit mode (Requires clk_in and pll_clk125 to be frequency locked.)                                                                                                                                                            | 0       |
| 7    | BYPASS_TXFIFO1000       | RW | 0 = Normal operation. 1 = Bypass transmit FIFO in Gigabit mode. (Useful for fiber or Gigabit only applications where the MAC is using the pll_clk125 as the clk_in port. User must meet timing to the pll_clk125 domain)                                                                      | 0       |
| 6    | FREQ_LOCK_ELASTICITY_TX | RW | 0 = Normal operation. 1 = Minimum FIFO latency to properly handle a clock which is frequency locked, but out of phase. (overrides bits [2:1] of this register). pll clk125 and clk in must be using the same crystal.                                                                         | 1       |
| 5    | FREQ_LOCK_ELASTICITY_RX | RW | 0 = Normal operation 1 = Minimum FIFO latency to properly handle a clock which is frequency locked, but out of phase. (Not necessary if MAC uses crs to determine collision; overrides bits [2:1] of this register).  MAC and PHY must be using the same crystal for this mode to be enabled. | 0       |
| 4    | EARLY_PREAMBLE_RX       | RW | 0 = Normal operation 1 = Send extra bytes of preamble to avoid FIFO latency. (Not necessary if MAC uses crs to determine collision)                                                                                                                                                           | 0       |
| 3    | EARLY_PREAMBLE_TX       | RW | 0 = Normal operation 1 = Send extra bytes of preamble to avoid FIFO latency. (Used in half-duplex applications to reduce collision domain latency. MAC must send 5 bytes of preamble or less to avoid non-compliant behavior.)                                                                | 0       |
| 2:1  | FIFO_ELASTICITY_TX_RX   | RW | 00 = Supports packets up to 5 KB 01 = Supports packets up to 10 KB 1X = Supports packets up to 13.5 KB                                                                                                                                                                                        | 0       |

| Bits | Name        | RW | Description                                                          | Default |
|------|-------------|----|----------------------------------------------------------------------|---------|
| 0    | TX_FIFO_RST | RW | 0 = Normal operation                                                 | 0       |
|      |             |    | 1 = Reset transmit FIFO. FIFO will remain in reset until this bit is |         |
|      |             |    | cleared with a software write.                                       |         |

#### 14.7.11 1000XSTATUS1

Register Description: 1000X Status1 Register.

Register Offset: 0x14 at Block 0

| Bits | Name               | RW | Description                                                                                                | Default |
|------|--------------------|----|------------------------------------------------------------------------------------------------------------|---------|
| 15   | TXFIFO_ERR_DETECTE | RO | 1 = Transmit FIFO error detected since last read.                                                          | 0       |
|      | D                  |    | 0 = No transmit FIFO error detected since last read.                                                       |         |
| 14   | RXFIFO_ERR_DETECTE | RO | 1 = Receive FIFO error detected since last read.                                                           | 0       |
|      | D                  |    | 0 = No receive FIFO error detected since last read.                                                        |         |
| 13   | FALSE_CARRIER_DETE | RO | 1 = False carrier detected since last read.                                                                | 0       |
|      | CTED               |    | 0 = No false carrier detected since last read.                                                             |         |
| 12   | CRC_ERR_DETECTED   | RO | 1 = CRC error detected since last read.                                                                    | 0       |
|      |                    |    | 0 = No CRC error detected since last read or detection is disabled via register 0*10h bit [7].             |         |
| 11   | TX_ERR_DETECTED    | RO | 1 = Transmit error code detected since last read (rx_data_error state in pcs receive fsm).                 | 0       |
|      |                    |    | 0 = No transmit error code detected since last read.                                                       |         |
| 10   | RX_ERR_DETECTED    | RO | 1 = Receive error since last read (early_end state in pcs receive fsm)                                     | 0       |
|      |                    |    | 0 = No receive error since last read                                                                       |         |
| 9    | CARRIER_EXT_ERR_D  | RO | 1 = Carrier extend error since last read (extend_err in pcs receive fsm)                                   | 0       |
|      | ETECTED            |    | 0 = No carrier extend error since last read                                                                |         |
| 8    | EARLY_END_EXT_DET  | RO | 1 = Early end extension since last read (early_end_ext in pcs receive fsm)                                 | 0       |
|      | ECTED              |    | 0 = No early end extension since last read                                                                 |         |
| 7    | LINK_STATUS_CHG    | RO | 1 = Link status has changed since last read                                                                | 0       |
|      |                    |    | 0 = Link status has not changed since last read                                                            |         |
| 6    | PAUSE_RESOLUTION_  | RO | 1 = Enable pause receive                                                                                   | 0       |
|      | RXSIDE             |    | 0 = Disable pause receive                                                                                  |         |
| 5    | PAUSE_RESOLUTION_T | RO | 1 = Enable pause transmit                                                                                  | 0       |
|      | XSIDE              |    | 0 = Disable pause transmit                                                                                 |         |
| 4:3  | SPEED_STATUS       | RO | 1X = Gigabit                                                                                               | 0       |
|      |                    |    | 01 = 100 mbps                                                                                              |         |
|      |                    |    | 00 = 10 mbps                                                                                               |         |
| 2    | DUPLEX_STATUS      | RO | 1 = Full-duplex                                                                                            | 0       |
|      |                    |    | 0 = Half-duplex                                                                                            |         |
|      |                    |    | When the ten bit interface is selected with fiber mode (1000-X), then half-duplex will always be reported. |         |
| 1    | LINK_STATUS        | RO | 1 = Link is up.                                                                                            | 0       |
|      |                    |    | 0 = Link is down.                                                                                          |         |
|      |                    |    | When the ten bit interface is selected with fiber mode (1000-X), then link will always be down             |         |

| Bits | Name       | RW | Description             | Default |
|------|------------|----|-------------------------|---------|
| 0    | SGMII_MODE | RO | 1 = SGMII mode          | 0       |
|      |            |    | 0 = Fiber mode (1000-X) |         |

## 14.7.12 1000XSTATUS2

Register Description: 1000X Status2 Register.

Register Offset: 0x15 at Block 0

|                          | RW                                                                                                                                           | Description                                                                                                                                                        | Default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SGMII_MODE_CHG           | RO                                                                                                                                           | 1 = SGMII mode has changed since last read (SGMII mode enabled or disabled).                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | This bit is useful when the auto-detection is enabled in register 0*10h bit [4].                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                          |                                                                                                                                              | 0 = SGMII mode has not changed since last read (fixed in SGMII or fiber mode).                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CONSISTENCY_MISMA        | RO                                                                                                                                           | 1 = Consistency mismatch detected since last read.                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TCH                      |                                                                                                                                              | 0 = Consistency mismatch has not been detected since last read.                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AUTONEG_RES_ERR          | RO                                                                                                                                           | 1 = Auto-negotiation HCD error detected since last read (HCD is none in fiber mode).                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | 0 = Auto-negotiation HCD error has not been detected since last read.                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SGMII_SELECTOR_MIS MATCH | RO                                                                                                                                           | 1 = SGMII selector mismatch detected since last read (auto-negotiation page received from link partner with bit [0] = 0 while local device is in SGMII mode).      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | 0 = SGMII selector mismatch not detected since last read.                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SYNC_STATUS_FAIL         | RO                                                                                                                                           | 1 = Sync_status has failed since last read (synchronization has been lost).                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | 0 = Sync_status has not failed since last read.                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SYNC_STATUS_OK           | RO                                                                                                                                           | 1 = Sync_status ok detected since last read (synchronization has been achieved).                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | 0 = Sync_status ok has not been detected since last read.                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RESERVED                 | RO                                                                                                                                           | Reserved.                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LINK_DOWN_SYNC_LO        | RO                                                                                                                                           | 1 = Valid link went down due to a loss of synchronization for over 10 ms.                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SS                       |                                                                                                                                              | 0 = Failure condition has not been detected since last read.                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RESERVED                 | RO                                                                                                                                           | Reserved.                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ANEG_ENABLE_STATE        | RO                                                                                                                                           | 1 = An_enable state in auto-negotiation fsm entered since last read.                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                          |                                                                                                                                              | 0 = An_enable state has not been entered since last read.                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                          | CONSISTENCY_MISMA TCH  AUTONEG_RES_ERR  SGMII_SELECTOR_MIS MATCH  SYNC_STATUS_FAIL  SYNC_STATUS_OK  RESERVED  LINK_DOWN_SYNC_LO SS  RESERVED | CONSISTENCY_MISMA RO TCH  AUTONEG_RES_ERR RO  SGMII_SELECTOR_MIS RO MATCH  SYNC_STATUS_FAIL RO  SYNC_STATUS_OK RO  RESERVED RO LINK_DOWN_SYNC_LO RO SS RESERVED RO | disabled). This bit is useful when the auto-detection is enabled in register 0*10h bit [4]. 0 = SGMII mode has not changed since last read (fixed in SGMII or fiber mode).  CONSISTENCY_MISMA RO 1 = Consistency mismatch detected since last read. 0 = Consistency mismatch has not been detected since last read.  AUTONEG_RES_ERR RO 1 = Auto-negotiation HCD error detected since last read (HCD is none in fiber mode). 0 = Auto-negotiation HCD error has not been detected since last read.  SGMII_SELECTOR_MIS MATCH  SYNC_STATUS_FAIL  RO 1 = SGMII selector mismatch detected since last read (auto-negotiation page received from link partner with bit [0] = 0 while local device is in SGMII mode). 0 = SGMII selector mismatch not detected since last read.  SYNC_STATUS_FAIL  RO 1 = Sync_status has failed since last read (synchronization has been lost). 0 = Sync_status has not failed since last read (synchronization has been achieved). 0 = Sync_status ok detected since last read (synchronization has been achieved). 0 = Sync_status ok has not been detected since last read.  RESERVED  RO Reserved.  IINK_DOWN_SYNC_LO RO 1 = Valid link went down due to a loss of synchronization for over 10 ms. 0 = Failure condition has not been detected since last read.  RESERVED  RO Reserved.  ANEG_ENABLE_STATE RO 1 = An_enable state in auto-negotiation fsm entered since last read. |

#### 14.7.13 1000XSTATUS3

Register Description: 1000X Status3 Register.

Register Offset: 0x16 at Block 0

| Bits  | Name           | RW | Description                                                                    | Default |
|-------|----------------|----|--------------------------------------------------------------------------------|---------|
| 15:11 | RESERVED       | RO | Reserved                                                                       | 0x00    |
| 10    | LATCH_LINKDOWN | RO | 1 = Link has been down since register 0*13h bit [9] has been written a '1'     | 0       |
|       |                |    | 0 = Link has not been down since register 0*13h bit [9] has been written a '1' |         |

| Bits | Name           | RW | Description                                                                                                                                                                                                                                                                                      | Default |
|------|----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 9    | SD_FILTER      | RO | 1 = Output of signal detect filter is set                                                                                                                                                                                                                                                        | 0       |
|      |                |    | 0 = Output of signal detect is not set                                                                                                                                                                                                                                                           |         |
|      |                |    | This signal is used for the PCS synchronization. When register 0*10h bit [2] is 0, then the output of the filter will be forced high. This status signal is still valid when register 0*10h bit [14] is 1. Noise pulses less than 16 ns wide are still removed when even the filter is disabled. |         |
| 8    | SD_MUX         | RO | 1 = Output of signal detect filter is set                                                                                                                                                                                                                                                        | 0       |
|      |                |    | 0 = Output of signal detect is not set                                                                                                                                                                                                                                                           |         |
|      |                |    | This is the only SD status bit that will be valid when the SerDes is powered down from register 0.11. This status signal is the "signal detect" input port when register 0*10h bit [3] is 0, otherwise it is the "signal detect" input port inverted.                                            |         |
| 7    | SD_FILTER_CHG  | RO | 1 = Signal detect has changed since last read                                                                                                                                                                                                                                                    | 0       |
|      |                |    | 0 = Signal detect has not changed since last read                                                                                                                                                                                                                                                |         |
|      |                |    | The signal detect change is based on a change in bit [9] of this register                                                                                                                                                                                                                        |         |
| 6    | SIGNAL_DETECT  | RO | Signal detect directly from pin                                                                                                                                                                                                                                                                  | 0       |
| 5    | ANA_SIGNAL_DET | RO | Analog signal detect status bit. This status signal is the analog signal detect status if register 0*13h bit [0] is set, otherwise it is the value based on register 0*13h bit [1].                                                                                                              | 0       |
| 4    | ANA_SIGDET_CHG | RO | 1 = Analog signal detect has changed since last read                                                                                                                                                                                                                                             | 0       |
|      |                |    | 0 = Analog signal detect has not changed since last read                                                                                                                                                                                                                                         |         |
|      |                |    | The analog signal detect change is based on a change in bit [5] of this register.                                                                                                                                                                                                                |         |
| 3:0  | RESERVED       | RO | Reserved                                                                                                                                                                                                                                                                                         | 0       |

#### **14.7.14 FXCONTROL1**

Register Description: 100FX enabling control register

Register Offset: 0x10 at Block 2

| Bits | Name                     | RW | Description                                                                                                                                                           | Default |
|------|--------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15   | RESERVED                 | RW | Reserved                                                                                                                                                              | 0       |
| 14   | FIBER_AUTOPWRDWN_WAKEUP  | RW | 1 = Wake up for 250ms before powering down                                                                                                                            | 0       |
|      |                          |    | 0 = Wake up for 42ms before powering down                                                                                                                             |         |
| 13   | FIBER_AUTOPWRDWN_SLEEP   | RW | 1 = Power-down for 3 seconds before waking up                                                                                                                         | 0       |
|      |                          |    | 0 = Power-down for 5 seconds before waking up                                                                                                                         |         |
| 12   | FIBER_AUTOPWRDWN_ENABLE  | RW | 1 = Power-down fiber when signal detect is inactive (wake up for 42 ms every 5 seconds to transmit code words; see register 2*10h[13:12] for different time options). | 0       |
|      |                          |    | 0 = Normal operation.                                                                                                                                                 |         |
| 11   | FIBER_AUTOPWRDWN_DISABLE | RW | 1 = Disable 1000-X power down from fiber auto-power down (register 0[11] powerdown not affected). 0 = Normal operation                                                | 0       |
| 10   | FX100_AUTODET_TIMER_SEL  | RW | 1 = 125-166 ms (do not use if fiber auto-power down is enabled; register 2*10h[12]).                                                                                  | 0       |
|      |                          |    | 0 = 31-42 ms                                                                                                                                                          |         |
| 9:6  | FX100_RXDATA_SEL         | RW | Selects the sample bit out of 10 bits for FX100 RX data                                                                                                               | 0x9     |
| 5    | FX100_DISABLE_RX_QUAL    | RW | 1 = Always use sample bit without filtering                                                                                                                           | 0       |
|      |                          |    | 0 = Normal operation                                                                                                                                                  |         |

| Bits | Name                  | RW | Description                                                       | Default |
|------|-----------------------|----|-------------------------------------------------------------------|---------|
| 4    | FX100_FORCE_RX_QUAL   | RW | 1 = Always compare 2 surrounding bits with sample to filter noise | 0       |
|      |                       |    | 0 = Normal operation                                              |         |
| 3    | FX100_FAREND_FAULT_EN | RW | 1 = Enable far-end fault                                          | 1       |
|      |                       |    | 0 = Disable far-end fault                                         |         |
| 2    | FX100_AUTODET_EN      | RW | 1 = Auto-detect between 100FX mode and 1000-X mode                | 0       |
|      |                       |    | 0 = Disable auto-detection                                        |         |
| 1    | FX100_FULL_DUPLEX     | RW | 1 = 100-FX SerDes full-duplex                                     | 1       |
|      |                       |    | 0 = 100-FX SerDes half-duplex                                     |         |
| 0    | FX100_ENABLE          | RW | 1 = Select 100-FX mode                                            | 0       |
|      |                       |    | 0 = Select 1000-X mode                                            |         |

#### **14.7.15 FXCONTROL2**

Register Description: 100FX extended packet size enabled

Register Offset: 0x11 at Block 2

| Bits | Name            | RW | Description                                    | Default |
|------|-----------------|----|------------------------------------------------|---------|
| 15:1 | RESERVED        | RW | Reserved                                       | 0x000   |
| 0    | EXTEND_PKT_SIZE | RW | 1 = Allow reception of extended length packets | 0       |
|      |                 |    | 0 = Allow normal length Ethernet packets only  |         |

#### **14.7.16 FXCONTROL3**

Register Description: 100FX control register

Register Offset: 0x12 at Block 2

| Bits | Name                    | RW | Description                                                                             | Default |  |  |  |  |
|------|-------------------------|----|-----------------------------------------------------------------------------------------|---------|--|--|--|--|
| 15:7 | RESERVED                | RW | Reserved                                                                                | 0x000   |  |  |  |  |
| 6    | FX100_BYPASS_NRZ        | RW | 1 = Bypass NRZ encoder in 100FX mode 0 = Normal operation                               |         |  |  |  |  |
| 5    | FX100_BYPASS_ENCODER    | RW | 1 = Bypass 4B5B encoder in 100FX mode<br>0 = Normal operation                           |         |  |  |  |  |
| 4    | FX100_BYPASS_ALIGNMENT  | RW | 1 = Bypass 5B code group alignment in 100FX mode<br>0 = Normal operation                | 0       |  |  |  |  |
| 3    | FX100_FORCE_LINK        | RW | 1 = Force link in 100FX mode<br>0 = Normal operation                                    | 0       |  |  |  |  |
| 2    | FX100_FORCE_LOCK        | RW | 1 = Force lock in 100FX mode<br>0 = Normal operation                                    | 0       |  |  |  |  |
| 1    | FX100_FAST_UNLOCK_TIMER | RW | 1 = Speed up unlock timer in 100FX mode 0 = Normal operation                            | 0       |  |  |  |  |
| 0    | FX100_FAST_TIMER        | RW | 1 = Speed up timer to acquire lock and link (test vectors and simulation) in 100FX mode | 0       |  |  |  |  |
|      |                         |    | 0 = Normal operation                                                                    |         |  |  |  |  |

## 14.7.17 FXSTATUS1

Register Description: 100FX link status register

Register Offset: 0x13 at Block 2

| Bits  | Name                         | RW    | Description                                                                                                    | Default |  |  |  |  |
|-------|------------------------------|-------|----------------------------------------------------------------------------------------------------------------|---------|--|--|--|--|
| 15:10 | RESERVED                     | RW    | Reserved                                                                                                       |         |  |  |  |  |
| 9     | FX100_LINK_STATUS_CHG        | RO/LH | 1 = 100-FX mode link status change since last read 0 = 100-FX mode link status has not changed since last read |         |  |  |  |  |
| 8     | FX100_BAD_ESD_DETECTED       | RO/LH | 1 = 100-FX mode bad ESD error detected since last read (premature end)                                         | 0       |  |  |  |  |
|       |                              |       | 0 = No 100-FX mode bad ESD error detected since last read                                                      |         |  |  |  |  |
| 7     | FX100_FALSE_CARRIER_DETECTED | RO/LH | 1 = 100-FX mode false carrier detected since last read                                                         | 0       |  |  |  |  |
|       |                              |       | 0 = No 100-FX mode false carrier detected since last read                                                      |         |  |  |  |  |
| 6     | FX100_TX_ERR_DETECTED        | RO/LH | 1 = 100-FX mode received packet with txer code detected since last read                                        | 0       |  |  |  |  |
|       |                              |       | 0 =No 100-FX mode received packet with txer code detected since last read                                      |         |  |  |  |  |
| 5     | FX100_RX_ERR_DETECTED        | RO/LH | 1 = 100-FX mode receive coding error detected since last read                                                  | 0       |  |  |  |  |
|       |                              |       | 0 = No 100-FX mode receive coding error detected since last read                                               |         |  |  |  |  |
| 4     | FX100_LOCK_TIMER_EXPIRED     | RO/LH | 1 = Unable to lock within 730us since last read                                                                | 0       |  |  |  |  |
|       |                              |       | 0 = Condition not detected since last read                                                                     |         |  |  |  |  |
| 3     | FX100_LOST_LOCK              | RO/LH | 1 = Lost lock since last read                                                                                  | 0       |  |  |  |  |
|       |                              |       | 0 = Lock has not been lost since last read                                                                     |         |  |  |  |  |
| 2     | FX100_FAULTING               | RO/LH | 1 = Far-end fault detected since last read                                                                     | 0       |  |  |  |  |
|       |                              |       | 0 = No far-end fault detected since last read                                                                  |         |  |  |  |  |
| 1     | FX100_LOCKED                 | RO    | 1 = Enough idles are properly detected to lock                                                                 | 0       |  |  |  |  |
|       |                              |       | 0 = Not locked                                                                                                 |         |  |  |  |  |
| 0     | FX100_LINK                   | RO    | 1 = 100-FX mode link is up                                                                                     | 0       |  |  |  |  |
|       |                              |       | 0 = 100-FX mode link is down                                                                                   |         |  |  |  |  |

### 14.7.18 ANALOG\_TX1

Register Description: Analog transmitter output for the SerDes when it is in SGMII mode.

Register Offset: 0x10 at Block 3

| Bits  | Name           | RW | Description                                                                  | Default |
|-------|----------------|----|------------------------------------------------------------------------------|---------|
| 15:12 | DRIVER_CURRENT | RW | Setting the output amplitude of the SerDes ranging from 700 mV to 1280 mV.   | 0x7     |
| 11    | RESERVED       | RW | Reserved                                                                     | 0       |
| 10:7  | PREEMPH_COEF   | RW | Setting the pre-emphasis level for the SerDes driver, ranging from 0 to 60%. | 0       |
| 6     | RX_CLKP        | RW | Reserved for factory use only.                                               | 0       |
|       |                |    | 1 = Select RX clock                                                          |         |
|       |                |    | 0 = Do not select RX clock                                                   |         |

| Bits | Name         | RW | Description                                                                                                                                                                                                                                                                                                                         | Default |
|------|--------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 5    | REG_EDGE_SEL | RW | Reserved for factory use only.                                                                                                                                                                                                                                                                                                      | 0       |
|      |              |    | 1 = Capture on rising edge                                                                                                                                                                                                                                                                                                          |         |
|      |              |    | 0 = Capture on falling edge                                                                                                                                                                                                                                                                                                         |         |
| 4    | BOOST_MODE   | RW | Reserved for factory use only                                                                                                                                                                                                                                                                                                       | 0       |
|      |              |    | 1 = Enable boost output current for preamp driver                                                                                                                                                                                                                                                                                   |         |
|      |              |    | 0 = Normal mode                                                                                                                                                                                                                                                                                                                     |         |
| 3    | DRIVER_IDLE  | RW | 1 = Enable transmit driver idle                                                                                                                                                                                                                                                                                                     | 0       |
|      |              |    | 0 = Disable transmit driver idle                                                                                                                                                                                                                                                                                                    |         |
| 2    | LOOPBACK     | RW | 1 = Enable remote loopback. The far end sends the data to the device and the data is looped back to the wire at the analog block prior of reaching to the deserializer. The data will not reach the device MAC block. In order to use the remote loopback, both loopback bits must be set in the ANALOG_TX and ANALOG_RX registers. | 0       |
|      |              |    | 0 = Normal operation                                                                                                                                                                                                                                                                                                                |         |
| 1    | RESET        | RW | 1 = SerDes is in reset                                                                                                                                                                                                                                                                                                              | 0       |
|      |              |    | 0 = SerDes is not in reset                                                                                                                                                                                                                                                                                                          |         |
| 0    | IDDQ         | RW | 1 = Power down the driver                                                                                                                                                                                                                                                                                                           | 0       |
|      |              |    | 0 = Normal operation                                                                                                                                                                                                                                                                                                                |         |

## 14.7.19 ANALOG\_TX2

Register Description: Analog transmitter2 output for the SerDes when it is in SGMII mode.

Register Offset: 0x11 at Block 3

| Bits | Name              | RW | Description                                                                                          | Default |
|------|-------------------|----|------------------------------------------------------------------------------------------------------|---------|
| 15:4 | RESERVED          | RW | Reserved                                                                                             | 0x000   |
| 3:0  | PREDRIVER_CURRENT |    | This is to control the output driving amplitude. This is set in conjunction with the DRIVER_CURRENT. | 0x7     |

### 14.7.20 ANALOG\_TXAMP

**Register Description:** Analog transmitter output for the SerDes when it is in FX (Fiber) mode. This register is not used when device is in SGMII mode.

Register Offset: 0x12 at Block 3

| Bits  | Name                        | RW | Description                                   | Default |
|-------|-----------------------------|----|-----------------------------------------------|---------|
| 15    | DRIVER_FULL_RANGE           | RW | Reserved for factory use only.                | 0       |
|       |                             |    | 1 = Enable TX driver full output range        |         |
|       |                             |    | 0 = Disable TX driver full output range       |         |
| 14    | 4 PREDRIVER_SWING_B RW OOST |    | Reserved for factory use only.                | 0       |
|       |                             |    | 1 = Enable final stage predriver swing boost  |         |
|       |                             |    | 0 = Disable final stage predriver swing boost |         |
| 13:10 | RESERVED                    | RW | Reserved.                                     | 0x0     |

| Bits | Name              | RW | Description                                                                                          | Default |
|------|-------------------|----|------------------------------------------------------------------------------------------------------|---------|
| 9    | BMODE             | RW | Reserved for factory use only.                                                                       | 0       |
|      |                   |    | 1 = Enable transmit boost mode                                                                       |         |
|      |                   |    | 0 = Normal operation                                                                                 |         |
| 8:5  | PREDRIVER_CURRENT | RW | This is to control the output driving amplitude. This is set in conjunction with the DRIVER_CURRENT. | 0x7     |
| 4:1  | DRIVER_CURRENT    | RW | Setting the output amplitude of the SerDes ranging from 700 mV to 1280 mV.                           | 0x7     |
| 0    | RESERVED          | RW | Reserved.                                                                                            | 0       |

## 14.7.21 ANALOG\_RX1

Register Description: Controlling the SerDes receiver.

Register Offset: 0x13 at Block 3

| Bits  | Name            | RW | Description                                                                      | Default |
|-------|-----------------|----|----------------------------------------------------------------------------------|---------|
| 15:13 | RESERVED        | RW | Reserved                                                                         | 0x00    |
| 12:10 | SD_THRESHOLD    | RW | Controls when signal detect should be asserted, based on energy level.           | 0x2     |
|       |                 |    | 000 = 10 mV                                                                      |         |
|       |                 |    | 001 = 20 mV                                                                      |         |
|       |                 |    | 011 = 30 mV                                                                      |         |
|       |                 |    | 010 = 40 mV                                                                      |         |
|       |                 |    | 110 = 50 mV                                                                      |         |
|       |                 |    | 111 = 60 mV                                                                      |         |
|       |                 |    | 101 = 70 mV                                                                      |         |
|       |                 |    | 100 = 80 mV                                                                      |         |
| 9     | SIGDET_EN       | RW | 1 = Enable signal detect                                                         | 0       |
|       |                 |    | 0 = Disable signal detect                                                        |         |
| 8     | LOOPBACK        | RW | Set to enable remote loopback. This must be set in conjunction with the loopback | 0       |
|       |                 |    | bit under ANALOG_TX1 register.                                                   |         |
|       |                 |    | 1 = Enable loopback                                                              |         |
|       |                 |    | 0 = Normal operation                                                             |         |
| 7     | REG_EDGE_SELECT | RW | Reserved for factory use only.                                                   | 0       |
|       |                 |    | 1 = Use rising edge of rx_wclk                                                   |         |
|       |                 |    | 0 = Use falling edge of rx_wclk                                                  |         |
| 6:1   | RESERVED        | RW | Reserved                                                                         | 0x00    |
| 0     | IDDQ            | RW | Set to power down analog receiver block                                          | 0       |
|       |                 |    | 1 = Power down RX                                                                |         |
|       |                 |    | 0 = Normal operation                                                             |         |

## 14.7.22 ANALOG\_RX2

Register Description: 100FX Test Mode

Register Offset: 0x14 at Block 3

| Bits | Name         | RW | Description                                                                | Default |
|------|--------------|----|----------------------------------------------------------------------------|---------|
| 15:4 | RESERVED     | RW | Reserved                                                                   | 0x000   |
| 3    | 100FX_ENABLE | RW | Set to enable SerDes in 100-FX mode.  1 = FX100 mode  0 = Normal operation | 0       |
| 2:0  | RESERVED     | RW | Reserved                                                                   | 0x0     |

## 14.7.23 ANALOG\_PLL

Register Description: Controlling the GE PLL circuitry.

Register Offset: 0x18 at Block 3

| Bits | Name           | RW | Description          | Default |
|------|----------------|----|----------------------|---------|
| 15:1 | RESERVED       | RW | Reserved             | 0x4040  |
| 0    | PLL_POWER_DOWN | RW | 1 = PLL power down   | 0       |
|      |                |    | 0 = Normal operation |         |

#### 14.7.24 GE\_PRBS\_CONTROL

Register Description: PRBS Control Register. This is to use in PRBS test mode only.

Register Offset: 0x18 (Block 0)

| Bit Number |    |    |    |    |    |   |   |   |   |   |   |      |        |                        |             |
|------------|----|----|----|----|----|---|---|---|---|---|---|------|--------|------------------------|-------------|
| 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2      | 1                      | 0           |
| Reserved   |    |    |    |    |    | • |   |   |   |   | • | prbs | _order | inv_pr<br>bs_or<br>der | prbs_<br>en |

| Bit  | Name           | RW | Description                        | Default |
|------|----------------|----|------------------------------------|---------|
| 15:4 | Reserved       | RO | Reserved                           | 0x0     |
| 3:2  | Prbs_order     | RW | 0 = 7th order                      | 0       |
|      |                |    | 1 = 15th order                     |         |
|      |                |    | 2 = 23rd order                     |         |
|      |                |    | 3 = 31st order                     |         |
| 1    | Inv_prbs_order | RW | Set to invert the polynomial order | 0       |
| 0    | Prbs_en        | RW | Set to enable PRBS testing         | 0       |

#### 14.7.25 GE\_PRBS\_STATUS

Register Description: PRBS Status Register. This is to use in PRBS test mode only.

Register Offset: 0x19 (Block 0)

| Bit Number           |    |    |             |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------------|----|----|-------------|----|----|---|---|---|---|---|---|---|---|---|---|
| 15                   | 14 | 13 | 12          | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved Unlock Lock |    |    | Prbs_errors |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name        | RW | Description                                                                             | Default |
|-------|-------------|----|-----------------------------------------------------------------------------------------|---------|
| 15:13 | Reserved    | RO | Reserved                                                                                | 0x0     |
| 12    | Unlock      | RO | In PRBS mode, this bit indicates signal is no longer available or PRBS pattern is loss. | 0       |
| 11    | Lock        | RO | In PRBS mode, this indicates PRBS pattern is locked.                                    | 0       |
| 10:0  | Prbs_errors | RO | In PRBS mode, this indicates number of errors detected.                                 | 0x0000  |

## 14.8 Clause 45 Registers

Clause 45 registers are accessed in the Clause 22 register space according to the method in Clause 22.2.4.3.11-12 and Annex 22D.

**Example:** To advertise that EEE mode is supported for 1000BASE-T and 100BASE-TX, Clause 45 Dev 7.3Ch bits 2:1 must be set to 11. To perform this write, the following sequence may be used:

- In register 0Dh, write bits15:14 = 00 (set the function field to Address) and set bits 4:0 to '00111' (set DEVAD to 7) (write 007h to Register 0Dh).
- In register 0Eh, write the desired address value. In this example, write 003Ch to Register 0Eh.
- In register 0Dh, write the Function field (bits 15:14) to 01 for Data, no post increment. Set DEVAD to 7. (Write 4007h to Register 0Dh).
- In register 0Eh, write the content of the register. (Write to Register 0Eh to 0006h to set bits 2:1 = 11).

To read the EEE Resolution Status Register (Clause 45 DEV 7 Reg803Eh), the following register sequence may be followed:

- Write bits 15:14 to 00 to register 0Dh to set the function field to Address, and set bits 4:0 to '00111' to set DEVAD to 7.
- Write 803Eh to register 0Eh to select the EEE Resolution Status Register.
- Write 4007h to register 0Dh to set the Function to Data, no post increment and to set the Device Address to 7.
- Read register 0Eh to read the content of the selected Clause 45 register (EEE Resolution Status Register in this case).

#### 14.8.1 Clause 45 Register Dev 3 Reg14h (20d): EEE Capability Register

| Bit  | Name           | RW | Description                             | Default |
|------|----------------|----|-----------------------------------------|---------|
| 15:3 | Reserved       | RO | Ignore on read                          | 0       |
| 2    | 1000BASE-T EEE | RO | 1 = EEE is supported for 1000BASE-T     | 0       |
|      |                |    | 0 = EEE is not supported for 1000BASE-T |         |
| 1    | 100BASE-TX EEE | RO | 1 = EEE is supported for 100BASE-TX     | 0       |
|      |                |    | 0 = EEE is not supported for 100BASE-TX |         |
| 0    | Reserved       | RO | Write as 0, ignore on read              | 0000h   |

# 14.8.2 Clause 45 Register Dev 7 Reg3ch (60d): EEE Advertisement Register

| Bit  | Name           | RW | Description                                                 | Default |
|------|----------------|----|-------------------------------------------------------------|---------|
| 15:3 | Reserved       | RW | Write as 0, ignore on read.                                 | 0       |
| 2    | 1000BASE-T EEE | RW | 1 = Advertise PHY has EEE capability for 1000BASE-T.        | 0       |
|      |                |    | 0 = Do not advertise PHY has EEE capability for 1000BASE-T. |         |
| 1    | 100BASE-TX EEE | RW | 1 = Advertise PHY has EEE capability for 100BASE-TX.        | 0       |
|      |                |    | 0 = Do not advertise PHY has EEE capability for 100BASE-TX. |         |
| 0    | Reserved       | RW | Write as 0, ignore on read.                                 | 0000h   |

#### 14.8.2.1 1000BASE-T EEE

This bit, when set, turns on advertisement for 1000BASE-T EEE mode. EEE mode is turned off by default. Register 09h bits 9:8 must be set to advertise 1000BASE-T mode and auto-negotiation must be restarted for EEE mode to take effect.

#### 14.8.2.2 100BASE-TX EEE

This bit, when set, turns on advertisement for 100BASE-TX EEE mode. EEE mode is turned off by default. Register 04h bits 8:7 must be set to advertise 100BASE-TX mode and auto-negotiation must be restarted for EEE mode to take effect.

# 14.8.3 Clause 45 Register Dev 7 Reg803Eh (32830d): EEE Resolution Status

| Bit  | Name                      | RW | Description                                                                                                                                             | Default |
|------|---------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 15:3 | Reserved                  | RW | Write as 0, ignore on read                                                                                                                              | 0       |
| 2    | EEE 1000BASE-T Resolution | RW | 1 = Both local device and link partner advertise EEE 1000BASE-T capability     0 = No EEE capability in local device or link partner in 1000BASE-T mode | 0       |
| 1    | EEE 100BASE-TX Resolution | RW | 1 = Local and remote link partner advertise EEE 100BASE-TX mode 0 = No EEE capability in either local or link partner in 100BASE-TX mode                | 0       |
| 0    | Reserved                  | RW | Write as 0, ignore on read                                                                                                                              | 0000h   |

#### 14.8.3.1 EEE 1000BASE-T Resolution

This bit returns the status of the resolution of EEE 1000BASE-T mode. If this bit is set, PHY and remote receiver have autonegotiation enabled, and both PHY and link partner advertise EEE 1000BASE-T mode. If this bit is cleared, either the local or remote PHY does not have auto-negotiation enabled, or local or remote PHY does not advertise EEE capability in 1000BASE-T mode.

#### 14.8.3.2 EEE 100BASE-TX Resolution

This bit returns the status of the resolution of EEE 100BASE-TX mode. If this bit is set, PHY and remote receiver have autonegotiation enabled, and both PHY and link partner advertise EEE 100BASE-TX mode. If this bit is cleared, either the local or remote PHY does not have auto-negotiation enabled, or local or remote PHY does not advertise EEE capability in 100BASE-TX mode.

# 14.8.4 Clause 45 Register Dev 7 Reg803dh (32817d): EEE Control Register

| Bit  | Name                            | RW  | Description                                                   | Default |
|------|---------------------------------|-----|---------------------------------------------------------------|---------|
| 15   | LPI Feature Enable              | RW* | 1 = Enable LPI Feature                                        | 0       |
|      |                                 |     | 0 = Disable LPI Feature                                       |         |
| 14   | Enables EEE capability using RW |     | 1 = Enable EEE capability using SGMII auto-negotiation        | 0       |
|      | SGMII auto-negotiation          |     | 0 = Do not enable EEE capability using SGMII auto-negotiation |         |
| 13   | Reserved                        | RW  | Write as 0, ignore on read.                                   | 0       |
| 12   | Reserved                        | RW  | Write as 0, ignore on read.                                   | 0       |
| 11:0 | Reserved                        | RW  | Write as 0, ignore on read.                                   | 0000h   |

### 14.8.4.1 LPI Feature Enable

Setting this bit high enables LPI

# **Appendix A: Flow Control**

### **14.9 Notes**

Developers can refer to the IEEE 802.3 Annex 31B specification for detailed information on Ethernet flow control mechanisms.

- Flow control frames use a well-known multicast address, defined in the 802.1D Bridging specification The MAC destination address is 01-80-C2-00-01.
- Bridges and Switches will not forward pause frames to downstream ports.
- A pause frame contains a request\_operand that contains a pause\_time field. Pause\_time specifies the number of quanta, which transmission should be inhibited.
- Pause frames cannot inhibit MAC control Frames
- Pause\_time is a two-octet field, which represents a quanta value. The quanta value is based on bit/slot times for the connection speed. Valid pause times vary from 0 to 65535.
- The pause frame contains a MAC control opcode. 00-01 is reserved for PAUSE MAC control functions.
- MAC control layers will provide two indicators—paused and not paused.
- The Enet source address equals the unicast address of the MAC sublayer, which transmits the pause\_frame.
- The receive engine will set a countdown timer, based on the value of pause\_time. When the timer expires, the transmit engine may resume send operation
- A Mac sublayer may transmit pause frames with pause\_time = 0. The zero value will stop a pause count down, executed by the MAC's link partner. Effectively, a value of zero restarts a link partner's transmit engine, assuming the link partner was inhibited by a previous pause operation.

# 14.10 Flow Control Scenario

This scenario assumes that the Gigabit switch has a 1:1 port mapping, between the Gigabit Server and Client. The switch does not implement header aligned blocking, nor will it drop packets to alleviate buffer pressure. The following constraints are placed on this scenario:

- Client
  - Full-duplex connection at Gigabit speed.
  - Implements flow control.
  - Flow control enabled.
- Switch
  - Does not drop packets.
  - Full-duplex connection to Client.
- Server
  - Gigabit connection.
  - Either half/full-duplex connection at Gigabit speed (i.e., this scenario will cover two subcases).

#### 14.10.1 File Transfer

The client begins a FTP session (see Figure 56). The file size is very large and will take several minutes for a complete transfer, even at Gigabit wire speed.

Figure 56: File Transfer Scenario: FTP Session Begins



# 14.10.2 Speed Mismatch

The Client sends pause frame(s) to the switch (see Figure 57). The Client's pipe has been saturated, and the RX buffers are almost exhausted. The Client begins sending pause frames, when the RX buffer high-water mark/threshold is hit. Any number of reasons can account for the RX buffer issue. The assumption will be made that the Client PCI bus lack bandwidth to DMA packets, at wire speed, to host memory. The user may be playing a DVD, for example.

Figure 57: File Transfer Scenario: Speed Mismatch



# 14.10.3 Switch Buffers Run Low

The switch must wait/inhibit transmission to the Client (see Figure 58). During the pause interval, the server is still sending packets to the switch. The switch buffers some packets, but eventually hits an internal threshold; memory will run short. Since dropping packets is undesirable, the switch must slow incoming packets from the server. The duplex mode of the server's connection dictates how the switch slows traffic. There are two options:

- Jamming (half-duplex)
- Pause frames (full-duplex)

Figure 58: File Transfer Scenario: Speed Buffers Run Low



# 14.10.4 Switch Backpressure

The Switch will jam ports configured with half-duplex link to slow frame transmission (see Figure 59). In this case, the Server connection must be half-duplex, and then the switch may apply back pressure to the port. The Switch will transmit a jamming pattern, which will prevent the Server from transmitting further packets. The Server's MAC will detect a collision situation, and will back off for a specified interval. The Switch will continue to apply back pressure to the Server Ingress, until the Client egress is available. The Client port will be available when the pause interval expires, and no further pause packets are sent by the Gigabit Client.

Figure 59: File Transfer Scenario: Switch Backpressure



### 14.10.5 Switch Flow Control

The Switch can only use IEEE 802.3x flow control when the link is configured for full-duplex operation (see Figure 60). When buffers are near exhaustion, the switch will send a pause frame to the Server. The Server's MAC will be inhibited for a pause\_time interval. During the pause interval, the Switch has the opportunity to empty the buffered packets. Once the buffered packets fall below the high water mark, the Switch may send another pause frame, with pause\_time = 0, to terminate the Server's pause interval. The Switch may also allow the Server's pause interval to expire. Either way, the Switch no longer will inhibit the Server from sending packets.

Figure 60: File Transfer Scenario: Switch Flow Control



# 14.10.6 File Transfer Complete

The Client has caught up with the transmission flow of the Server (see Figure 61). The Client's RX buffers/memory is below the flow control threshold. The file transfer is complete. This scenario was a worst-case cascade, where the pause delay propagated through the LAN. The Switch could absorb the Client's pause delay, without having to flow control the Server.

Figure 61: File Transfer Scenario: File Transfer Complete



### 14.11 Pause Control Frame

The minimum size frame is 512 bits or 64 bytes (see Figure 62). MAC control frames must pad zeros into the unused portion of the payload. A flow control frame contains the following fields:

- Destination address field, set to 01-80-C2-00-00-01
- Source address field set to unique MAC address of sender
- LL/Type field set to the 802 3 MAC CONTROL value, set to 88–08
- MAC control pause opcode (00-01), pause\_time, and reserved field (zeros)

Figure 62: Pause Control Frame



# **Appendix B: Terminology**

| Term                                  | Definition                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| BD                                    | Buffer Descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Deferred Procedure Call (DPC)         | The ISR may schedule a O/S callback to process interrupts at a later time.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Expansion ROM                         | PCI devices may optionally expose device specific programs to BIOS. For example, network devices may place PXE boot code in their expansion ROM region.                                                                                                                                                                                                                                                                                  |  |  |  |
| Host Coalescing                       | A hardware block which the Ethernet controller status block. The hardware will drive a line interrupt or MSI.                                                                                                                                                                                                                                                                                                                            |  |  |  |
| Interrupt Distribution Queue          | The Ethernet controller supports four interrupt distribution queues per class of service. The rules engine may place traffic into RX return rings based on rules checking. Within each class of service, the traffic may further be organized in Interrupt Distribution Queues. For example, frames with errors may be given lower data path priority over frames without errors, all within the same class of service (RX Return Ring). |  |  |  |
| Interrupt Service Routine (ISR)       | A procedure where device interrupts are processed.                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Pre-boot execution (PXE)              | An industry-standard client/server interface that allows networked computers that are not yet loaded with an operating system to be configured and booted remotely.                                                                                                                                                                                                                                                                      |  |  |  |
| Receive BD Initiator                  | The hardware block that DMA's BDs when receive ring indices are written.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| Receive Data and Receive BD Initiator | The hardware block the updates packet buffers, in host memory, after an Ethernet frame is received. The hardware block will also update the BD with information like checksum and VLAN Tags.                                                                                                                                                                                                                                             |  |  |  |
| Receive Data Completion               | The hardware block that updates the host coalescing engine after the packet buffers and BD are DMAed to host memory.                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Receive Queue Placement               | The hardware block that routes a categorized frame to one of sixteen RX Return rings.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| Send BD Initiator                     | The hardware block that is activated when a Send producer index is updated by host software. The hardware block will DMA a BD from host memory.                                                                                                                                                                                                                                                                                          |  |  |  |
| Send Data Initiator                   | The hardware block updates the DMAs in the packet buffers from host memory. The packet buffers are DMAed after the BD has been moved to device local memory.                                                                                                                                                                                                                                                                             |  |  |  |

# **Appendix C: Device Register and Memory Map**

# 14.12 BCM5717/BCM5718 Memory Map

Table 107: BCM5717/BCM5718 Memory Map

| Region                                                                                | Size      | NIC CPU View              | Host Flat View            | Host Standard<br>View (Offset) | Host UNDI View            |
|---------------------------------------------------------------------------------------|-----------|---------------------------|---------------------------|--------------------------------|---------------------------|
| Unmapped                                                                              | 256B      | 0x00000000-<br>0x000000FF | 0x01000000-<br>0x010000FF | 0x00000000-<br>0x000000FF      | 0x00000000-<br>0x000000FF |
| Send Ring [1] RCB                                                                     | 16B       | 0x00000100-<br>0x0000010F | 0x01000100-<br>0x0100010F | 0x00000100-<br>0x0000010F      | 0x00000100-<br>0x0000010F |
| Send Ring [2 – 16] RCBs<br>(Relocated or expanded in BCM5717/<br>BCM5718)             | 240B      | 0x00000110-<br>0x000001FF | 0x01000110-<br>0x010001FF | 0x00000110-<br>0x000001FF      | 0x00000110-<br>0x000001FF |
| Receive Return<br>Ring0 RCB                                                           | 16B       | 0x00000200-<br>0x0000020F | 0x01000200-<br>0x0100020F | 0x00000200-<br>0x0000020F      | 0x00000200-<br>0x0000020F |
| Receive Return<br>Ring1 RCB                                                           | 16B       | 0x00000210-<br>0x0000021F | 0x01000210-<br>0x0100021F | 0x00000210-<br>0x0000021F      | 0x00000210-<br>0x0000021F |
| Receive Return<br>Ring2 RCB                                                           | 16B       | 0x00000220-<br>0x0000022F | 0x01000220-<br>0x0100022F | 0x00000220-<br>0x0000022F      | 0x00000220-<br>0x0000022F |
| Receive Return<br>Ring3 RCB                                                           | 16B       | 0x00000230-<br>0x0000023F | 0x01000230-<br>0x0100023F | 0x00000230-<br>0x0000023F      | 0x00000230-<br>0x0000023F |
| VRQ Receive Return Ring RCBs – [4 – 16]<br>(Relocated or expanded in BCM5717/BCM5718) | 208B      | 0x00000240-<br>0x0000030F | 0x01000240-<br>0x0100030F | 0x00000240-<br>0x0000030F      | 0x00000240-<br>0x0000030F |
| Unmapped                                                                              | 2.3KB     | 0x00000420-<br>0x00000B4F | 0x01000420-<br>0x01000B4F | 0x00000420-<br>0x00000B4F      | 0x00000420-<br>0x00000B4F |
| Software Gencomm                                                                      | 1KB       | 0x00000B50-<br>0x00000F4F | 0x01000B50-<br>0x01000F4F | 0x00000B50-<br>0x00000F4F      | 0x00000B50-<br>0x00000F4F |
| Unmapped                                                                              | 12KB-176B | 0x00000F50-<br>0x00003FFF | 0x01000F50-<br>0x01003FFF | 0x00000F50-<br>0x00003FFF      | 0x00000F50-<br>0x00003FFF |
| Unmapped                                                                              | 32KB      | 0x01004000-<br>0x0100FFFF | 0x01004000-<br>0x0100FFFF | 0x00004000-<br>0x0000FFFF      | 0x00004000-<br>0x0000FFFF |
| RX MBUF<br>(Relocated or expanded in BCM5717/<br>BCM5718)                             | 32KB      | 0x00010000-<br>0x00019FFF | 0x01010000-<br>0x01019FFF | 0x00010000-<br>0x00019FFF      | 0x00010000-<br>0x00019FFF |
| Unmapped                                                                              | 32KB      | 0x0001A000-<br>0x0001FFFF | 0x0101A000-<br>0x0101FFFF | 0x0001A000-<br>0x0001FFFF      | 0x0001A000-<br>0x0001FFFF |
| SBD Cache<br>(Relocated or expanded in BCM5717/<br>BCM5718)                           | 16KB      | 0x00020000-<br>0x00023FFF | 0x00020000-<br>0x00023FFF | 0x00020000-<br>0x00023FFF      | 0x00020000-<br>0x00023FFF |
| Std RBD Cache<br>(Relocated or expanded in BCM5717/<br>BCM5718)                       | 17KB      | 0x00024000-<br>0x000283FF | 0x01024000-<br>0x010283FF | 0x00024000-<br>0x000283FF      | 0x00024000-<br>0x000283FF |

Table 107: BCM5717/BCM5718 Memory Map (Cont.)

| Region                                                            | Size          | NIC CPU View              | Host Flat View            | Host Standard<br>View (Offset) | Host UNDI View            |
|-------------------------------------------------------------------|---------------|---------------------------|---------------------------|--------------------------------|---------------------------|
| Jumbo RBD Cache<br>(Relocated or expanded in BCM5717/<br>BCM5718) | 17KB          | 0x00028400-<br>0x0002C7FF | 0x01028400-<br>0x0102C7FF | 0x00028400-<br>0x0002C7FF      | 0x00028400-<br>0x0002C7FF |
| TX MBUF (Relocated or expanded in BCM5717/BCM5718)                | 29KB          | 0x0002C800-<br>0x00033BFF | 0x0102C800-<br>0x01033BFF | 0x0002C800-<br>0x00033BFF      | 0x0002C800-<br>0x00033BFF |
| Unmapped                                                          | 15M<br>+817KB | 0x00033C00-<br>0x00FFFFF  | 0x01033C00-<br>0x01FFFFFF | 0x00033C00-<br>0x00FFFFF       | 0x00033C00-<br>0x00FFFFF  |
| RXCPU ROM <sup>C</sup>                                            | 1.2KB         | 0x40000000-<br>0x400004FF | -                         | -                              | -                         |
| PCI Configuration                                                 | 256B          | 0xC0000000-<br>0xC00000FF | 0x00000000-<br>0x000000FF | 0x00000000-<br>0x000000FF      | 0x00000000-<br>0x000000FF |
| High Priority Mailbox                                             | 512B          | _                         | 0x00000200-<br>0x000003FF | 0x00000200-<br>0x000003FF      | 0x00005800-<br>0x000059FF |
| Functional Registers                                              | 31KB          | 0xC0000400-<br>0xC0007FFF | 0x00000400-<br>0x00007FFF | 0x00000400-<br>0x00007FFF      | 0x00000100-<br>0x00007FFF |
| Mailboxes                                                         | 1MB           | -                         | 0x00100000-<br>0x001FFFFF | _                              | -                         |
| Scratch Pad<br>(Relocated or expanded in BCM5717/<br>BCM5718)     | 28KB          | 0xC0030000-<br>0xC0036FFF | 0xC0030000-<br>0xC0036FFF | 0xC0030000-<br>0xC0036FFF      | 0xC0030000-<br>0xC0036FFF |
| Unmapped                                                          | 4KB           | 0xC0037000-<br>0xC0037FFF | 0xC0037000-<br>0xC0037FFF | 0xC0037000-<br>0xC0037FFF      | 0xC0037000-<br>0xC0037FFF |
| RXCPU ROM Secondary Access                                        | 8KB           | 0xC0038000-<br>0xC009FFF  | 0xC0038000-<br>0xC0039FFF | 0xC0038000-<br>0xC0039FFF      | 0xC0038000-<br>0xC0039FFF |
| Send RCB0 NIC Address                                             | 4B            | 0x00004000-<br>0x0000400F | 0x01004000-<br>0x0100400F | 0x00004000-<br>0x0000400F      | 0x00004000-<br>0x0000400F |
| Receive Standard Producer RCB0 NIC Address                        | 4B            | 0x00040000-<br>0x0004000F | 0x01040000-<br>0x0104000F | 0x00040000-<br>0x0004000F      | 0x00040000-<br>0x0004000F |
| Receive Jumbo Producer RCB0 NIC Address                           | 4B            | 0x00044400-<br>0x0004440F | 0x01044400-<br>0x0104440F | 0x00044400-<br>0x0004440F      | 0x00044400-<br>0x0004440F |

# 14.13 BCM5717/BCM5718 Register Map

This is the Host Standard View of BAR1 and BAR2.

| Block Name  | Block Range   | Sub-Block Range | Description                                        |
|-------------|---------------|-----------------|----------------------------------------------------|
| HP Mail Box | 0x0000-0x01FF | 0x0000-0x01FF   | Unused (Legacy-PCle Configuration Register Shadow) |
|             | 0x0200-0x03FF | 0x0200-0x03FF   | High Priority Mail Boxes                           |
| EMAC        | 0x0400-0x07FF | 0x0400-0x06FF   | EMAC                                               |
|             |               | 0x0700-0x7FF    | Unused                                             |
| EMAC STAT   | 0x0800-0x0BFF | 0x0800-0x08FF   | EMAC Statistics (Aggregated)                       |
|             |               | 0x0900-0x09CF   | APE Private EMAC Stats (Aggregated)                |
| 201         |               | 0x09D0-0x0BFF   | IOV per Queue EMAC Statistics                      |
| SDI         | 0x0C00-0x0FFF | 0x0C00-0x0CF7   | Send Data Initiator                                |
|             |               | 0x0CF8-0x0FFF   | Unused                                             |
| SDC         | 0x1000-0x13FF | 0x1000-0x100B   | Send data Completion                               |
|             |               | 0x100C-0x13FF   | Unused                                             |
| SBDS        | 0x1400-0x17FF | 0x1400-0x147F   | SBDS Registers                                     |
|             |               | 0x1480-0x17FF   | Unused                                             |
| SBDI        | 0x1800-0x1BFF | 0x1800-0x1847   | Send BD Initiator                                  |
|             |               | 0x1848-0x1BFF   | Unused                                             |
| SBDC        | 0x1C00-0x1FFF | 0x1C00-0x1C03   | Send BD Completion                                 |
|             |               | 0x1C04-0x1FFF   | Unused                                             |
| RQP         | 0x2000-0x23FF | 0x2000-0x2258   | Receive List Placement                             |
|             |               | 0x2259-0x23FF   | Unused                                             |
| RDI         | 0x2400-0x27FF | 0x2400-0x24C3   | Receive Data Initiator                             |
|             |               | 0x24C4-0x24FF   | Unused                                             |
|             |               | 0x2500-0x27FF   | VRQ RCB Registers                                  |
| RDC         | 0x2800-0x2BFF | 0x2800-0x2803   | Receive Data Completion                            |
|             |               | 0x2804-0x2BFF   | Unused                                             |
| RBDI        | 0x2C00-0x2FFF | 0x2C00-0x2C1B   | Receive BD Initiator                               |
|             |               | 0x2C1C-0x2FFF   | Unused                                             |
| RBDC        | 0x3000-0x33FF | 0x3000-0x300F   | Receive BD Completion                              |
|             |               | 0x3010-0x33FF   | Unused                                             |
| CMPU        | 0x3400-0x37FF | 0x3400-0x35FF   | Unused                                             |
|             |               | 0x3600-0x3687   | Central Power Management Unit                      |
| DBU         | 0x3800-0x3BFF | 0x3800-0x3817   | Debug Unit (UART)                                  |
|             |               | 0x3900-0x3907   | Chip Debug                                         |
|             |               | 0x3908-0x3BFF   | Unused                                             |
| HC          | 0x3C00-0x3FFF | 0x3C00-0x3CC3   | Host Coalescing                                    |
|             |               | 0x3CC4-0x3FFF   | Multiqueue HC                                      |
| MA          | 0x4000-0x43FF | 0x4000-0x400F   | Memory Arbiter                                     |
|             |               | 0x4010-0x43FF   | Unused                                             |
| ВМ          | 0x4400-0x47FF | 0x4400-0x445B   | Buffer manager                                     |
|             |               | 0x445C-0x47FF   | Unused                                             |

| Block Name             | Block Range               | Sub-Block Range | Description                                               |
|------------------------|---------------------------|-----------------|-----------------------------------------------------------|
| DMAR                   | 0x4800-0x4BFF             | 0x4800-0x4910   | DMAR LSO channel                                          |
|                        |                           | 0x4A00-0x4AFF   | DMAR BD channel                                           |
|                        |                           | 0x4B00-0x4BFF   | DMAR non-LSO channels                                     |
| DMAW                   | 0x4C00 -0x4FFF            | 0x4C00-0x4C07   | DMA Write                                                 |
|                        |                           | 0x4C08-0x4FFF   | Unused                                                    |
| RX-CPU                 | 0x5000-0x53FF             | 0x5000-0x5037   | RX CPU                                                    |
|                        |                           | 0x5038-0x53FF   | Unused                                                    |
| VRQ Filter-EMAC        | 0x5400-0x57FF             | 0x5400-0x55FF   | VRQ Filter Set                                            |
|                        |                           | 0x5600-0x568F   | VRQ Mapper                                                |
|                        |                           | 0x5690-0x572F   | VRQ Perfect Match Registers                               |
|                        |                           | 0x5730-0x57FF   | Unused                                                    |
| MB                     | 0x5800-0x5BFF             | 0x5800-0x5903   | Low Priority Mail Box                                     |
|                        |                           | 0x5903-0x5BFF   | Unused                                                    |
| FTQ                    | 0x5C00-0x5FFF             | 0x5C00-0x5CFF   | Flow Through Queue                                        |
|                        |                           | 0x5D00-0x5FFF   | Unused                                                    |
| MSI                    | 0x6000-0x63FF             | 0x6000-0x6007   | Message Signaled Interrupt                                |
|                        |                           | 0x6008-0x63FF   | Unused                                                    |
| CFG Port               | 0x6400-0x67FF             | 0x6400-0x67FF   | PCIe Core Private Registers Access to Configuration Space |
| GRC                    | 0x6800-0x6BFF             | 0x6800-0x681B   | Misc Host Control                                         |
|                        |                           | 0x6834-0x6843   | SEEPROM                                                   |
|                        |                           | 0x6890-0x68A8   | Misc Control                                              |
|                        |                           | 0x68B4-0x68EF   | E Switch                                                  |
| ASF                    | 0x6C00-0x6FFF             | 0x6C00-6C37     | ASF & SMBUS                                               |
|                        |                           | 0x6C38-0x6FFF   | Unused                                                    |
| NVM                    | 0x7000-0x73FF             | 0x7000-0x703B   | Non Volatile memory (Flash Controller)                    |
|                        |                           | 0x703C-0x73FF   | Unused                                                    |
| UART                   | 0x7800-0x7BFF             | 0x7800-0x781F   | Debug UART Modem                                          |
|                        |                           | 0x7820-0x7BFF   | Unused                                                    |
| TL-DL-PL Port          | 0x7C00-0x7FFF             | 0x7C00-0x7FFF   | PCIe Core Private Register Access to TL, DL & PL          |
| Registers below are or | utside Host Standard View |                 |                                                           |
| APE                    | 0x10000-0x18FFF           | _               | APE Access                                                |
| MF                     | 0x19000-0x193FF           | _               | Management Filters                                        |

# 14.14 BCM5719 Memory Map

| Region            | Size | NIC CPU View |             | Host Standard<br>View (Offset) | Host UNDI View |
|-------------------|------|--------------|-------------|--------------------------------|----------------|
| Unmapped          | 256B | 0x00000000-  | 0x01000000- | 0x00000000-                    | 0x0000000-     |
|                   |      | 0x000000FF   | 0x010000FF  | 0x000000FF                     | 0x00000FF      |
| Send Ring [1] RCB | 16B  | 0x00000100-  | 0x01000100- | 0x00000100-                    | 0x0000100-     |
|                   |      | 0x0000010F   | 0x0100010F  | 0x0000010F                     | 0x0000010F     |
| Send Ring [2-16]  | 240B | 0x00000110-  | 0x01000110- | 0x00000110                     | 0x00000110-    |
| RCBs              |      | 0x000001FF   | 0x010001FF  | 0x000001FF                     | 0x000001FF     |

| Region                                    | Size      | NIC CPU View              | Host Flat View            | Host Standard<br>View (Offset) | Host UNDI View            |
|-------------------------------------------|-----------|---------------------------|---------------------------|--------------------------------|---------------------------|
| Receive Return                            | 16B       | 0x00000200-               | 0x01000200-               | 0x00000200-                    | 0x00000200-               |
| Ring0 RCB                                 |           | 0x0000020F                | 0x0100020F                | 0x0000020F                     | 0x0000020F                |
| Receive Return                            | 16B       | 0x00000210-               | 0x01000210-               | 0x00000210-                    | 0x00000210-               |
| Ring1 RCB                                 |           | 0x0000021F                | 0x0100021F                | 0x0000021F                     | 0x0000021F                |
| Receive Return                            | 16B       | 0x00000220-               | 0x01000220-               | 0x00000220-                    | 0x00000220-               |
| Ring2 RCB                                 |           | 0x0000022F                | 0x0100022F                | 0x0000022F                     | 0x0000022F                |
| Receive Return                            | 16B       | 0x00000230-               | 0x01000230-               | 0x00000230-                    | 0x00000230-               |
| Ring3 RCB                                 |           | 0x0000023F                | 0x0100023F                | 0x0000023F                     | 0x0000023F                |
| VRQ Receive<br>Return Ring RCBs<br>[4–16] | 208B      | 0x00000240-<br>0x0000030F | 0x01000240-<br>0x0100030F | 0x00000240-<br>0x0000030F      | 0x00000240-<br>0x0000030F |
| Unmapped                                  | 2.3KB     | 0x00000420-               | 0x01000420-               | 0x00000420-                    | 0x00000420-               |
|                                           |           | 0x00000B4F                | 0x01000B4F                | 0x00000B4F                     | 0x00000B4F                |
| Software                                  | 1KB       | 0x00000B50-               | 0x01000B50-               | 0x00000B50-                    | 0x00000B50-               |
| Gencomm                                   |           | 0x00000F4F                | 0x01000F4F                | 0x00000F4F                     | 0x00000F4F                |
| Unmapped                                  | 12KB-176B | 0x00000F50-               | 0x01000F50-               | 0x00000F50-                    | 0x00000F50-               |
|                                           |           | 0x00003FFF                | 0x01003FFF                | 0x00003FFF                     | 0x00003FFF                |
| Unmapped                                  | 32KB      | 0x01004000-               | 0x01004000-               | 0x00004000-                    | 0x00004000-               |
|                                           |           | 0x0100FFFF                | 0x0100FFFF                | 0x0000FFFF                     | 0x0000FFFF                |
| RX MBUF                                   | 32KB      | 0x00010000-               | 0x01010000-               | 0x00010000-                    | 0x00010000-               |
|                                           |           | 0x00019FFF                | 0x01019FFF                | 0x00019FFF                     | 0x00019FFF                |
| Unmapped                                  | 32KB      | 0x0001A000-               | 0x0101A000-               | 0x0001A000-                    | 0x0001A000-               |
| 000 0 1                                   | 40KD      | 0x0001FFFF                | 0x0101FFFF                | 0x0001FFFF                     | 0x0001FFFF                |
| SBD Cache                                 | 16KB      | 0x00020000-<br>0x00023FFF | 0x00020000-               | 0x00020000-                    | 0x00020000-               |
| Std RBD                                   | 17KB      |                           | 0x00023FFF                | 0x00023FFF                     | 0x00023FFF                |
| Cache                                     | IIID      | 0x00024000-<br>0x000283FF | 0x01024000-<br>0x010283FF | 0x00024000-<br>0x000283FF      | 0x00024000-<br>0x000283FF |
| Jumbo RBD                                 | 17KB      | 0x00028311                | 0x01028400-               | 0x00028311                     | 0x00028400-               |
| Cache                                     | TAKE      | 0x00020400-               | 0x01020400-               | 0x0002C7FF                     | 0x0002C7FF                |
| TX MBUF                                   | 29KB      | 0x0002C800-               | 0x0102C800-               | 0x0002C800-                    | 0x0002C800-               |
| TA MEGI                                   | 20112     | 0x00033BFF                | 0x01033BFF                | 0x00033BFF                     | 0x00033BFF                |
| Unmapped                                  | 15M       | 0x00033C00-               | 0x01033C00-               | 0x00033C00-                    | 0x00033C00-               |
|                                           | +817KB    | 0x00FFFFF                 | 0x01FFFFF                 | 0x00FFFFF                      | 0x00FFFFF                 |
| RXCPU ROM                                 | 1.2KB     | 0x40000000-<br>0x400004FF | _                         | -                              | -                         |
| PCI Configuration                         | 256B      | 0xC0000000-               | 0x00000000-               | 0x00000000-                    | 0x00000000—               |
|                                           |           | 0xC00000FF                | 0x000000FF                | 0x000000FF                     | 0x000000FF                |
| High Priority                             | 512B      |                           | 0x00000200-               | 0x00000200-                    | 0x00005800-               |
| Mailbox                                   |           |                           | 0x000003FF                | 0x000003FF                     | 0x000059FF                |
| Functional                                | 31KB      | 0xC0000400-               | 0x00000400-               | 0x00000400-                    | 0x00000100-               |
| Registers                                 |           | 0xC0007FFF                | 0x00007FFF                | 0x00007FFF                     | 0x00007FFF                |
| Mailboxes                                 | 1MB       | _                         | 0x00100000-<br>0x001FFFFF |                                |                           |
| Scratch Pad                               | 28KB      | 0xC0030000-               | 0xC0030000-               | 0xC0030000-                    | 0xC0030000-               |
|                                           |           | 0xC0036FFF                | 0xC0036FFF                | 0xC0036FFF                     | 0xC0036FFF                |

| Region                                           | Size | NIC CPU View                           | Host Flat View                          | Host Standard<br>View (Offset)          | Host UNDI View                          |
|--------------------------------------------------|------|----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|
| Unmapped                                         | 4KB  | 0xC0037000-                            | 0xC0037000-                             | 0xC0037000-                             | 0xC0037000-                             |
| RXCPU ROM<br>Secondary                           | 8KB  | 0xC0037FFF<br>0xC0038000-<br>0xC009FFF | 0xC0037FFF<br>0xC0038000-<br>0xC0039FFF | 0xC0037FFF<br>0xC0038000-<br>0xC0039FFF | 0xC0037FFF<br>0xC0038000-<br>0xC0039FFF |
| AccessC<br>Send RCB0 NIC<br>Address              | 4B   | 0x00004000-<br>0x0000400F              | 0x01004000-<br>0x0100400F               | 0x00004000-<br>0x0000400F               | 0x00004000-0x0000400F                   |
| Receive Standard<br>Producer RCB0<br>NIC Address | 4B   | 0x0000400F<br>0x0004000F               | 0x0104000F<br>0x0104000F                | 0x0000400F<br>0x0004000F                | 0x00040000-0x0004000F                   |
| Receive Jumbo<br>Producer RCB0<br>NIC Address    | 4B   | 0x00044400-<br>0x0004440F              | 0x01044400-<br>0x0104440F               | 0x00044400-<br>0x0004440F               | 0x00044400-0x0004440F                   |

# 14.15 BCM5719 Register Map

This is the Host Standard View of BAR1 & BAR2.

| Block Name  | Block Range   | Sub-Block Range | Description                                        |
|-------------|---------------|-----------------|----------------------------------------------------|
| HP Mail Box | 0x0000-0x01FF | 0x0000-0x01FF   | Unused (Legacy-PCle Configuration Register Shadow) |
|             | 0x0200-0x03FF | 0x0200-0x03FF   | High Priority Mail Boxes                           |
| EMAC        | 0x0400-0x07FF | 0x0400-0x06FF   | EMAC                                               |
|             |               | 0x0700-0x7FF    | Unused                                             |
| EMAC STAT   | 0x0800-0x0BFF | 0x0800-0x08FF   | EMAC Statistics (Aggregated)                       |
|             |               | 0x0900-0x09CF   | APE Private EMAC Stats (Aggregated)                |
| 001         |               | 0x09D0-0x0BFF   | IOV per Queue EMAC Statistics                      |
| SDI         | 0x0C00-0x0FFF | 0x0C00-0x0CF7   | Send Data Initiator                                |
|             |               | 0x0CF8-0x0FFF   | Unused                                             |
| SDC         | 0x1000-0x13FF | 0x1000-0x100B   | Send data Completion                               |
|             |               | 0x100C-0x13FF   | Unused                                             |
| SBDS        | 0x1400-0x17FF | 0x1400-0x147F   | SBDS Registers                                     |
|             |               | 0x1480-0x17FF   | Unused                                             |
| SBDI        | 0x1800-0x1BFF | 0x1800-0x1847   | Send BD Initiator                                  |
|             |               | 0x1848-0x1BFF   | Unused                                             |
| SBDC        | 0x1C00-0x1FFF | 0x1C00-0x1C03   | Send BD Completion                                 |
|             |               | 0x1C04-0x1FFF   | Unused                                             |
| RQP         | 0x2000-0x23FF | 0x2000-0x2258   | Receive List Placement                             |
|             |               | 0x2259-0x23FF   | Unused                                             |
| RDI         | 0x2400-0x27FF | 0x2400-0x24C3   | Receive Data Initiator                             |
|             |               | 0x24C4-0x24FF   | Unused                                             |
|             |               | 0x2500-0x27FF   | VRQ RCB Registers                                  |
| RDC         | 0x2800-0x2BFF | 0x2800-0x2803   | Receive Data Completion                            |
|             |               | 0x2804-0x2BFF   | Unused                                             |
| RBDI        | 0x2C00-0x2FFF | 0x2C00-0x2C1B   | Receive BD Initiator                               |
|             |               | 0x2C1C-0x2FFF   | Unused                                             |
| RBDC        | 0x3000-0x33FF | 0x3000-0x300F   | Receive BD Completion                              |
|             |               | 0x3010-0x33FF   | Unused                                             |
| CMPU        | 0x3400-0x37FF | 0x3400-0x35FF   | Unused                                             |
|             |               | 0x3600-0x3687   | Central Power Management Unit                      |
| DBU         | 0x3800-0x3BFF | 0x3800-0x3817   | Debug Unit (UART)                                  |
|             |               | 0x3900-0x3907   | Chip Debug                                         |
|             |               | 0x3908-0x3BFF   | Unused                                             |
| HC          | 0x3C00-0x3FFF | 0x3C00-0x3CC3   | Host Coalescing                                    |
|             |               | 0x3CC4-0x3FFF   | Multiqueue HC                                      |
| MA          | 0x4000-0x43FF | 0x4000-0x400F   | Memory Arbiter                                     |
|             |               | 0x4010-0x43FF   | Unused                                             |
| ВМ          | 0x4400-0x47FF | 0x4400-0x445B   | Buffer manager                                     |
|             |               | 0x445C-0x47FF   | Unused                                             |

| Block Name          | Block Range              | Sub-Block Range | Description                                               |  |
|---------------------|--------------------------|-----------------|-----------------------------------------------------------|--|
| DMAR                | 0x4800-0x4BFF            | 0x4800-0x4910   | DMAR LSO channel                                          |  |
|                     |                          | 0x4A00-0x4AFF   | DMAR BD channel                                           |  |
|                     |                          | 0x4B00-0x4BFF   | DMAR non-LSO channels                                     |  |
| DMAW                | 0x4C00-0x4FFF            | 0x4C00-0x4C07   | DMA Write                                                 |  |
|                     |                          | 0x4C08-0x4FFF   | Unused                                                    |  |
| RX-CPU              | 0x5000-0x53FF            | 0x5000-0x5037   | RX CPU                                                    |  |
|                     |                          | 0x5038-0x53FF   | Unused                                                    |  |
| VRQ Filter-EMAC     | 0x5400-0x57FF            | 0x5400-0x55FF   | VRQ Filter Set                                            |  |
|                     |                          | 0x5600-0x568F   | VRQ Mapper                                                |  |
|                     |                          | 0x5690-0x572F   | VRQ Perfect Match Registers                               |  |
|                     |                          | 0x5730-0x57FF   | Unused                                                    |  |
| MB                  | 0x5800-0x5BFF            | 0x5800-0x5903   | Low Priority Mail Box                                     |  |
|                     |                          | 0x5903-0x5BFF   | Unused                                                    |  |
| FTQ                 | 0x5C00-0x5FFF            | 0x5C00-0x5CFF   | Flow Through Queue                                        |  |
|                     |                          | 0x5D00-0x5FFF   | Unused                                                    |  |
| MSI                 | 0x6000-0x63FF            | 0x6000-0x6007   | Message Signaled Interrupt                                |  |
|                     |                          | 0x6008-0x63FF   | Unused                                                    |  |
| CFG Port            | 0x6400-0x67FF            | 0x6400-0x67FF   | PCIe Core Private Registers Access to Configuration Space |  |
| GRC                 | 0x6800-0x6BFF            | 0x6800-0x681B   | Misc Host Control                                         |  |
|                     |                          | 0x6834-0x6843   | SEEPROM                                                   |  |
|                     |                          | 0x6890-0x68A8   | Misc Control                                              |  |
|                     |                          | 0x68B4-0x68EF   | E Switch                                                  |  |
| ASF                 | 0x6C00-0x6FFF            | 0x6C00-6C37     | ASF & SMBUS                                               |  |
|                     |                          | 0x6C38-0x6FFF   | Unused                                                    |  |
| NVM                 | 0x7000-0x73FF            | 0x7000-0x703B   | Non Volatile memory (Flash Controller)                    |  |
|                     |                          | 0x703C-0x73FF   | Unused                                                    |  |
| UART                | 0x7800-0x7BFF            | 0x7800-0x781F   | Debug UART Modem                                          |  |
|                     |                          | 0x7820-0x7BFF   | Unused                                                    |  |
| TL-DL-PL Port       | 0x7C00-0x7FFF            | 0x7C00-0x7FFF   | PCIe Core Private Register Access to TL, DL & PL          |  |
| Registers below are | outside Host Standard Vi | ew              |                                                           |  |
| APE                 | 0x10000-0x18FFF          | _               | APE Access                                                |  |
| MF                  | 0x19000-0x193FF          | _               | Management Filters                                        |  |

# 14.16 BCM5720 Memory Map

The BCM5720 internal memory map is shown in the table below.

| Region                          | Size   | NIC CPU View              | Host Flat View            | Host Standard<br>View (Offset) | Host UNDI View            |
|---------------------------------|--------|---------------------------|---------------------------|--------------------------------|---------------------------|
| Unmapped                        | 256B   | 0x00000000-               | 0x01000000-               | 0x00000000-                    | 0x00000000-               |
| оппаррец                        | 2300   | 0x0000000FF               | 0x0100000FF               | 0x0000000FF                    | 0x000000FF                |
| Send Ring [1] RCB               | 16B    | 0x00000011                | 0x01000011                | 0x00000011                     | 0x0000011                 |
| Ocha King [1] KOD               | 100    | 0x00000100-               | 0x01000100-               | 0x00000100-                    | 0x00000100-               |
| Send Ring [2 – 16]              | 240B   | 0x00000101                | 0x01000101                | 0x00000101                     | 0x00000110-               |
| RCBs                            | 2400   | 0x00000116-               | 0x01000110-               | 0x00000116-                    | 0x00000116-               |
| Receive Return                  | 16B    | 0x00000111                | 0x01000111                | 0x00000111                     | 0x000000111               |
| Ring0 RCB                       | 100    | 0x00000200-<br>0x0000020F | 0x01000200-<br>0x0100020F | 0x00000200F                    | 0x00000200F               |
| Receive Return                  | 16B    | 0x00000201                | 0x01000201                | 0x00000201                     | 0x00000201                |
| Ring1 RCB                       | 100    | 0x00000210-<br>0x0000021F | 0x01000210-<br>0x0100021F | 0x00000210-<br>0x0000021F      | 0x00000210-<br>0x0000021F |
| Receive Return                  | 16B    | 0x0000021F                | 0x0100021P                | 0x0000021F                     | 0x0000021F                |
| Ring2 RCB                       | 100    | 0x00000220-<br>0x0000022F | 0x01000220-<br>0x0100022F | 0x0000022F                     | 0x0000022F                |
|                                 | 4CD    |                           |                           |                                |                           |
| Receive Return<br>Ring3 RCB     | 16B    | 0x00000230-               | 0x01000230-               | 0x00000230-<br>0x0000023F      | 0x00000230-               |
|                                 | 0000   | 0x0000023F                | 0x0100023F                |                                | 0x0000023F                |
| VRQ Receive<br>Return Ring RCBs | 208B   | 0x00000240-<br>0x0000030F | 0x01000240-<br>0x0100030F | 0x00000240-<br>0x0000030F      | 0x00000240-<br>0x0000030F |
| - [4 - 16]                      | 0.0KD  | 0,00000420                | 0.04000400                | 0,00000400                     | 0,,00000420               |
| Unmapped                        | 2.3KB  | 0x00000420-               | 0x01000420-               | 0x00000420-                    | 0x00000420-               |
| 0.5                             | 4145   | 0x00000B4F                | 0x01000B4F                | 0x00000B4F                     | 0x00000B4F                |
| Software<br>Gencomm             | 1KB    | 0x00000B50-               | 0x01000B50-               | 0x00000B50-                    | 0x00000B50-               |
|                                 |        | 0x00000F4F                | 0x01000F4F                | 0x00000F4F                     | 0x00000F4F                |
| Unmapped                        | 12KB – | 0x00000F50-               | 0x01000F50-               | 0x00000F50-                    | 0x00000F50-               |
|                                 | 176B   | 0x00003FFF                | 0x01003FFF                | 0x00003FFF                     | 0x00003FFF                |
| Unmapped                        | 32KB   | 0x01004000-               | 0x01004000-               | 0x00004000-                    | 0x00004000-               |
|                                 |        | 0x0100FFFF                | 0x0100FFFF                | 0x0000FFFF                     | 0x0000FFFF                |
| RX MBUF                         | 32KB   | 0x00010000-               | 0x01010000-               | 0x00010000-                    | 0x00010000-               |
|                                 |        | 0x00019FFF                | 0x01019FFF                | 0x00019FFF                     | 0x00019FFF                |
| Unmapped                        | 32KB   | 0x0001A000-               | 0x0101A000-               | 0x0001A000-                    | 0x0001A000-               |
|                                 |        | 0x0001FFFF                | 0x0101FFFF                | 0x0001FFFF                     | 0x0001FFFF                |
| SBD Cache                       | 16KB   | 0x00020000-               | 0x00020000-               | 0x00020000-                    | 0x00020000-               |
|                                 |        | 0x00023FFF                | 0x00023FFF                | 0x00023FFF                     | 0x00023FFF                |
| Std RBD Cache                   | 17KB   | 0x00024000-               | 0x01024000-               | 0x00024000-                    | 0x00024000-               |
|                                 |        | 0x000283FF                | 0x010283FF                | 0x000283FF                     | 0x000283FF                |
| Jumbo RBD Cache                 | 17KB   | 0x00028400-               | 0x01028400-               | 0x00028400-                    | 0x00028400-               |
|                                 |        | 0x0002C7FF                | 0x0102C7FF                | 0x0002C7FF                     | 0x0002C7FF                |
| TX MBUF                         | 29KB   | 0x0002C800-               | 0x0102C800-               | 0x0002C800-                    | 0x0002C800-               |
|                                 |        | 0x00033BFF                | 0x01033BFF                | 0x00033BFF                     | 0x00033BFF                |
| Unmapped                        | 15M    | 0x00033C00-               | 0x01033C00-               | 0x00033C00-                    | 0x00033C00-               |
|                                 | +817KB | 0x00FFFFF                 | 0x01FFFFFF                | 0x00FFFFF                      | 0x00FFFFFF                |
| RXCPU ROM                       | 1.2KB  | 0x40000000-<br>0x400004FF | -                         | -                              | -                         |

| Region                                           | Size | NIC CPU View              | Host Flat View            | Host Standard<br>View (Offset) | Host UNDI View        |
|--------------------------------------------------|------|---------------------------|---------------------------|--------------------------------|-----------------------|
| PCI Configuration                                | 256B | 0xC0000000-               | 0x00000000-               | 0x00000000-                    | 0x0000000-            |
|                                                  |      | 0xC00000FF                | 0x000000FF                | 0x000000FF                     | 0x000000FF            |
| High Priority                                    | 512B | _                         | 0x00000200-               | 0x00000200-                    | 0x00005800-           |
| Mailbox                                          |      |                           | 0x000003FF                | 0x000003FF                     | 0x000059FF            |
| Functional                                       | 31KB | 0xC0000400-               | 0x00000400-               | 0x00000400-                    | 0x00000100-           |
| Registers                                        |      | 0xC0007FFF                | 0x00007FFF                | 0x00007FFF                     | 0x00007FFF            |
| Mailboxes                                        | 1MB  | _                         | 0x00100000-               | _                              | -                     |
|                                                  |      |                           | 0x001FFFFF                |                                |                       |
| Scratch Pad                                      | 28KB | 0xC0030000-               | 0xC0030000-               | 0xC0030000-                    | 0xC0030000-           |
|                                                  |      | 0xC0036FFF                | 0xC0036FFF                | 0xC0036FFF                     | 0xC0036FFF            |
| Unmapped                                         | 4KB  | 0xC0037000-               | 0xC0037000-               | 0xC0037000-                    | 0xC0037000-           |
|                                                  |      | 0xC0037FFF                | 0xC0037FFF                | 0xC0037FFF                     | 0xC0037FFF            |
| RXCPU ROM                                        | 8KB  | 0xC0038000-               | 0xC0038000-               | 0xC0038000-                    | 0xC0038000-           |
| Secondary Access                                 |      | 0xC009FFF                 | 0xC0039FFF                | 0xC0039FFF                     | 0xC0039FFF            |
| Send RCB0 NIC<br>Address                         | 4B   | 0x00004000-<br>0x0000400F | 0x01004000-<br>0x0100400F | 0x00004000-<br>0x0000400F      | 0x00004000-0x0000400F |
| Receive Standard<br>Producer RCB0<br>NIC Address | 4B   | 0x00040000-<br>0x0004000F | 0x01040000-<br>0x0104000F | 0x00040000-<br>0x0004000F      | 0x00040000-0x0004000F |
| Receive Jumbo<br>Producer RCB0<br>NIC Address    | 4B   | 0x00044400-<br>0x0004440F | 0x01044400-<br>0x0104440F | 0x00044400-<br>0x0004440F      | 0x00044400-0x0004440F |

# 14.17 BCM5720 Register Map

The BCM5720 internal register map of each MAC unit is shown in the table below. This is the Host Standard View of BAR1 & BAR2.

| Block Name  | Block Range     | Sub-Block Range | Description                                                                  |  |
|-------------|-----------------|-----------------|------------------------------------------------------------------------------|--|
| HP Mail Box | 0x0000 – 0x01FF | 0x0000 – 0x01FF | Unused {Legacy – PCle Configuration Register Shadow High Priority Mail Boxes |  |
|             | 0x0200 - 0x03FF | 0x0200 - 0x03FF |                                                                              |  |
| EMAC        | 0x0400 - 0x07FF | 0x0400 - 0x06FF | EMAC                                                                         |  |
|             |                 | 0x0700 – 0x7FF  | Unused                                                                       |  |
| EMAC STAT   | 0x0800 - 0x0BFF | 0x0800 - 0x08FF | EMAC Statistics (Aggregated)                                                 |  |
|             |                 | 0x0900 - 0x09CF | APE Private EMAC Stats (Aggregated)                                          |  |
|             |                 | 0x09D0 - 0x0BFF | IOV per Queue EMAC Statistics                                                |  |
| SDI         | 0x0C00 - 0x0FFF | 0x0C00 - 0x0CF7 | Send Data Initiator                                                          |  |
|             |                 | 0x0CF8 - 0x0FFF | Unused                                                                       |  |
| SDC         | 0x1000 - 0x13FF | 0x1000 - 0x100B | Send data Completion                                                         |  |
|             |                 | 0x100C - 0x13FF | Unused                                                                       |  |
| SBDS        | 0x1400 - 0x17FF | 0x1400 - 0x147F | SBDS Registers                                                               |  |
|             |                 | 0x1480 - 0x17FF | Unused                                                                       |  |
| SBDI        | 0x1800 - 0x1BFF | 0x1800 - 0x1847 | Send BD Initiator                                                            |  |
|             |                 | 0x1848 - 0x1BFF | Unused                                                                       |  |
| SBDC        | 0x1C00 - 0x1FFF | 0x1C00 - 0x1C03 | Send BD Completion                                                           |  |
|             |                 | 0x1C04 - 0x1FFF | Unused                                                                       |  |
| RQP         | 0x2000 - 0x23FF | 0x2000 - 0x2258 | Receive List Placement                                                       |  |
|             |                 | 0x2259 - 0x23FF | Unused                                                                       |  |
| RDI         | 0x2400 – 0x27FF | 0x2400 - 0x24C3 | Receive Data Initiator                                                       |  |
|             |                 | 0x24C4 - 0x24FF | Unused                                                                       |  |
|             |                 | 0x2500 - 0x27FF | VRQ RCB Registers                                                            |  |
| RDC         | 0x2800 - 0x2BFF | 0x2800 - 0x2803 | Receive Data Completion                                                      |  |
|             |                 | 0x2804 - 0x2BFF | Unused                                                                       |  |
| RBDI        | 0x2C00 - 0x2FFF | 0x2C00 - 0x2C1B | Receive BD Initiator                                                         |  |
|             |                 | 0x2C1C - 0x2FFF | Unused                                                                       |  |
| RBDC        | 0x3000 - 0x33FF | 0x3000 - 0x300F | Receive BD Completion                                                        |  |
|             |                 | 0x3010 - 0x33FF | Unused                                                                       |  |
| CMPU        | 0x3400 – 0x37FF | 0x3400 – 0x35FF | Unused                                                                       |  |
|             |                 | 0x3600 - 0x3687 | Central Power Management Unit                                                |  |
| DBU         | 0x3800 – 0x3BFF | 0x3800 - 0x3817 | Debug Unit (UART)                                                            |  |
|             |                 | 0x3900 - 0x3907 | Chip Debug                                                                   |  |
|             |                 | 0x3908 - 0x3BFF | Unused                                                                       |  |
| HC          | 0x3C00 - 0x3FFF | 0x3C00 - 0x3CC3 | Host Coalescing                                                              |  |
|             |                 | 0x3CC4 - 0x3FFF | MultiQueue HC                                                                |  |
| MA          | 0x4000 - 0x43FF | 0x4000 – 0x400F | Memory Arbiter                                                               |  |
|             |                 | 0x4010 - 0x43FF | Unused                                                                       |  |
| ВМ          | 0x4400 - 0x47FF | 0x4400 - 0x445B | Buffer manager                                                               |  |
|             |                 | 0x445C - 0x47FF | Unused                                                                       |  |

| Block Name          | Block Range               | Sub-Block Range | Description                                               |
|---------------------|---------------------------|-----------------|-----------------------------------------------------------|
| DMAR                | 0x4800 – 0x4BFF           | 0x4800 - 0x4910 | DMAR LSO channel                                          |
|                     |                           | 0x4A00 - 0x4AFF | DMAR BD channel                                           |
|                     |                           | 0x4B00 - 0x4BFF | DMAR non-LSO channels                                     |
| DMAW                | 0x4C00 -0x4FFF            | 0x4C00 - 0x4C07 | DMA Write                                                 |
|                     |                           | 0x4C08 - 0x4FFF | Unused                                                    |
| RX-CPU              | 0x5000 - 0x53FF           | 0x5000 - 0x5037 | RX CPU                                                    |
|                     |                           | 0x5038 - 0x53FF | Unused                                                    |
| VRQ Filter-EMAC     | 0x5400 - 0x57FF           | 0x5400 - 0x55FF | VRQ Filter Set                                            |
|                     |                           | 0x5600 - 0x568F | VRQ Mapper                                                |
|                     |                           | 0x5690 - 0x572F | VRQ Perfect Match Registers                               |
|                     |                           | 0x5730 – 0x57FF | Unused                                                    |
| MB                  | 0x5800 - 0x5BFF           | 0x5800 - 0x5903 | Low Priority Mail Box                                     |
|                     |                           | 0x5903 - 0x5BFF | Unused                                                    |
| FTQ                 | 0x5C00 - 0x5FFF           | 0x5C00 - 0x5CFF | Flow Through Queue                                        |
|                     |                           | 0x5D00 – 0x5FFF | Unused                                                    |
| MSI                 | 0x6000 – 0x63FF           | 0x6000 - 0x6007 | Message Signaled Interrupt                                |
|                     |                           | 0x6008 - 0x63FF | Unused                                                    |
| CFG Port            | 0x6400 - 0x67FF           | 0x6400 - 0x67FF | PCIe Core Private Registers Access to Configuration Space |
| GRC                 | 0x6800 – 0x6BFF           | 0x6800 - 0x681B | Misc Host Control                                         |
|                     |                           | 0x6834 - 0x6843 | SEEPROM                                                   |
|                     |                           | 0x6890 - 0x68A8 | Misc Control                                              |
|                     |                           | 0x68B4 - 0x68EF | E Switch                                                  |
| ASF                 | 0x6C00 - 0x6FFF           | 0x6C00 - 6C37   | ASF & SMBUS                                               |
|                     |                           | 0x6C38 - 0x6FFF | Unused                                                    |
| NVM                 | 0x7000 – 0x73FF           | 0x7000 – 0x703B | Non Volatile memory (Flash Controller)                    |
|                     |                           | 0x703C - 0x73FF | Unused                                                    |
| UART                | 0x7800 – 0x7BFF           | 0x7800 – 0x781F | Debug UART Modem                                          |
|                     |                           | 0x7820 - 0x7BFF | Unused                                                    |
| TL-DL-PL Port       | 0x7C00 - 0x7FFF           | 0x7C00 – 0x7FFF | PCIe Core Private Register Access to TL, DL & PL          |
| The registers below | are outside Host Standard | View.           |                                                           |
| APE                 | 0x10000 - 0x18FFF         | _               | APE Access                                                |
| MF                  | 0x19000 - 0x193FF         | _               | Management Filters                                        |

# **Revision History**

### 571X-5720-PG101; October 18, 2023

■ Jumbo Frames – Added footnote on MTU size.

### 571X-5720-PG100; October 13, 2022

Updated the document number and title.

# 5718-PG108; January 29, 2016

#### **Updated:**

- "Other Considerations Relating to Producer Ring Setup" on page 90
- "RCB Setup Pseudo Code" on page 91
- "Summary of Register Settings to Support Jumbo Frames" on page 129
- "Receive MTU Size Register (offset: 0x43C)" on page 316
- "BM Hardware Diagnostic 2 Register (offset: 0x4450)" on page 431

# 5718-PG107; July 17, 2013

#### **Updated:**

- "Send Rings" on page 106
- "Initialization Procedure" on page 140
- Table 49: "GPIO Usage for Power Management for Broadcom Drivers," on page 192
- Table 101: "Multiple Send Ring Mail Boxes," on page 357
- "Send BD Ring Host Producer Index Register (offset: 0x5900)" on page 465
- "Send BD Ring NIC Producer Index Register (offset: 0x5980)" on page 466
- Table 121: "GbE Port Internal PHY Register Map," on page 553
- Table 127: "AUTONEG LINK PARTNER ABILITY," on page 559

# 5718-PG106; June 25, 2012

#### **Updated:**

- "Base Address Register 1 (offset: 0x10)" on page 275
- "Base Address Register 2 (offset: 0x14)" on page 275
- "Base Address Register 3 (offset: 0x18)" on page 275
- "Base Address Register 4 (offset: 0x1c)" on page 276
- "Mode Control Register (offset: 0x6800)" on page 475

#### Added:

- Section 8: "IEEE1588," on page 152
- "RX TIME STAMP LSB REG [Offset 0X06B0]" on page 163
- "RX TIME STAMP MSB REG [Offset 0x06B4]" on page 163
- "RX PTP SEQUENCE ID REG [Offset 0X06B8]" on page 163
- "RX LOCK TIMER LSB REG [Offset 0x06C0]" on page 164

- "RX LOCK TIMER MSB REG [Offset 0x06C4]" on page 164
- "RX PTP CONTROL REG [Offset 0X06C8]" on page 164
- Section 12: "IO Virtualization (IOV)," on page 264
- "Perfect Match Destination Address Registers" on page 465
- "VRQ Filter Set Registers" on page 461
- "VRQ Mapper Registers" on page 462
- "Base Address Register 5 (offset: 0x20)" on page 276
- "Base Address Register 6 (offset: 0x24)" on page 277

### 5718-PG105; February 24, 2012

#### **Updated:**

- Table 3: "Family Revision Levels," on page 48
- Table 5: "Flag Fields for a Ring," on page 70
- Figure 24: "Ring Control Block," on page 118
- "Summary of Register Settings to Support Jumbo Frames" on page 126
- "Initialization Procedure" on page 136
- "Reading a PHY Register" on page 186
- "Writing a PHY Register" on page 187
- "Subsystem ID/Vendor ID Register (offset: 0x2C)" on page 251
- "DMA Read/Write Control Register (Offset: 0x6c)" on page 258
- "PCI State Register (offset: 0x70)" on page 259
- "Receive BD Standard Producer Ring Index Register (offset: 0x268-0x26f)" on page 281
- "Transmit MAC Status Register (offset: 0x460)" on page 296
- "Receive MAC Mode Register (offset: 0x468)" on page 297
- "Statistics Registers" on page 319
- "H2B Statistics Registers" on page 320
- "Receive Data and Receive BD Initiator Mode Register (offset: 0x2400)" on page 341
- "Link Speed 10 MB/No Link Power Mode Clock Policy Register (offset: 0x3604)" on page 356
- "Link Speed 100 MB Power Mode Clock Policy Register (offset: 0x3608)" on page 357
- "Link Aware Power Mode Clock Policy Register (offset: 0x3610)" on page 359
- "D0u Clock Policy Register (offset: 0x3614)" on page 360
- "Link Idle Power Mode Clock Policy Register (offset: 0x3618)" on page 360
- "APE CLK Policy Register (offset: 0x361C)" on page 361
- "APE Sleep State Clock Policy Register (offset: 0x3620)" on page 363
- "Clock Speed Override Policy Register (offset: 0x3624)" on page 364
- "Clock Status Register (offset: 0x3630)" on page 367
- "Padring Control Register (offset: 0x3668)" on page 376
- "Receive Coalescing Ticks Register (offset: 0x3C08)" on page 393
- "Send Coalescing Ticks Register (offset: 0x3C0C)" on page 394
- "Receive Max Coalesced BD Count Register (offset: 0x3C10)" on page 395
- "Send Max Coalesced BD Count Register (offset: 0x3C14)" on page 397
- "Status Block Host Address Register (offset: 0x3C38)" on page 400
- "Status Block Base Address Register (offset: 0x3C44)" on page 426
- "BM Hardware Diagnostic 2 Register (offset: 0x4450)" on page 436
- "LSO Read DMA Mode Register (offset: 0x4800)" on page 438

- "LSO Read DMA Reserved Control Register (offset: 0x4900)" on
- page 445
- "LSO Read DMA Flow Reserved Control Register (offset: 0x4904)" on
- page 446
- "LSO/Non-LSO/BD Read DMA Corruption Enable Control Register
- (offset: 0x4910)" on page 446
- "BD Read DMA Mode Register (Offset: 0x4A00)" on page 449
- "BD READ DMA Reserved Control Register (offset: 0x4A70)" on page 456
- "BD READ DMA Flow Reserved Control Register (offset: 0x4A74)" on page 457
- "BD READ DMA Corruption Enable Control Register (offset: 0x4A78)" on page 457
- "Non LSO Read DMA Mode Register (offset: 0x4B00)" on page 458
- "Non-LSO Read DMA Reserved Control Register (offset: 0x4B74)" on page 461
- "Non-LSO Read DMA Corruption Enable Control Register (offset: 0X4B7C)" on page 462
- "Write DMA Mode Register (offset: 0x4C00)" on page 464
- "Low Priority Mailboxes" on page 469
- "Interrupt Mailbox 0 Register (offset: 0x5800)" on page 469
- "Other Interrupt Mailbox Register (offset: 0x5808–0x5818)" on page 469
- "General Mailbox Registers 1-8 (offset: 0x5820–0x5824)" on page 469
- "Receive BD Standard Producer Ring Index Register (offset: 0x5868)" on page 470
- "Receive BD Return Ring 0 Consumer Index Register (offset: 0x5880-0x5887)" on page 470
- "Receive BD Return Ring 0 Consumer Index Register (offset: 0x5880-0x5887)" on page 470
- "Send BD Ring Consumer Index Register (offset: 0x5900)" on page 471
- "NVM Write Register (offset: 0x7008)" on page 497
- "NVM Address Register (offset: 0x700C)" on page 497
- "NVM Read Register (offset: 0x7010)" on page 498
- "NVM Config 1 Register (offset: 0x7014)" on page 498
- "NVM Access Register (offset: 0x7024)" on page 502
- "00h: MII Control Register" on page 513
- "03h: PHY Identifier LSB Register" on page 515
- "04h: Auto Negot Advertisement Register" on page 515
- "09h: 1000Base T Control Register" on page 518
- "10h: PHY Extended Control Register" on page 522
- "18h: Auxiliary Control Register (Shadow Register Selector = "000")" on page 526
- "18h: Miscellaneous Control Register (Shadow Register Selector =
- "111")" on page 533
- "1Ch: Cabletron LED Register (Shadow Register Selector = "00h")" on page 538
- "1Ch: Spare Control 4 Register (Shadow Register Selector = "0bh")" on page 547
- "1Ch: External SerDes Control Register (Shadow Register Selector ="14h")" on page 557
- "1Ch: SGMII Slave Register (Shadow Register Selector = "15h")" on page 559
- "1Ch: Misc 1000-X Control 2 Register (Shadow Register Selector = "16h")" on page 561
- "1Ch: Misc 1000-X Control Register (Shadow Register Selector = "17h")" on page 563
- "1Ch: Auto-Detect SGMII/GBIC Register (Shadow Register Selector ="18h")" on page 564
- "1Ch: Auto-Detect Medium Register (Shadow Register Selector = "1eh")" on page 572
- "1Ch: Mode Control Register (Shadow Register Selector = "1fh")" on page 573

#### Added:

- Table 1: "Register Access Methods," on page 46
- "Device Reset Procedure" on page 146
- "PHY Loopback Configuration" on page 205
- "PHY Configuration Auto-Negotiation (10/100/1000 Speed with Half and Full Duplex Support)" on page 206
- "MSI-X Capabilities Registers" on page 281
- "PCIe Capabilities Registers" on page 282
- "VRQ Flush Control Register (Offset: 0x2410)" on page 369
- "VRQ Flush Timer Register (offset: 0x2414)" on page 370
- "RDI B2HRX Hardware Debugging Register (offset: 0x2418)" on page 370
- "Receive BD Ring Initiator Local NIC Standard Receive BD Consumer Index (offset: 0x2474)" on page 373
- "B2HRX Byte-count Statistics Count (offset: 0x24D0)" on page 374
- "B2HRX Unicast Statistics Count (offset: 0x24D4)" on page 374
- "B2HRX Multicast Statistics Count (offset: 0x24D8)" on page 374
- "B2HRX Broadcast Statistics Count (offset: 0x24DC))" on page 374
- "B2HRX Drop Packet Count (offset: 0x24E0)" on page 374
- "B2HRX Drop Packet Byte Count (offset: 0x24E4)" on page 374
- "B2HRX APE Byte-count Statistics Count (offset: 0x24E8)" on page 375
- "B2HRX APE Unicast Statistics Count (offset: 0x24EC)" on page 375
- "B2HRX APE Multicast Statistics Count (offset: 0x24F0)" on page 375
- "B2HRX APE Broadcast Statistics Count (offset: 0x24F4)" on page 375
- "B2HRX APE Drop Packet Count (offset: 0x24F8)" on page 375
- "B2HRX APE Drop Packet Byte Count (offset: 0x24FC)" on page 375
- "Receive Max Coalesced BD Count During Interrupt Register (offset: 0x3C18)" on page 424
- "Send Max Coalesced BD Count During Interrupt Register (offset: 0x3C1C)" on page 425
- "NIC Mini Receive BD Consumer Index (offset: 0x3c58)" on page 428
- "Send BD Ring Producer Index Register (offset: 0x5980)" on page 471
- "DMA Completion Mode Register (Offset: 0x6400)" on page 477
- Figure 58: "Copper PHY Register Mapping Table," on page 511
- Figure 59: "SerDes PHY Register Map," on page 512
- "Clause 45 Registers" on page 601
- "SerDes PHY Register Definitions" on page 578
- "PHY 0x18 Shadow 0x1 register read Procedure" on page 527
- Added PHY 0x1C Shadow 0x1 register read Procedure information to
- "1Ch: Cabletron LED Register (Shadow Register Selector = "00h")" on page 538
- Added Clause 45 register Dev3 Reg803Eh read Procedure to "Clause 45 Register Dev 3 Reg14h (20d): EEE Capability Register" on page 601
- NIC Ring Addresses information to Memory map tables in Appendix C: "Device Register and Memory Map," on page 611

#### **Deleted:**

- Section 11: Host to/from BMC Pass Through
- Appendix D: Appendix
- Top Level MII Registers

### 5718-PG104; June 29, 2011

#### **Updated:**

- Table 27: "Flag Field Description," on page 113
- Table 31: "Send Buffer Descriptor Flags," on page 123
- "Clock Control" on page 191
- Table 47: "Ethernet Controller Power Pins," on page 191
- "Internal Memory" on page 214
- "ISR Flow" on page 230
- Table 82: "Interrupt-Related Registers," on page 235
- "Status Register (offset: 0x362C)" on page 391
- "Clock Status Register (offset: 0x3630)" on page 393
- "LSO Read DMA Mode Register (offset: 0x4800)" on page 438
- "NVM Write Register (offset: 0x7008)" on page 497

#### Added:

- "Device Closing Procedure" on page 147
- "TX TIME STAMP LSB REG (offset: 0x5C0)" on page 327
- "TX TIME STAMP MSB REG (offset: 0x5C4)" on page 327

# 5718-PG103; January 26, 2011

#### **Updated:**

- Added BCM5720 to Section 1: "Introduction," on page 49.
- Added BCM5720 to "Introduction" on page 49.
- Added Host to BMC to "Transmit MAC Mode Register (offset: 0x45C)" on page 317.
- Added Host to BMC to "Transmit MAC Lengths Register (offset: 0x464)" on page 319.
- Added Host to BMC to "Mode Control Register (offset: 0x6800)" on page 477.

#### Added:

- "HTX2B Perfect Match[1–4] HI Reg (offset: 0x4880, 0x4888, 0x4890, 0x4898)" on page 330.
- "HTX2B Perfect Match[1-4] LO Reg (offset: 0x4884, 0x488C, 0x4894, 0x489C)" on page 330.
- "HTX2B Protocol Filter Reg (offset: 0x6D0)" on page 331.
- "HTX2B Global Filter Reg (address: 0x6D4)" on page 333.
- "H2B Statistics Registers" on page 346.
- "HTX2B Statistics" on page 347
- "B2HRX Statistics" on page 347
- "RMU Registers" on page 504
- "RMU EGRESS DA1 MATCH[1-8] REG (offsets: 0x00B0, 0x00B8, 0x00C0, 0x00C8 ... 0xE8)" on page 504
- "RMU EGRESS DA2 MATCH[1-8] REG (Offsets 0x00B4, 0x00BC, 0x00C4, 0xCC ...0xEC)" on page 504
- "RMU\_EGRESS\_STATUS\_REG (Offset 0x0000)" on page 504

# 5718-PG102; November 12, 2010

#### **Updated:**

- Added BCM5719 to "Introduction" on page 39.
- Added BCM5719 to "Related Documents" on page 39.

- Added BCM5719 to Table 1: "BCM571X/BCM5720 Family Product Features," on page 40.
- Removed PHY core column and added BCM5717 B0, BCM5718 BO, and BCM5719 to Table 2: "Family Revision Levels," on page 42.
- Updated note in "Revision Levels" on page 42.
- Added Memory Arbiter to Figure 1: "Individual Port Functional Block Diagram," on page 45.
- Added BCM5719 to "Overview of Features" on page 46.
- Added note about BCM5719 to Figure 2: "High-Level System Functional Block Diagram," on page 47.
- Added max ring sizes to "Ring Control Block" on page 99.
- Added BCM5719 toTable 6: "Defined Flags for Send Buffer Descriptors," on page 67.
- Updated Host Ring Size to Table 7: "Receive Return Rings," on page 70.
- Corrected typo in Figure 26: "Send Driver Interface," on page 119.
- Corrected typo in Figure 27: "Receive Producer Interface," on page 120.
- Corrected typo in Figure 28: "Receive Return Interface," on page 121.
- Updated Step 36 in "Initialization Procedure" on page 137.
- Added BCM5719 to "Description" on page 168.
- Corrected typo in "PCI Classcode and Revision ID Register (offset: 0x08)—Function 0" on page 255
- Corrected typos in "Power Management Control/Status Register (offset: 0x4C) Function 0" on page 261
- Added note to Enable Endian Byte Swap in "Miscellaneous Host Control Register (offset: 0x68)" on page 264.
- Updated all Indirection Table register descriptions in "RSS Registers" on page 276.
- Added BCM5717 and BCM5718 values to "CPMU Control Register (offset: 0x3600)" on page 346.
- Added BCM5719 to "Link Aware Power Mode Clock Policy Register (offset: 0x3610)" on page 349.
- Added BCM5719 to "APE CLK Policy Register (offset: 0x361C)" on page 352.
- Added BCM5719 to "Introduction" on page 39.
- Added BCM5719 to "Related Documents" on page 39.
- Added BCM5719 to Table 1: "BCM571X/BCM5720 Product Features," on page 40.
- Removed PHY core column and added BCM5717 B0, BCM5718 BO, and BCM5719 to Table 2: "Family Revision Levels," on page 42.
- Updated note in "Revision Levels" on page 42.
- Added Memory Arbiter to Figure 1: "Individual Port Functional Block Diagram," on page 45.
- Added BCM5719 to "Overview of Features" on page 46.
- Added note about BCM5719 to Figure 2: "High-Level System Functional Block Diagram," on page 47.
- Added max ring sizes to "Ring Control Block" on page 99.
- Added BCM5719 toTable 6: "Defined Flags for Send Buffer Descriptors," on page 67.
- Updated Host Ring Size to Table 7: "Receive Return Rings," on page 70.
- Corrected typo in Figure 26: "Send Driver Interface," on page 119.
- Corrected typo in Figure 27: "Receive Producer Interface," on page 120.
- Corrected typo in Figure 28: "Receive Return Interface," on page 121.
- Updated Step 36 in "Initialization Procedure" on page 137.
- Added BCM5719 to "Description" on page 168.
- Corrected typo in "PCI Classcode and Revision ID Register (offset: 0x08)—Function 0" on page 255
- Corrected typos in "Power Management Control/Status Register (offset: 0x4C) Function 0" on page 261
- Added note to Enable Endian Byte Swap in "Miscellaneous Host Control Register (offset: 0x68)" on page 264.
- Updated all Indirection Table register descriptions in "RSS Registers" onpage 276.
- Added BCM5717 and BCM5718 values to "CPMU Control Register (offset: 0x3600)" on page 346.
- Added BCM5719 to "Link Aware Power Mode Clock Policy Register (offset: 0x3610)" on page 349.
- Added BCM5719 to "APE CLK Policy Register (offset: 0x361C)" on page 352.

#### Added:

- "Receive BD Standard Producer Ring Index (High Priority Mailbox) Register (offset: 0x268-0x26f)" on page 276
- "TX Time Stamp LSB Reg (offset: 0x5C0)" on page 282
- "TX Time Stamp MSB Reg (offset: 0x5C4)" on page 283
- "RX Time Stamp LSB Reg (offset 0x06B0)" on page 308
- "RX Time Stamp MSB Reg (offset 0x06B4)" on page 308
- "RX PTP Sequence ID Reg (offset 0x06B8)" on page 308
- "RX Lock Timer LSB Reg (offset 0x6C0)" on page 309
- "RX Lock Timer MSB Reg (offset 0x06C4)" on page 309
- "RX PTP Control Reg (offset: 0x6C8)" on page 310
- "Clock Speed Override Policy Register (offset: 0x3624)" on page 355
- "Clock Status Register (offset: 0x3630)" on page 358
- "Global Mutex Request Register (offset: 0x36F0)" on page 381
- "Global Mutex Grant Register (offset: 0x36F4)" on page 381
- "Temperature Monitor Control Register (offset: 0x36FC)" on page 382
- "BCM5719 Registers" on page 469

#### Removed:

"Reserved (offset: 0x378C)"

# 5718-PG101; April 13, 2010

#### **Updated:**

- Table 1: "BCM571X/BCM5720 Product Features," on page 40
- IP cksum description in "Receive Buffer Descriptors" on page 70
- "Extended RX Buffer Descriptor (BD)" on page 110
- Table title for Table 34: "Jumbo Producer Ring Host Address Low
- Register (offset: 0x2444)," on page 123
- Default value and description in Table 36: "Jumbo Producer Ring NIC
- Address Register (offset: 0x244C)," on page 123
- NIC ring address values in Table 45: "NIC Ring Addresses," on page 126
- PCI version in "Description" on page 148
- "EMAC Status Register (offset: 0x404)" on page 279
- "DMA Flag Register for TCP Segmentation (offset: 0xCEC)" on page 321
- "Jumbo Producer Ring NIC Address Register (offset: 0x244C)" on page 337
- "Receive Producer Length/Flags Register (offset: 0x2458)" on page 337
- "Receive Producer Ring NIC Address Register (offset: 0x245C)" on page 338
- "GPHY Strap Register (offset: 0x3664)" on page 366
- "Read DMA Mode Register (offset: 0x4800)" on page 398
- "BCM571X/BCM5720 MII Bus PHY Addressing" on page 496

#### Added:

- Section 8: "Device Control," on page 137
- Registers 0x00 to 0x3c and 0x48 to 0x64 to "PCI Configuration Registers" on page 254
- Section 14: "Transceiver Registers," on page 496

#### Removed:

- References to BCM5724 throughout
- Column from Table 1: "BCM571X/BCM5720 Family Product Features," on page 40
- Register control mode from "MDI Register Access" on page 187
- MDI Control Register (offset: 0x6844)

# 5718-PG100; April 13, 2010

Initial release

