# SGMII Core

# SGMII

This document describes interfaces and design of SGMII Core

11/10/2012

#### **1. OVERVIEW**

This core implements Physical Coding Sublayer of 1000BaseX transmission (IEEE 802.3 Clause36 and 37). This core can also be used for SGMII interface as this interface leverages 1000BaseX PCS. The differences between the 2 protocols are Link-timer and the control information exchanged during Auto-negotiation process.

Modes of operation:

- 1000BaseX mode. This is the default mode of the core. In this mode, local capability register needs be set so that the core can advertise the capability of local link.
- Mac-SGMII mode: in this mode, the core works in SGMII mode at MAC side. The core only transmits acknowledgement bit during negotiation process, the other bits are set to "0" as specified by Cisco. The operating speed/duplex is set by:
  - Received partner speed/duplex (default)
  - Or Bit 6,13, and 8 in control register. To force the core into this speed, Use\_Local bit in Mode register must be set.
- Phy-SGMII mode: in this mode, the core works in SGMII mode at Phy-Side. That means the core would actively advertise control information which can be set by external ports (i\_PhyDuplex, i2\_PhySpeed, i\_PhyLink) or via *Local Capability registers*. The actual operating speed and duplex are controlled by the external ports or *Control Registers*.

## **2. INTERFACE**

| Tranceiver Interface                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| input i_SerRx,<br>output o_SerTx,<br>input i_CalClk,<br>input i_RefClk125M,<br>input i_ARstHardware_L,                                                                      | <ul> <li>This interface requires 125MHz reference clock<br/>and 50MHz Calibration Clock to feed to<br/>Transceiver.</li> <li>o_SerTx and i_SerRx are Transmit and Receive<br/>line of the transceiver.</li> <li>i_ArstHardware_L is to be connected to<br/>hardware reset line.</li> </ul>                                                   |
| Wishbonebus, single transaction mode (non-<br>pipeline slave)                                                                                                               |                                                                                                                                                                                                                                                                                                                                              |
| input i_Cyc,<br>input i_Stb,<br>input i_WEn,<br>input [31:00] i32_WrData,<br>input [07:00] iv_Addr,<br>output [31:00] o32_RdData,<br>output o_Ack,                          | This wishbone interface is to configures registers<br>such as mode, link-timer or speed                                                                                                                                                                                                                                                      |
| input i_Mdc,<br>inout io_Mdio,                                                                                                                                              | Mdio clause 22 interface, not supported yet                                                                                                                                                                                                                                                                                                  |
| Link Status                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                              |
| output o_Linkup,<br>output o_ANDone,<br>output [1:0] o2_SGMIISpeed,<br>output o_SGMIIDuplex,                                                                                | <ul> <li>Link-up is asserted after the synchronization is acquired.</li> <li>AN_Done is asserted after auto-negotiation process is done.</li> <li>SGMIISpeed encodes speed of SGMII mode: 10b: 1000Mbps</li> <li>01b: 100Mbps</li> <li>00b: 10Mbps (not supported)</li> <li>SGMIIDuplex, this core only support full duplex mode.</li> </ul> |
| SGMII Phy-Side Signals                                                                                                                                                      | Phy-Side SGMII advertised information                                                                                                                                                                                                                                                                                                        |
| input i_PhyLink,<br>input i_PhyDuplex,<br>input [1:0] i2_PhySpeed,                                                                                                          | PhyLink bit is tied to Bit.15 of Advertised<br>Configurations to indicate copper-link is up or<br>down. PhyDuplex and PhySpeed are tied to bit<br>12,11:10 of advertised 16-bit information                                                                                                                                                  |
| GMII Interface                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                              |
| input [07:00] i8_TxD,<br>input i_TxEN,<br>input i_TxER,<br>output [07:00] o8_RxD,<br>output o_RxDV,<br>output o_RxER,<br>output o_GMIIClk,<br>output o_Col,<br>output o_Crs | Standard GMII interface<br>GMIIClk output 125MHz clock output by the<br>tranceiver.<br>MIIClk output 25MHz clock used in 100Mbps<br>mode.                                                                                                                                                                                                    |

#### **2.1. REGISTERS**

