# MAC and PHY delay variation

Impact of MAC and PHY jitter

Ferreira Coelho, Rodrigo (Siemens AG)
Steindl, Günter (Siemens AG)

V01 2022-11-17

#### MAC and PHY model

Time stamping for synchronization faces a difference between the model and the reality.

While the model assumes he timestamping point at the MDI, the real timestamping is mainly done "before" the MAC.



- Reference point
- Timestamping point in reality

### PHY model

Values from manufacturer:

MII to MDI latency

- Transmit direction
- Receive direction

Latency variation (See 802.3cx)

- Min and Max
  - Transmit
  - Receive



### 802.3 – PHY located between xMII and MDI



AUI = ATTACHMENT UNIT INTERFACE

GMII = GIGABIT MEDIA INDEPENDENT INTERFACE

MAU = MEDIUM ATTACHMENT UNIT

MDI = MEDIUM DEPENDENT INTERFACE

MII = MEDIA INDEPENDENT INTERFACE

PCS = PHYSICAL CODING SUBLAYER
PHY = PHYSICAL LAYER DEVICE
PLS = PHYSICAL LAYER SIGNALING
PMA = PHYSICAL MEDIUM ATTACHMENT

PMD = PHYSICAL MEDIUM DEPENDENT



MDI = MEDIUM DEPENDENT INTERFACE XGMII = TEN GIGABIT MEDIA INDEPENDENT INTERFACE PCS = PHYSICAL CODING SUBLAYER
PMA = PHYSICAL MEDIUM ATTACHMENT
PHY = PHYSICAL LAYER DEVICE

\*XGMII is optional.

Figure 55–1—Type 10GBASE-T PHY relationship to the ISO Open Systems Interconnection (OSI) reference model and the IEEE 802.3 Ethernet model

Figure 22–1—MII relationship to the ISO/IEC Open Systems Interconnection (OSI) reference model and the IEEE 802.3 CSMA/CD LAN model

#### P802.3cx

### Transmit and Recieve latency variation

Table 45-140—TimeSync PMA/PMD transmit path data delay register

| Bit(s)      | Name                                                  | Description                       | R/W <sup>a</sup> |
|-------------|-------------------------------------------------------|-----------------------------------|------------------|
| 1.1801.15:0 | Maximum PMA/PMD transmit path data delay in ns, lower | PMA/PMD_delay_ns_TX_max [15:0]    | RO, MW           |
| 1.1802.15:0 | Maximum PMA/PMD transmit path data delay in ns, upper | PMA/PMD_delay_ns_TX_max [31:16]   | RO, MW           |
| 1.1803.15:0 | Minimum PMA/PMD transmit path data delay in ns, lower | PMA/PMD_delay_ns_TX_min [15:0]    | RO, MW           |
| 1.1804.15:0 | Minimum PMA/PMD transmit path data delay in ns, upper | PMA/PMD_delay_ns_TX_min [31:16]   | RO, MW           |
| 1.1809.15:0 | Maximum PMA/PMD transmit path<br>data delay in sub-ns | PMA/PMD_delay_subns_TX_max [15:0] | RO               |
| 1.1810.15:0 | Minimum PMA/PMD transmit path<br>data delay in sub-ns | PMA/PMD_delay_subns_TX_min [15:0] | RO               |

<sup>a</sup>RO = Read only, MW = Multi-word.

Table 45–141—TimeSync PMA/PMD receive path data delay register

| Bit(s)             | Name                                                 | Description                       | R/Wª      |
|--------------------|------------------------------------------------------|-----------------------------------|-----------|
| 1.1805.15:0        | Maximum PMA/PMD receive path data delay in ns, lower | PMA/PMD_delay_ns_RX_max [15:0]    | RO, MW    |
| 1.1806.15:0        | Maximum PMA/PMD receive path data delay in ns, upper | PMA/PMD_delay_ns_RX_max [31:16]   | RO, MW    |
| 1.1807.15:0        | Minimum PMA/PMD receive path data delay in ns. lower | PMA/PMD_delay_ns_RX_min [15:0]    | RO, MW    |
| 1.1808.15:0        | Minimum PMA/PMD receive path data delay in ns, upper | PMA/PMD_delay_ns_RX_min [31:16]   | RO, MW    |
| 1.1811.15:0        | Maximum PMA/PMD receive path data delay in sub-ns    | PMA/PMD_delay_subns_RX_max [15:0] | <u>RO</u> |
| <u>1.1812.15:0</u> | Minimum PMA/PMD receive path data delay in sub-ns    | PMA/PMD_delay_subns_RX_min [15:0] | <u>RO</u> |

<sup>&</sup>lt;sup>a</sup>RO = Read only, MW = Multi-word.

### PHY model: Parameter example

#### **Example (best in class):**

100Mbit/s

TX latency (const) = 100ns

TX latency (var) = 0...4ns

RX latency (const) = 180ns

RX latency (var) = 0...4ns

#### **Example (random):**

100Mbit/s

TX latency (const) = 100ns

TX latency (var) = 0...32ns

RX latency (const) = 180ns

RX latency (var) = 0...16ns

### MAC model: Parameter example

#### **Example (best in class):**

100Mbit/s

TX latency (const) = some value

TX latency (var) = 0

RX latency (const) = some value RX latency (var) = 0

#### That's the remaining delay of

- the MAC after the real time stamp point and xMII for transmit
- the MAC after the xMII and the real time stamp point for receive

### Problem statement: Synchronization



#### Example 1:

Timestamping error = timestamp itself (4ns/8ns)

- + uncertainty MAC latency (0ns)
- + uncertainty PHY latency (4ns)
- = 12ns

#### Example 2:

Timestamping error = timestamp itself (4ns/8ns)

- + uncertainty MAC latency (32ns)
- + uncertainty PHY latency (125ns)
- = 165ns

Timestamp error influences the

- Pdelay value
- Residence time value

Additionally, the asymmetry of errors is a problem

Reference point

Timestamping point in reality

### Questions 1/2

What are the values for the MAC delay variations?

For the selected

- 10Mbit/s MAU Types
- 100Mbit/s MAU Types
- 1Gbit/s MAU Types
- 2,5Gbit/s MAU Types
- 5Gbit/s MAU Types
- 10Gbit/s MAU Types

## Questions 2/2

What are the values for the PHY delay variations?

For the selected

- 10Mbit/s MAU Types
- 100Mbit/s MAU Types
- 1Gbit/s MAU Types
- 2,5Gbit/s MAU Types
- 5Gbit/s MAU Types
- 10Gbit/s MAU Types

### Summary

#### MAC and PHY delay variation influences

- Pdelay measurement erroneous
  - Delay value is the average value if filtering is applied
- Pdelay measured vs. real sync message pdelay
  - Different frames do have different pdelay (inside the min/max of MAC/PHY delay)
- Residence time measurement erroneous
  - Delay variation creates uncertainty when the frame is (and was) at the reference point (compared to the real timestamping point)

Used algorithms need to take these errors into account!

## Questions?