

# Erratum A-007207: TBI LINK STATUS SGMII STAYS UP

PB #16224 Affected Devices: BSC9132

May 2014



Confidential and Proprietary

 $\bigcirc$ 

Freescale, the Freescale logo, AltWec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire, C-Ware, the Energy Efficient Solutions logo, Kinetis, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, Qortiva, SafaAssure, the SafaAssure logo, StarCore, Symphony and VortiQa are trademarks of Freescale Semiconductor, Inc., Reg. U.S. Pat, & Trn. Off. Airfast, BeeKit, BeeStack, CoreNet, Flaxis, Layerscape, MagnN, MXC, Platform in a Package, QorlQ Qonverge, QUICC Engine, Ready Play, SMARTMOS, Tower, TurboLink, UMEMS, Vybrid and Xirhsic are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © 2014 Freescale Semiconductor, Inc.





#### TBI link status may stay "up" after SGMII electrical idle detected

Devices: BSC9132

#### **Description**:

The TBI Status Register (SR) contains a link status bit (TBI SR [Link Status]) that represents the current state of the SGMII link. If Auto-Negotiation (AN) is disabled, the TBI link status bit should become a b'1 indicating the link is up after recognizing IDLE sequences, and stay at b'1 as long as valid data is received & the TBI is not reset. TBI link status bit should become a b'0 indicating the link is down after several invalid characters are received or the TBI is reset. If AN is enabled, the TBI link status bit does not become set to b'1 until auto-negotiation is complete (TBI CR [AN DONE]=1), but the same conditions as AN disabled then apply for the TBI link status bit to get cleared to b'0.

An electrical idle (common mode) condition on the SGMII link results in the reception of invalid data, and should cause the TBI link status bit to get cleared. If the transition from active to common mode takes enough time that the Rx is able to recognize at least 4 more K28.5 characters (for IDLE sequences, 70-80 UI), the portion of the design intended to detect the link down condition may shut off before the link down condition is actually reflected in the TBI.

This premature shutdown <u>may</u> cause the TBI link status to remain set to a b'1 indicating the link is up. This 'stuck at 1' condition would persist until valid K28.5 characters are received again.



TBI link status may stay "up" after SGMII electrical idle detected (cont. 2 of 4)

#### Impact:

If the system never enters SGMII electrical idle, or if the transition from active to common mode takes less than 40 UI (~32 ns), then there is no impact and the false link up scenario does not occur.

If the system can generate an SGMII electrical idle condition as described above, then the TBI status may stay stuck at 1 while the link is down and does not transition to 0 until valid K28.5 characters are received again.



TBI link status may stay "up" after SGMII electrical idle detected (cont. 3 of 4)

#### Workaround:

If TBI SR[Link Status] = 0, the link is down.

For affected systems, in addition to examining the TBI link status, examine the SerDes electrical idle state. The link is actually down if either the TBI link status is cleared or the SerDes lane receive electrical idle is detected.

SerDes electrical idle detected is SERDES\_LnGCR1[REIDL] = 1 for lane n.

Example pseudo-code:

```
if (SERDES_LnGCR1[REIDL] == b'1)
OR
(TBI SR[LINK STATUS] == b'0)
{
LINK is DOWN
}
```



TBI link status may stay "up" after SGMII electrical idle detected (cont. 4 of 4)

#### **Disposition**:

No plans to fix.



## **Steps to Read TBI Status and Receive Electrical Idle**

| Action | Register                                                                                                                                                                              |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| write  | MIIMCOM[Read Cycle] = 1                                                                                                                                                               |
| write  | MIIMADD[PHY Address] = value from TBIPA for dTSEC used                                                                                                                                |
| write  | MIIMADD[Register Address] = 1 for TBI Status Register (SR)                                                                                                                            |
| write  | MIIMCOM[Read Cycle] = 0 to ensure 0 -> 1 transition for non-stale data                                                                                                                |
| write  | MIIMCOM[Read Cycle] = 1                                                                                                                                                               |
| read   | MIIMSTAT[PHY Status] for value in TBI SR. Check TBI SR[Link Status]. '0' means link is down.                                                                                          |
| read   | SERDES_LnGCR1[REIDL] where <i>n</i> means lane. '1' means link is down. '0' means non-electrical idle state but could be receiving invalid symbols which would result in a link down. |