The registers in the cores are accessed through 32-bit bus. Therefore registers are mapped into Double-word address although each register is only 16-bit. The 16 most significant bits are always zeros.

| Bit   | Name      | Offset | Default | Description                                                |  |
|-------|-----------|--------|---------|------------------------------------------------------------|--|
|       | Control   | 0x00   |         |                                                            |  |
|       | Register  |        |         |                                                            |  |
| 5:0   | Reserved  | R/W    | 5'b0    | Not used                                                   |  |
| 6     | MSB Speed | R/W    | 0       | From Table 22-7 (IEEE 802.3-2008-Section2)                 |  |
|       | Selection |        |         | 0.6 0.13                                                   |  |
|       |           |        |         | 1 1 = Reserved                                             |  |
|       |           |        |         | 1 	 0 = 1000 	 Mb/s                                        |  |
|       |           |        |         | $0 	 1 = 100 	ext{ Mb/s}$                                  |  |
|       |           |        |         | $0 	 0 = 10 	ext{ Mb/s}$                                   |  |
|       |           |        |         | This bit is used only inSGMII mode. The speed of SGMII     |  |
|       |           |        |         | mode can be configured to use these 2 bits or use link     |  |
| _     |           |        |         | partner advertised speed and duplex.                       |  |
| 7     | Collision | R/W    | 1'b0    | Not support                                                |  |
|       | Test      |        |         |                                                            |  |
| 8     | Duplex    | R/W    |         | Only full duplex mode is supported, this bit has no effect |  |
| 0     | Mode      | DAV    | 1.11.0  |                                                            |  |
| 9     | Auto-nego | R/W    | 1'b0    | Restart autonegotiation process. This bit is self cleared. |  |
| 10    | Restart   | SC     | 1210    |                                                            |  |
| 10    | Isolate   | R/W    | 1'b0    | Not supported                                              |  |
| 11    | PowerDown | R/W    | 1'b0    | To power down the tranceiver, this bit goes directly to    |  |
|       |           |        |         | powerdown pin of transceiver. Use with care. This feature  |  |
| 10    |           |        | 1.11.0  | has not been tested yet.                                   |  |
| 12    | ANEnable  | R/W    | 1'b0    | Enable auto negotiation                                    |  |
| 13    | LSB Speed | R/W    | 1'b0    | LSB of speed control                                       |  |
|       | Selection |        |         |                                                            |  |
| 14    | Loopback  | R/W    | 1'b0    | Enable/Disable Loopback mode (not tested)                  |  |
| 15    | Reset     | R/W/SC | 1'b0    | Write '1' to Soft-Reset the whole module                   |  |
| 31:16 | Reserved  | RO     |         | Zeros                                                      |  |

| Bit  | Name        | Offset | Default | Description                                 |
|------|-------------|--------|---------|---------------------------------------------|
|      | Status      | 0x04   |         |                                             |
|      | Register    |        |         |                                             |
| 1:0  |             | RO     | 2'b00   |                                             |
| 2    | Sync Status | RO     | 1'b0    | Status of Synchronization process           |
|      |             |        |         | 1: Synchronization has been done.           |
|      |             |        |         | 0: Rx can't sync to the incoming bit stream |
| 4:3  |             | RO     | 2'b00   | 2'b01                                       |
| 5    | AN          | RO     | 1'b0    | Autonegotiation is done                     |
|      | complete    |        |         |                                             |
| 31:6 |             | RO     | 26'h0   | Zeros                                       |

