## 101.3.2.1 Idle control character deletion process

In the transmitting PCS, the Idle control character deletion process is responsible for deleting excess Idle control characters inserted in between individual frames to adjust the data rate enforced by the MAC Control (as defined in {Clause 102}) to the effective data rate supported by the PCS and PMD. The gaps created within the data stream by the operation of the Idle control character deletion process are used in one of the following ways:

- a) some gaps created by the removal of Idle control characters are filled with FEC parity data (FEC overhead compensation sub-process); and
- b) other gaps created by the removal of Idle control characters are discarded in order to decrease the data rate between the MAC and PHY, while maintaining the effective data rate unchanged (data rate adaptation sub-process).

The Idle control character deletion process deletes a specific number of 72-bit vectors containing Idle control characters from the data stream composed of a series of 72-bit vectors received from the XGMII. The number of deleted 72-bit vectors containing Idle control characters depends on the EPoC PMD data rate, PMD overhead (including, for example, Cyclic Prefix), and the size of FEC parity data. The Idle control character deletion process is composed of two sub-processes executed in the following order:

- data rate adaptation sub-process, where the PCS discards a specific number of excess Idle control characters to decrease the data rate to match the effective data rate supported by the EPoC PMD; at the output of the data rate adaptation sub-process, the data stream still contains excess Idle control characters; and
- b) FEC overhead compensation sub-process, where the PCS discards the remaining excess Idle control characters to prepare space in the de-rated data stream for PHY parity data; at the output of the FEC overhead compensation sub-process, the data stream does not contain any excess Idle control characters.

The operation of the EPoC MPCP defined in {Clause 102} ensures that a sufficient number of excess Idle control characters are present in the data stream, so that the minimum IPG between two adjacent frames is preserved once all excess Idle control characters are removed through the operation of the data rate adaptation and the FEC overhead compensation sub-processes.

## 101.3.2.1.1 Constants

# FEC\_DSize

TYPE: 16-bit unsigned integer

The number of 72-bit vectors constituting the payload portion of a FEC codeword. To normalize pre-FEC data rate, the Idle control character deletion process removes FEC\_OSize vectors per every FEC\_DSize vectors transferred to the 64B/66B encoder.

Value: {TBD}

# FEC OSize

TYPE: 16-bit unsigned integer

The number of 72-bit vectors constituting the parity (overhead) portion of a FEC codeword. To normalize pre-FEC data rate, the Idle control character deletion process removes FEC\_OSize vectors per every FEC\_DSize vectors transferred to the 64B/66B encoder.

Value: {TBD}

Note that the list of constants will be updated per technical decision #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled.

3

4 5

6 7 8

9

10

11

12 13

14

15

16

17

18

19

20 21

22 23

242526

2.7

28

29

30

31

32

33

34 35

36 37

38

39 40 41

42 43

44 45

46

47

48

49 50

51

52

53

54

## 101.3.2.1.2 Variables

## **BEGIN**

TYPE: Boolean

This variable is used when initiating operation of the state diagram. It is set to true following initialization and every reset.

# delayBound

TYPE: 16-bit unsigned integer

This value represents the delay sufficient to initiate the transmitter at the CNU and to stabilize the receiver at the CLT (i.e., the maximum FIFO size expressed in units of 66-bit blocks). The value of delayBound includes {to be added when the burst structure is known}. This variable is used only by the CNU.

## PHY DSize

TYPE: 16-bit unsigned integer

The number of 72-bit vectors constituting (together with PHY\_OSize) the denominator in the EPoC PCS de-rating Equation (101–1). To normalize the effective PCS data rate, the Idle control character deletion process removes PHY\_OSize vectors per every PHY\_DSize vectors transferred to the FEC overhead compensation sub-process.

Value: {TBD, reference how it is calculated ?}

$$PCS_Rate = XGMII_Rate \times \frac{PHY_DSize}{PHY_DSize + PHY_OSize}$$
(101–1)

## PHY\_OSize

TYPE: 16-bit unsigned integer

The number of 72-bit vectors constituting the numerator in the EPoC PCS de-rating Equation (101–1). To normalize the effective PCS data rate, the Idle control character deletion process removes PHY\_OSize vectors per every PHY\_DSize vectors transferred to the FEC overhead compensation sub-process.

Value: {TBD, reference how it is calculated ?}

# tx\_raw<71:0>

This variable is defined in  $\{49.2.13.2.2\}$ .

# tx\_raw\_out<71:0>

72-bit vector sent from the output of the Idle control character deletion process to the 64B/66B encoder. This vector contains two XGMII transfers mapped as shown for tx\_raw<71:0>.

