## Adding Sequence Ordered Set to MII

### William Lo March 11, 2024

1

IEEE 802.3dg 100Mb/s Long-Reach Single Pair Ethernet



# MII vs. XGMII

- XGMII and MII are similar in transporting data, errors, idles, and low power idles
  - MII Less than 1G
  - XGMII More than 1G
  - GMII 1G (Not discussed in this presentation)
- Half duplex features in MII not present in XGMII
- XGMII has useful features to send ordered sets
  - Local Fault
  - Remote Fault
  - Link Interruption
  - Open way to add new ordered sets while keeping the transport backwards compatible.



## Tx MII vs XGMII

### Table 22–1—Permissible encodings of TXD<3:0>, TX\_EN, and TX\_ER

| TX_EN | TX_ER | TXD<3:0>          | Indication                 |   |
|-------|-------|-------------------|----------------------------|---|
| 0     | 0     | 0000 through 1111 | Normal inter-frame         | • |
| 0     | 1     | 0000              | Reserved                   |   |
| 0     | 1     | 0001              | Assert LPI                 | - |
| 0     | 1     | 0010              | PLCA BEACON request        |   |
| 0     | 1     | 0011              | PLCA COMMIT request        |   |
| 0     | 1     | 0100 through 1111 | Reserved                   |   |
| 1     | 0     | 0000 through 1111 | Normal data transmission   |   |
| 1     | 1     | 0000 through 1111 | Transmit error propagation |   |

#### TXC TXD Description PLS DATA.request parameter 0 00 through FF Normal data transmission ZERO, ONE (eight bits) 00 through 05 Reserved 1 06 Only valid on all four lanes No applicable parameter simultaneously to request LPI (normal interframe) 07 Idle No applicable parameter 1 (Normal inter-frame) 08 through 9B Reserved 9C No applicable parameter Sequence (only valid in lane 0) (Inter-frame status signal) 9D through FA Reserve 1 FB Start (only valid in lane 0) No applicable parameter, replaces first 1 eight ZERO, ONE of a frame (preamble octet) 1 FC Reserved FD Terminate DATA COMPLETE 1 No applicable parameter FE Transmit error propagation 1 FF Reserved NOTE-Values in TXD column are in hexadecimal, most significant bit to least significant bit (i.e., <7:0>).

• MII is missing ability to send Sequence Ordered Sets

3

IEEE 802.3dg 100Mb/s Long-Reach Single Pair Ethernet



### Table 46–3—Permissible encodings of TXC and TXD

## Rx MII vs XGMII

### Table 22–2—Permissible encoding of RXD<3:0>, RX\_ER, and RX\_DV

| RX_DV | RX_ER | RXD<3:0>          | Indication                 |  |
|-------|-------|-------------------|----------------------------|--|
| 0     | 0     | 0000 through 1111 | Normal inter-frame         |  |
| 0     | 1     | 0000              | Normal inter-frame         |  |
| 0     | 1     | 0001              | Assert LPI                 |  |
| 0     | 1     | 0010              | PLCA BEACON indication     |  |
| 0     | 1     | 0011              | PLCA COMMIT indication     |  |
| 0     | 1     | 0100 through 1101 | Reserved                   |  |
| 0     | 1     | 1110              | False Carrier indication   |  |
| 0     | 1     | 1111              | Reserved                   |  |
| 1     | 0     | 0000 through 1111 | Normal data reception      |  |
| 1     | 1     | 0000 through 1111 | Data reception with errors |  |

#### Table 46–4—Permissible lane encodings of RXD and RXC