| Bit               | Name                                                              | Offset | Default | Descripti                                                                                                                                    | on                                                                                                    |                                                                                  |                                                                       |                                               |
|-------------------|-------------------------------------------------------------------|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------|
|                   | Local                                                             | 0x10   |         | This regi                                                                                                                                    | ster se                                                                                               | ets the                                                                          | advertised capability of                                              | local link.                                   |
|                   | Advertised                                                        |        |         | Some bits are used in 1000BaseX, some are used in SGMI                                                                                       |                                                                                                       | used in SGMII                                                                    |                                                                       |                                               |
|                   | Ability                                                           |        |         | Mode, some are used in both.                                                                                                                 |                                                                                                       |                                                                                  |                                                                       |                                               |
|                   |                                                                   |        |         | 1000Base                                                                                                                                     | eX m                                                                                                  | ode                                                                              |                                                                       |                                               |
| 4:0               |                                                                   |        |         |                                                                                                                                              |                                                                                                       |                                                                                  |                                                                       |                                               |
| 6:5               |                                                                   |        |         | Only sup                                                                                                                                     | ports                                                                                                 | Full D                                                                           | uplex mode                                                            |                                               |
| 7                 |                                                                   |        |         | Pause                                                                                                                                        | •                                                                                                     |                                                                                  | •                                                                     |                                               |
| 8                 |                                                                   |        |         | Asymetri                                                                                                                                     |                                                                                                       | Table 37-2                                                                       | -Pause encoding                                                       |                                               |
|                   |                                                                   |        |         | PAUSE (D?                                                                                                                                    | ) A83                                                                                                 | I_DIR(D8)                                                                        | Capability                                                            |                                               |
|                   |                                                                   |        |         | 0                                                                                                                                            |                                                                                                       | 0                                                                                | No PAUSE                                                              |                                               |
|                   |                                                                   |        |         | 0                                                                                                                                            |                                                                                                       | 1                                                                                | Asymmetric PAUSE toward link partner                                  |                                               |
|                   |                                                                   |        |         | 1                                                                                                                                            |                                                                                                       | 0                                                                                | Symmetric PAUSE                                                       |                                               |
|                   |                                                                   |        |         | 1                                                                                                                                            |                                                                                                       | 1                                                                                | Both Symmetric PAUSE and<br>Asymmetric PAUSE toward local device      |                                               |
| 11:10<br>12<br>13 | SGMII<br>Speed<br>SGMII<br>Duplex/<br>Remote<br>Fault 1<br>Remote |        |         | Encoding<br>10: 1000<br>01: 100M<br>00: 10M<br>Notice th<br>mode. In<br>i2_PhySp<br>In Mac-si<br>SGMII sp<br>1000Base<br>SGMII P<br>mode is: | g:<br>Mbps<br>Ibps<br>pps<br>at the<br>Phy S<br>peed  <br>ide SO<br>pecific<br>eX mo<br>hy-M<br>i_Phy | se bit a<br>SGMII<br>Local/<br>GMII n<br>cations<br>ode: Re<br>ode: D<br>/Duple: | emote fault bit 1<br>uplex mode, the adverti<br>k LocalAdvertisedCapa | beed is:<br>1:10]<br>s zeros as<br>sed Duplex |
|                   | Fault 2                                                           |        |         | 12                                                                                                                                           | -                                                                                                     | -3—Ren                                                                           | note Fault encoding                                                   |                                               |
|                   |                                                                   |        |         | RF1                                                                                                                                          | RF2                                                                                                   |                                                                                  | Description                                                           |                                               |
|                   |                                                                   |        |         | 0                                                                                                                                            | 0                                                                                                     | No error                                                                         | r, link OK (default)                                                  |                                               |
|                   |                                                                   |        |         | 0                                                                                                                                            | 1                                                                                                     | Offline                                                                          |                                                                       |                                               |
|                   |                                                                   |        |         | 1                                                                                                                                            | 0                                                                                                     | Link_Fa                                                                          | ilure                                                                 |                                               |
|                   |                                                                   |        |         | 1                                                                                                                                            | 1                                                                                                     | Auto-N                                                                           | egotiation_Error                                                      |                                               |
|                   |                                                                   |        |         | Table 37                                                                                                                                     | -3 and                                                                                                | 1 37-2 f                                                                         | From IEEE 802.3-2008                                                  | Section 3.                                    |
| 14                | Ack bit                                                           |        |         |                                                                                                                                              |                                                                                                       |                                                                                  |                                                                       |                                               |
| 15                | 1'b0                                                              |        |         |                                                                                                                                              |                                                                                                       |                                                                                  |                                                                       |                                               |