Note that the list of variables will be updated per technical decision #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled.

## 101.3.2.1.3 Counters

# countDeleteF

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors that need to be deleted from the received data stream as part of the FEC overhead compensation sub-process.

# countDeleteP

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors that need to be deleted from the received data stream as part of the data rate adaptation sub-process.

## countIdleF

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors containing Idle control characters or other control vectors as part of the FEC overhead compensation sub-process.

#### countIdleP

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors containing Idle control characters or other control vectors as part of the data rate adaptation sub-process.

#### countVectorF

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors transmitted after the removal of Idle characters as part of the FEC overhead compensation sub-process.

#### countVectorP

TYPE: 16-bit unsigned integer

Counts the number of 72-bit vectors transmitted after the removal of Idle characters as part of the data rate adaptation sub-process.

Note that the list of counters will be updated per technical decision #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled.

# 101.3.2.1.4 Functions

T TYPE(tx raw<71:0>)

This function is defined in  $\{49.2.13.2.3\}$ .

Note that the list of functions will be updated per technical decision #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled.

# 101.3.2.1.5 State diagrams

The CLT PCS shall perform the Idle control character deletion process as shown in Figure 101–3 (data rate adaptation sub-process) and in Figure 101–4 (FEC overhead compensation sub-process), in the order shown in {Figure 101-X1}. The CNU PCS shall perform the Idle control character deletion process as shown in Figure 101–5 (data rate adaptation sub-process) and in Figure 101–6 (FEC overhead compensation sub-process), in the order shown in {Figure 101-X1}. In case of any discrepancy between state diagrams and the descriptive text, the state diagrams prevail.



Figure 101–3—CLT Idle control character deletion process (data rate adaptation sub-process)



Figure 101–4—CLT Idle control character deletion process (FEC overhead compensation sub-process)



Figure 101–5—CNU Idle control character deletion process (data rate adaptation sub-process)



**BEGIN** 

Figure 101–6—CNU Idle control character deletion process (FEC overhead compensation sub-process)

Note that Figure 101–3, Figure 101–5, Figure 101–5, and Figure 101–6 will be updated per technical decision #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled, as well as the burst structure is defined.

## 101.3.3.7 Idle control character insertion process

In the receiving PCS, the Idle control character insertion process inserts Idle control characters into the data stream with gaps as received from the FEC decoder and 64B/66B decoder, adjusting the effective PCS and PMD data rate to the data rate enforced by the MAC Control (as defined in {Clause 102}). Effectively, the Idle control character insertion process fills in the gaps created after the removal of FEC parity data, as well as compensates for the derating of the EPoC PMD relative to the EPoC MAC.

The Idle control character insertion process (see {Figure 101-3}) is composed of:

- a) a receive process, receiving 72-bit vectors from the 64B/66B decoder and writing them into the Idle Insertion FIFO (called FIFO\_II); and
- b) a transmit process, reading 72-bit vectors from FIFO\_II and transferring them to the XGMII.

The receive process receives 72-bit vectors from the 64B/66B decoder at a slower data rate than the nominal XGMII data rate for two reasons:

- a) the FEC parity data is removed within the FEC decoder, leaving behind gaps in the data stream; and
- b) the data rate supported by EPoC PCS and PMD is lower than the data rate supported by MAC Control Client, requiring data rate adaptation between the PCS and MAC.

The transmit process outputs 72-bit vectors at the nominal XGMII data rate.

To match the difference in data rates between the receive process and the transmit process, the Idle control character insertion process inserts additional 72-bit vectors containing Idle control characters. The additional blocks are inserted between frames and not necessarily at the same locations where FEC parity data was removed within the FEC decoder.

#### 101.3.3.7.1 Constants

# FIFO\_II\_SIZE

TYPE: 16-bit unsigned integer

This constant represents the size of Idle Insertion FIFO buffer. The size of this buffer is selected in such a way that it is able to accommodate the number of 66-bit vectors sufficient to fill the gap introduced by removing the FEC parity data for a maximum size MAC frame, and compensate for the maximum supported difference between the MAC rate and PMD rate.

Value: {TBD}

It seems that the FIFO\_II\_SIZE depends on the two following items: (a) the type of FEC and the size of FEC parity that is removed from data stream at regular intervals; and (b) the data rate differential between the PMD and the MAC. Every time the data rate changes, the size of FIFO\_II may need to be adapted as well, to make sure that no additional delay / jitter is introduced. Whether such a change is needed, needs to be studied in more detail when more PMD/PCS details are available.

# IDLE\_VECTOR

TYPE: 72-bit binary array

