Introduction

The Serial Gigabit Media Independent Interface (SGMII) is a connection bus for Ethernet MACs and PHYs defined by Cisco Systems. It replaces the classic 22-wire GMII connection with a low pin count, 4-pair, differential SGMII connection. The classic GMII interface defined in the IEEE 802.3 specification is strictly for gigabit rate operation. However, the Cisco SGMII specification defines a method for operating 10Mbps, 100Mbps and 1000Mbps over the interface. Moreover, the Cisco SGMII specification is comprised of more than just a bus interface definition; it defines a bridging function between SGMII and GMII buses.

The transmit and receive data paths leverage the 1000BASE-SX PCS defined in the IEEE 802.3z specification (clause 36). Control information, as specified in Table 1, is transferred from the PHY to the MAC to signal the change of the control information. This is achieved by using the Auto-Negotiation functionality defined in Clause 37 of the IEEE Specification 802.3z. Instead of the ability advertisement, the PHY sends the control information via its tx_config_Reg[15:0], as specified in Table 1, whenever the control information changes. Upon receiving control information, the MAC acknowledges the update of the control information by asserting bit 14 of its tx_config_Reg[15:0] as specified in Table 1.

This document provides a report on the SGMII Physical Layer interoperability tests between a LatticeECP2M™ device and the Marvell 88E1111/88E1112 devices. Specifically, this technical note discusses the following topics:

- Overview of LatticeECP2M devices and Marvell Alaska Ultra 88E1111/88E1112 devices.

Table 1. Definition of Control Information Passed Between Links via tx_config_Reg[15:0]

<table>
<thead>
<tr>
<th>Bit Number</th>
<th>tx_config_Reg[15:0] Sent from the PHY to the MAC</th>
<th>tx_config_Reg[15:0] Sent from the MAC to the PHY</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Link: 1 = link up, 0 = link down</td>
<td>0: Reserved for future use</td>
</tr>
<tr>
<td>14</td>
<td>Reserved for Auto-Negotiation acknowledge as specified in 802.3z</td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td>0: Reserved for future use</td>
<td>0: Reserved for future use</td>
</tr>
<tr>
<td>12</td>
<td>Duplex mode: 1 = full duplex, 0 = half duplex</td>
<td>0: Reserved for future use</td>
</tr>
<tr>
<td>11-10</td>
<td>Speed: Bit 11, 10: 11 = Reserved 10 = 1000 Mbps: 1000BASE-TX, 1000BASE-X 01 = 100 Mbps: 100BASE-TX, 100BASE-FX 00 = 10 Mbps: 10BASET, 10BASE2, 10BASES</td>
<td>0: Reserved for future use</td>
</tr>
<tr>
<td>9:1</td>
<td>0: Reserved for future use</td>
<td>0: Reserved for future use</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

LatticeECP2M/PCS Overview

LatticeECP2M Features

The LatticeECP2/M family of FPGA devices has been optimized to deliver high performance features such as advanced DSP blocks, high speed SERDES (LatticeECP2M family only) and high speed source synchronous interfaces in an economical FPGA fabric. This combination was achieved through advances in device architecture and the use of 90nm technology.
The LatticeECP2/M FPGA fabric was optimized for the new technology from the outset with high performance and low cost in mind. LatticeECP2/M devices include LUT-based logic, distributed and embedded memory, Phase Locked Loops (PLLs), Delay Locked Loops (DLLs), pre-engineered source synchronous I/O support, enhanced sysDSP™ blocks and advanced configuration support, including encryption and dual-boot capabilities.

The LatticeECP2M family of devices features high speed SERDES with PCS. These high jitter tolerance and low transmission jitter SERDES with PCS blocks can be configured to support an array of popular data protocols including PCI Express, Ethernet (1GbE and SGMII), OBAI and CPRI. Transmit Pre-emphasis and Receive Equalization settings make SERDES suitable for chip-to-chip and small form factor backplane applications.

The ispLEVER® design tool from Lattice allows large complex designs to be efficiently implemented using the LatticeECP2/M family of FPGA devices.

**LatticeECP2M SGMII Solution**