| Bit   | Name       | Offset | Default | Description                  |                              |
|-------|------------|--------|---------|------------------------------|------------------------------|
|       | Link       | 0x14   |         | Capability advertised by Lin | k Partner. The values change |
|       | Partner    |        |         | with mode of operations      |                              |
|       | capability |        |         |                              |                              |
|       |            |        |         | 1000BaseX mode               | SGMII mode                   |
| 0     | reserved   |        |         | 1'b0                         | 1'b1                         |
| 1     | reserved   |        |         | 1'b0                         | 1'b0                         |
| 2     | reserved   |        |         | 1'b0                         | 1'b0                         |
| 3     | reserved   |        |         | 1'b0                         | 1'b0                         |
| 4     | reserved   |        |         | 1'b0                         | 1'b0                         |
| 5     | FD         |        |         | Full Duplex                  | 1'b0                         |
| 6     | HD         |        |         | Half Duplex                  | 1'b0                         |
| 7     | PS1        |        |         | Pause                        | 1'b0                         |
| 8     | PS2        |        |         | ASM_DIR                      | 1'b0                         |
| 9     |            |        |         |                              | 1'b0                         |
| 10    | Speed0     |        |         |                              | Speed Bit 0                  |
| 11    | Speed1     |        |         |                              | Speed Bit 1. Encoding:       |
|       | -          |        |         |                              | 10: 1000Mbps                 |
|       |            |        |         |                              | 01: 100Mbps                  |
|       |            |        |         |                              | 00: 10Mbps                   |
| 12    | RF1        |        |         | Remote fault 1               | 1: Full Duplex               |
|       |            |        |         |                              | 0: Half Duplex               |
| 13    | RF2        |        |         | Remote fault 2               |                              |
| 14    | Ack Bit    |        |         | Sent between partners to     | SGMII Mode, sent from        |
|       |            |        |         | acknowledge autonego         | MAC to Phy to                |
|       |            |        |         | process                      | acknowledge the              |
|       |            |        |         |                              | autonegotiation process      |
| 15    | Link State |        |         |                              | SGMII Mode, sent from        |
|       |            |        |         |                              | PHY to Mac                   |
|       |            |        |         |                              | 1: Link Up                   |
|       |            |        |         |                              | 0: Link Down                 |
| 31:16 | Reserved   |        |         |                              |                              |

| Bit  | Name         | Offset | Default | Description                                                 |
|------|--------------|--------|---------|-------------------------------------------------------------|
| 15:0 | Link Timer 1 | 0x20   |         | Least Significant 16-bit of Link Timer                      |
|      | Link Timer 2 | 0x24   |         |                                                             |
| 4:0  |              |        |         | Most Significant 5 bit of Link Timer                        |
|      |              |        |         | Together these 2 registers from 21 bit timer which is run   |
|      |              |        |         | by 8-ns clock. Change the value of this register to smaller |
|      |              |        |         | value during simulation to speed up simulation process.     |
| 15:0 | Scratch      | 0x28   |         | Scratch register to test                                    |

| Bit | Name      | Offset | Default | Description                                                      |
|-----|-----------|--------|---------|------------------------------------------------------------------|
|     | Mode      | 0x7C   |         |                                                                  |
| 0   | SGMII     |        |         | 1: SGMII mode                                                    |
|     |           |        |         | 0: 1000BaseX mode                                                |
|     |           |        |         | The 2 modes differ in autonegotiation process and                |
|     |           |        |         | capability resolution                                            |
| 1   | Phy       |        |         | 1: Use as in SGMII Phy Side, i.e. transmit the control           |
|     |           |        |         | information.                                                     |
|     |           |        |         | 0: Use as in SGMII Mac Side, i.e receive the control             |
|     |           |        |         | information and send ack bit                                     |
| 2   | Use Local |        |         | For SGMII Mode                                                   |
|     | Config    |        |         | Mac Side, the speed and duplex at which the core is              |
|     |           |        |         | operated are set by Link-partner's "advertised"                  |
|     |           |        |         | information by default. If this "Use Local Config" is set        |
|     |           |        |         | to "1", the Speed and Duplex are set by control bits 6,13 and 8. |
|     |           |        |         | Phy Side, the speed and duplex at which the core is              |
|     |           |        |         | operated have to be set by either input port: i_PhyDuplex,       |
|     |           |        |         | i2_PhySpeed or by control bits 8 and 6,13                        |
|     |           |        |         | Note:                                                            |
|     |           |        |         | Do not get confused by advertised speed and the                  |
|     |           |        |         | operating speed.                                                 |
|     |           |        |         | Mac-Side SGMII: the Advertised 16-bits are all "0"               |
|     |           |        |         | except ack bit and bit 0.                                        |
|     |           |        |         | Phy-Side SGMII:                                                  |
|     |           |        |         | The advertised speed/duplex are set by either i_Phy*             |
|     |           |        |         | ports or by Local Capability bits 1210.                          |
|     |           |        |         | The operating speed and duplex are set by either i_Phy*          |
|     |           |        |         | port of by Control register bits 8, 6, 13.                       |
|     |           |        |         |                                                                  |