This constant represents a 72-bit vector containing Idle control characters.

### LBLOCK\_R

This constant is defined in {49.2.13.2.1}.

Note that the value of FIFO\_II\_SIZE, as well as the list of constants will be updated per technical decision #43 and #45 (http://www.ieee802.org/3/bn/public/decisions/decisions.html) once EPoC-specific FEC and PMD overhead details are settled.

| 101.3.3.7.2      | 2 Variables                                                                                       | 1        |
|------------------|---------------------------------------------------------------------------------------------------|----------|
| BEGIN            |                                                                                                   | 2        |
|                  | TYPE: Boolean                                                                                     | 4        |
|                  | This variable is used when initiating operation of the state diagram. It is set to true following | 5        |
|                  | initialization and every reset.                                                                   | 6        |
| FIFO_II          |                                                                                                   | 7<br>8   |
| 111 0_11         | TYPE: Array of 72-bit vectors                                                                     | 9        |
|                  | The FIFO_II buffer is used to perform data rate adaptation between XGMII data rate and the        | 10       |
|                  | EPoC PMD data rate. Upon initialization, all elements of this array are filled with instances of  | 11       |
|                  | IDLE_VECTOR. The FIFO_II buffer has the size of FIFO_II_SIZE (see 101.3.3.7.1).                   | 12       |
| RX_CLK           |                                                                                                   | 13<br>14 |
| KA_CLK           | TYPE: Boolean                                                                                     | 15       |
|                  | This variable represents the RX_CLK signal defined in {46.3.2.1}.                                 | 16       |
|                  |                                                                                                   | 17       |
| rx_raw_ii        | n<71:0>                                                                                           | 18       |
|                  | TYPE: 72-bit binary array                                                                         | 19       |
|                  | This variable represents a 72-bit vector received from the output of the 64B/66B decoder.         | 20       |
|                  | RXD<0> through RXD<31> for the second transfer are placed in rx_raw<40> through                   | 21       |
|                  | rx_raw<71>, respectively.                                                                         | 22       |
| rx_raw_out<71:0> |                                                                                                   | 23<br>24 |
| IA_Iaw_0         | TYPE: 72-bit binary array                                                                         | 25       |
|                  | This variable represents a 72-bit vector passed from the Idle control character insertion process | 26       |
|                  | to XGMII. The vector is mapped to two consecutive XGMII transfers as follows:                     | 27       |
|                  | Bits rx_raw<3:0> are mapped to RXC<3:0> for the first transfer;                                   | 28       |
|                  | Bits rx_raw<7:4> are mapped to RXC<3:0> for the second transfer;                                  | 29       |
|                  | Bits rx_raw<39:8> are mapped to RXD<31:0> for the first transfer;                                 | 30       |
|                  | Bits rx_raw<71:40> are mapped to RXD<31:0> for the second transfer.                               | 31<br>32 |
| countVec         | tor                                                                                               | 33       |
|                  | TYPE: 16-bit unsigned integer                                                                     | 34       |
|                  | This variable represents the number of 72-bit vectors stored in the FIFO_II at the given          | 35       |
|                  | moment of time.                                                                                   | 36       |
|                  | <b>.</b>                                                                                          | 37       |
| 101.3.3.7.3      | 3 Functions                                                                                       | 38       |
| T TVDE           | (rx_raw<71:0>)                                                                                    | 39<br>40 |
| 1_1111           | This function is defined in {49.2.13.2.3}.                                                        | 41       |
|                  | This function is defined in (47.2.13.2.3).                                                        | 42       |
| 101.3.3.7.4      | 1 Messages                                                                                        | 43       |
|                  |                                                                                                   | 44       |
| DECODE           | ER_UNITDATA.indicate(rx_raw_in<71:0>)                                                             | 45       |
|                  | A signal sent by the EPoC PCS Receive process, conveying the next received 72-bit vector.         | 46       |
| DUDI             |                                                                                                   | 47<br>48 |
| DODI             | Alias for DECODER_UNITDATA.indicate(rx_raw_in<71:0>).                                             | 49       |
|                  | Times 101. DDC-ODDR_CTATDTTTT:Illidicute(IA_1UW_III\/11.07).                                      | 50       |
| 101.3.3.7.5      | 5 State diagrams                                                                                  | 51       |
|                  | -                                                                                                 | 52       |
| The CLT an       | d CNU PCS shall perform the Idle control character insertion process as shown in Figure 101–7.    | 53       |
| In case of an    | ny discrepancy between state diagrams and the descriptive text, the state diagrams prevail.       | 54       |



Figure 101-7—Idle control character insertion process state diagram