The LatticeECP2M achieves SGMII compliance by combining both a PCS block and SGMII soft IP in FPGA logic. The LatticeECP2M SGMII solution has the following features:

- Word Alignment based on IEEE 802.3-2002 defined alignment characters (PCS)
- 8b/10b Encoding/Decoding (PCS)
- Link State Machine functions compliant with the IEEE 802.3-2002 specification (PCS)
- Conforms to the Cisco SGMII Specification, Revision 1.7
- 4-bit or 8-bit (G)MII Interface operating at 10Mbs, 100Mbs, or 1Gbps
- Pin selectable MAC/PHY mode for auto negotiation
- Management registers access through serial or parallel control interface
- 2-wire, CML differential SGMII Interface operating at 1.25Gbps (PCS)
- Transmit SGMII clock embedded in data stream (no external SGMII transmit clock) (PCS)
- Receive SGMII clock recovered from data stream (no external SGMII receive clock) (PCS)

Figure 1 illustrates the LatticeECP2M SGMII solution.

*Figure 1. LatticeECP2M SGMII Solution*
Marvell Alaska Ultra 88E1111/88E1112 Overview

88E1111/88E1112 Features

The Alaska Ultra 88E1111/88E1112 Gigabit Ethernet Transceivers are physical layer devices for Ethernet 1000BASE-T, 100BASE-TX, and 10BASE-T applications. They contain all the active circuitry required to implement the physical layer functions to transmit and receive data on standard CAT 3 and CAT 5 unshielded twisted pairs.

The 88E1111/88E1112 devices support the Gigabit Media Independent Interface (GMII), Reduced GMII (RGMII), Serial GMII (SGMII), the Ten-Bit Interface (TBI), and Reduced TBI (RTBI) for direct connection to a MAC/Switch port.

The 88E1111/88E1112 devices incorporate a 1.25GHz SERDES, which may be directly connected to a fiber-optic transceiver for 1000BASE-T/1000BASE-X media conversion applications. Additionally, the 88E1111/88E1112 devices may be used to implement 1000BASE-T Gigabit Interface Converter (GBIC) or Small Form Factor Pluggable (SFP) modules.

The 88E1111/88E1112 devices use advanced mixed-signal processing to perform equalization, echo and crosstalk cancellation, data recovery, and error correction at a gigabit per second data rate. The devices achieve robust performance in noisy environments with very low power dissipation.

The Alaska Ultra 88E1111/88E1112 features include:

- 10/100/100BASE-T IEEE 802.3 compliant
- Support for GMII, TBI, RGMII, RTBI, and SGMII
- Integrated 1.25GHz SERDES for 1000BASE-X fiber applications
- The 88E1112 device also supports 100BASE-FX
- Four RGMII timing modes
- Three energy detect modes as well as a low power COMA mode
- Three loopback modes for diagnostics
- Fully integrated digital adaptive equalizers, echo cancellers, and crosstalk cancellers
- Advanced digital baseline wander correction
- Automatic polarity correction
- IEEE 802.3u compliant Auto-Negotiation
- CRC checker, packet counter
- Automatic detection of fiber or copper media
- Virtual Cable Tester (VCT)
- Selectable MDC/MDIO interface or Two-Wire Serial Interface.

Test Equipment

Below is the equipment used in the interoperability tests.

Spirent SmartBits 2000 Protocol Analyzer

Spirent Communications’ SmartBits 2000 (SMB-2000) has become the industry standard for measuring the performance limits of everything from an emerging technology in a development lab to the largest enterprise network. The SMB-2000 is widely used to test a variety of network devices and complex network configurations, including 10/100 Mbps Ethernet, Gigabit Ethernet, ATM, and Frame Relay.
Figure 2 illustrates the SMB-2000 analyzer with a 1000BASE-T copper module (GX-1420B, rightmost module with RJ45 cable attached).

Figure 3 illustrates the GUI command console for the SMB-2000. The GX-1420B module is also shown to the right of the screen.

**Figure 2. SmartBits 2000 Protocol Analyzer with 1000BASE-T Module**

**Figure 3. SmartBits 2000 GUI Controls**