#### **2.2. ARCHITECTURES**



Sync block: synchronises to the received characters and gives odd/even flag and type of the received order-set. The first code-group of any ordered set must be "even".

Check-end block: the end of a packet may occur in many "fashion". The check-end block buffers 3 consecutive code-group and decodes what kind of "end of transmission" is about to happen. The information is fed into Receive block so that the receive block could generate appropriate receive signals.

Receive block: the Receive block receives code groups and generate RxDV, RxER signals. If the received code-group belongs to Configuration Ordered Set (C1/C2), it copies the configuration data and presents to Auto-negotiation block, else it feeds to the rate adapter.

Auto-negotiation block: this block is in charge of sending configuration code groups, checking of the received configuration codes and send "ack" bit if all auto-nego information is valid. It also gives out the current state of the synchronization process which is used by both Transmit and Receive.

Transmit block: In auto-negotiation state, the transmit block receives "config data" from autonegotiation block and then transmit this 16-bit register in Configuration Ordered set. In data transmit state, it transmits data from rate-adapter block.

Registers block: this block contains registers that control the operation of the core. The registers are accessible via Wishbone-compatible bus. MDIO will be implemented if necessary.

Rate adapter block: in 1000Mb speed rate, the rate adapter is bypassed. In 10/100Mb speed rate, this block elongated each data byte 100/10 times so that it can be transmitted in 1000Mb line rate.

Transceiver block: this block is technology dependent and you have to modify it to fit your system. The transceiver can be implemented using dedicated transceiver or using LVDS differential IO. Using lvds differential IOs requires 8b10b encoder/decoder. The current implementation of bit-slip signal requires the 8b10b encoder/decoder generates Decoding Error signal. Some 8b10b endec doesn't have this signal. In that case, bit-slip should be generated by searching for a fixed pattern (e.g 0xBC) in the received bytes.

#### **3. SIMULATION GUIDE**

Testbench and simulation scripts are placed in sim folder. The latest simulation script that should be run is: *Sim\_SGMII1000Mblvds.do*. The paths need to be changed to fit user's Quartus Installation. This simulation script compile and run the core in SGMII mode with LVDS serdes. The link partner is an Altera's SGMII-core instantiated in *sim/BFMs* folder. Other scripts that would be useful are:

*Sim\_1000BaseX.do*: Simulates the core in 1000BaseX mode using dedicated transceiver.

*Sim\_SGMII1000Mb.do*: simulates the core in SGMII 1000Mbps using dedicated transceiver

*Sim\_SGMII100Mb.do*: simulates the core in SGMII 100Mb using dedicated transceiver.

For these 3 simulations, users have to modify the SGMII.v top file to instantiate GXB-based Serdes.



If everything goes right, simulator should print out something like this:



## 4. REVISION HISTORY

| Date<br>(dd/mm/yy) | Author | Doc's<br>Rev | Core's<br>Rev | Description                                                                            |
|--------------------|--------|--------------|---------------|----------------------------------------------------------------------------------------|
|                    | Jeff   | 1.0          |               | Core is in verification state                                                          |
|                    |        | 1.1          |               | Correct some typos<br>Core has been verified in SGMII mode with 88E1111<br>Marvell Phy |
| 10/11/12           | Jeff   | 1.2          | 19            | Correct some typos<br>Added simulation guide                                           |

Jeff: jefflieu@fpga-ipcores.com