| RXC                        | RXD                                   | Description                                                                        | PLS_DATA.indication parameter                                                                                                                                                             |
|----------------------------|---------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                          | 00 through FF                         | Normal data reception                                                              | ZERO, ONE (eight bits)                                                                                                                                                                    |
| 1                          | 00 through 05                         | Reserved                                                                           | _                                                                                                                                                                                         |
| 1                          | 06                                    | Only valid on all four lanes<br>simultaneously to indicate LP_IDLE<br>is asserted  | No applicable parameter<br>(Normal interframe)                                                                                                                                            |
| 1                          | 07                                    | Idle                                                                               | No applicable parameter<br>(Normal inter-frame)                                                                                                                                           |
| 1                          | 08 through 9B                         | Reserved                                                                           | _                                                                                                                                                                                         |
| 1                          | 9C                                    | Sequence (only valid in lane 0)                                                    | No applicable parameter<br>(Inter-frame status signal)                                                                                                                                    |
|                            |                                       |                                                                                    |                                                                                                                                                                                           |
| 1                          | 9D through FA                         | Reserved                                                                           | _                                                                                                                                                                                         |
| 1                          | 9D through FA<br>FB                   | Reserved<br>Start (only valid in lane 0)                                           | No applicable parameter, first eight ZERO, ONE of a frame (a preamble octet)                                                                                                              |
| 1 1 1 1                    | 9D through FA<br>FB<br>FC             | Reserved<br>Start (only valid in lane 0)<br>Reserved                               | On applicable parameter, first eight ZERO, ONE of a frame (a preamble octet)                                                                                                              |
| 1<br>1<br>1<br>1<br>1      | 9D through FA<br>FB<br>FC<br>FD       | Reserved<br>Start (only valid in lane 0)<br>Reserved<br>Terminate                  | <ul> <li>No applicable parameter, first eight ZERO, ONE of a frame (a preamble octet)</li> <li>No applicable parameter (Start of inter-frame)</li> </ul>                                  |
| 1<br>1<br>1<br>1<br>1<br>1 | 9D through FA<br>FB<br>FC<br>FD<br>FE | Reserved<br>Start (only valid in lane 0)<br>Reserved<br>Terminate<br>Receive error | <ul> <li>No applicable parameter, first eight ZERO, ONE of a frame (a preamble octet)</li> <li>No applicable parameter (Start of inter-frame)</li> <li>No applicable parameter</li> </ul> |





### MII Sequence Ordered Set Coding Proposal

| TX_EN/ | TX_ER/ | TXD<3:0>/                               |                               |
|--------|--------|-----------------------------------------|-------------------------------|
| RX_DV  | RX_ER  | RXD<3:0>                                |                               |
| 0      | 1      | 0100                                    | Sequence Ordered Set 1st Half |
| 0      | 1      | 0100                                    | Sequence Ordered Set 2nd Half |
| 0      | 0      | Lane1<3:0>                              | Ordered Set Value Lane 1 LSB  |
| 0      | 0      | Lane1<7:4>                              | Ordered Set Value Lane 1 MSB  |
| 0      | 0      | Lane2<3:0> Ordered Set Value Lane 2     |                               |
| 0      | 0      | Lane2<7:4> Ordered Set Value Lane 2     |                               |
| 0      | 0      | Lane3<3:0> Ordered Set Value Lane 3     |                               |
| 0      | 0      | Lane3<7:4> Ordered Set Value Lane 3 MSE |                               |

 Table 46–5—Sequence ordered sets

| Lane 0   | Lane 1 | Lane 2 | Lane 3 | Description       |
|----------|--------|--------|--------|-------------------|
| Sequence | 0x00   | 0x00   | 0x00   | Reserved          |
| Sequence | 0x00   | 0x00   | 0x01   | Local Fault       |
| Sequence | 0x00   | 0x00   | 0x02   | Remote Fault      |
| Sequence | 0x00   | 0x00   | 0x03   | Link Interruption |
| Sequence | ≥ 0x00 | ≥ 0x00 | ≥ 0x04 | Reserved          |
|          |        | •      |        |                   |

NOTE—Values in Lane 1, Lane 2, and Lane 3 columns are in hexadecimal, most significant bit to least significant bit (i.e., <7:0>). The link fault signaling state diagram allows future standardization of reserved Sequence ordered sets for functions other than link fault indications

- If two ordered set codes seen in a row, the next 6 nibbles are the 24-bit ordered set value
- Legacy MACs RX\_DV = 0, RX\_ER = 1, RXD = 0100 currently reserved
  - Does legacy MACs treat this as idles?
- The 6 nibbles recognized by legacy MACs as idles

5



# **Connecting to Legacy MACs**

- Option 1:
  - Standard stays silent. Proprietary method to convert Sequence Order Set symbol to idles in implementations
- Option 2:
  - Specify IEEE define register to give applications hint
    - OS\_ABILITY Read only register indicating PHY can handle ordered set
    - OS\_ENABLE -

1 = PHY passes ordered set through on RX\_DV/RX\_ER/RXD, 0 = PHY converts ordered set to idles

11 Mar 2024



# **THANK YOU**

IEEE 802.3dg 100Mb/s Long-Reach Single Pair Ethernet