**Marvell 88E1112 64 QFN Evaluation Board**

The Marvell 88E1112 64 QFN evaluation board includes:

- An 88E1111 device
- An 88E1112 device
- On-board oscillator clock sources
- MDIO/MDC monitoring/control to both devices
- An SGMII interface between the 88E1111 and the 88E1112
- An RJ45 connector for MDI access to the 88E1111
- Two Transmit SMAs and two Receive SMAs for access to the 88E1112 SERDES

Figure 4 shows the 88E1112 64 QFN evaluation board.
Marvell ALASKA Virtual Cable Tester Software

The ALASKA Virtual Cable Tester Software GUI controls the 88E1111/88E1112 parts and monitor status bits. Figure 5 shows the VCT GUI. The GUI is mainly used for 1000-BASE-T or 1000BASE-X modes.

In SGMII mode, the PHY Register Control Panel is used instead to control and monitor the 88E1112 registers. Figure 6 illustrates the Phy Register Control Panel.

Figure 5. ALASKA Virtual Cable Tester Software GUI
Agilent 81130A Pulse/Data Generator

The Agilent 81130A pulse/data generator was used to supply an external 125MHz reference clock source to the LatticeECP2M PCS.

For more information on this module, please refer to Agilent's website: www.agilent.com.

LatticeECP2M SERDES Evaluation Board

The LatticeECP2M SERDES Evaluation Board features the LatticeECP2M LFE2M35-FF672 FPGA device. The stand-alone evaluation board provides a functional platform for development and rapid prototyping of applications that require high-speed SERDES interfaces to PCI Express protocols.

The LatticeECP2M SERDES Evaluation Board includes provisioning to connect four high-speed SERDES channels via SMA connectors to test and measurement equipment. This interface is used to demonstrate XAUI type applications. The board is manufactured using standard FR4 dielectric and through-hole vias. The nominal impedance is 50-ohm for single-ended traces and 100-ohm for differential traces. The board has several debugging and analyzing features for complete customer evaluations of the LatticeECP2M device.

The board features:

- Four SERDES high-speed channels interfaced to SMA test points and clock connections SERDES interface to x1 PCI Express edge fingers
- DDR2 memory device
- SFP Transceiver cage and associated interface
- SATA-like connections to SERDES channels
- Power connections and power sources
- ispVM® programming support
LatticeECP2M/Marvell Serial-GMII (SGMII)  
Physical Layer Interoperability

- On-board and external reference clock sources
  - Interchangeable clock oscillators
  - On-board reference clock management using Lattice ispClock™ devices
- ORCAstra Demonstration Software interface via standard ispVM JTAG connection
- Various high-speed layout structures

Figure 7 shows the LatticeECP2M SERDES Evaluation Board.

**Figure 7. LatticeECP2M SERDES Evaluation Board**

**ispVM System**

The ispVM System is included with Lattice’s ispLEVER software, and is also available as a stand-alone device programming manager. The ispVM System is a comprehensive design download package that provides an efficient method of programming ISP™ devices using JEDEC and Bitstream files generated by design tools from Lattice and other vendors. This complete device programming tool allows the user to quickly and easily download designs through an ispSTREAM to devices and includes features that facilitate ispATE™, ispTEST, and ispSVF programming as well as gang-programming with DLxConnect.

ispVM System is used in this interoperability test to download the LatticeECP2M bitstream to configure the FPGA in SGMII mode.

Figure 8 shows a screen shot of the ispVM System.
The Lattice ORCAstra software is a PC-based graphical user interface that allows the user to configure the operational mode of an FPGA or FPSC by programming control bits in the on-chip registers. This helps users quickly explore configuration options without going through a lengthy re-compile process or making changes to their board.

Configurations created in the GUI can be saved to memory and re-loaded for later use. A macro capability is also available to support script-based configuration and testing. The GUI can also be used to display system status information in real time. Use of the ORCAstra software does not interfere with the programming of the FPGA portion of the FPSC.

Figure 9 is a screen shot of the ORCAstra system.
Interoperability Testing

This section provides details on SGMII Physical Layer interoperability tests between the LatticeECP2M device and the Marvell 88E1111/88E1112 devices. The purpose of these tests is to confirm the correct processing of 1000BASE-T copper protocol from the SMB-2000, through the 88E1111/88E1112 devices, and ending at the LatticeECP2M (G)MII interface, and then back in the other direction. Particularly, the tests verify:

- The ability to auto negotiate successfully
- The ability to transfer packets across the system asynchronously

Test Setup

Figure 10 shows the board connections of the test setup.

Figure 11 is a block diagram of the test setup.

The setup includes:

- A Spirent SMB-2000 with a GX-1420B module
- The Marvell 88E1112 Evaluation Board (with the 88E1111/88E1112 devices)
- The LatticeECP2M SERDES Evaluation Board
- A PC for software control/monitoring
- The Agilent 811130A Data/Pulse Generator to provide an external 125MHZ reference clock to the LatticeECP2M PCS
Test Description
The following describes how the SGMII Physical Layer Interoperability is achieved.

SMB-2000
The GX-1420B module generates and checks full protocol compliant Gigabit Ethernet packets. The setup is as follows:
• Random source/destination addresses
• Random payload content
• Random payload length
• 0.096µs IPG GAP.

Figure 12 illustrates the SMB-2000 counter window used to keep track of transmission and reception statistics.

The SMB-2000 connects to the Marvell 88E1112/88E1118 EVAL Board via an RJ45 cable. It transmits the Gigabit Ethernet packets to the 88E1111 device in the TX direction, and checks them back from the 88E1111 device in the RX direction.

*Figure 12. SMB-2000 Counter Window*

Marvell 88E1112/88E111 Evaluation Board
In one direction, the 88E1111 device receives 1000BASE-T packets from the SMB-2000 and sends it to the 88E1112 device via its SGMII interface. In the other direction, the opposite flow of data occurs.

In one direction, the 88E1112 part receives SGMII packets from the 88E1111 and sends it to the LatticeECP2M board via SMAs on its SGMII interface. In the other direction, the opposite flow of data occurs.

Note that because the 88E1112 is configured as an SGMII MAC device, the LatticeECP2M SGMII IP is programmed as a PHY device via register settings.

LatticeECP2M SERDES Evaluation Board
In the RX direction, The LatticeECP2M PCS recovers SGMII packets from the 88E1112 device and the SGMII IP converts them into (G)MII format.

The (G)MII loopback logic in the FPGA portion loops the (G)MII data back into the TX direction. The LatticeECP2M device then transmits the SGMII packets back to the 88E1112 device. The LatticeECP2M SGMII IP is programmed as an SGMII PHY device.

Results
Correct auto negotiation was verified by monitoring both the LatticeECP2M SGMII solution status signals and registers and the Marvell PHY Register Panel (see Figure 6). The tx_config_Reg[15:0] content transmitted from the SGMII PHY (LatticeECP2M) to the SGMII MAC (88E1112) was also read back at register 5 of page 1 (see Figure 6). The content of that register was hD801. According to Table 1, this corresponds to the following LatticeECP2M SGMII PHY information:
• Link is up
• Auto-negotiation acknowledgement
• Full Duplex operation
• Advertised speed of 1000Mbps at the (G)MII interface

The Smartbits SMB-2000 GX-1420B counter window (as shown in Figure 12) was monitored for error-free packet transmission and reception. Additionally, the Lattice ORCAstra System GUI was also monitored for proper link synchronization. The setup ran for over one hour, during which just over 657 million packets were transmitted/received error-free (see Figure 12).

Summary
In conclusion, the LatticeECP2M FPGA family offers users SGMII Physical Layer support and is fully inter-operable with Marvell 88E1111/88E1112 devices.

Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>November 2006</td>
<td>01.0</td>
<td>Initial release.</td>
</tr>
<tr>
<td>February 2012</td>
<td>01.1</td>
<td>Updated document with new corporate logo.</td>
</tr>
</tbody>
</table>

Technical Support Assistance
Hotline: 1-800-LATTICE (North America)
+1-503-268-8001 (Outside North America)
e-mail: techsupport@latticesemi.com
Internet: www.latticesemi.com