

#### **MAC-PHY** Rate Adaptation Baseline

### Arthur Marris

#### arthurm@tality.com

IEEE802.3ah EFM Task Force March 2002

### TALITY

### **The Rate Matching Problem**

- The data rate for the EFM copper PHY is not fixed
- The data rate for the EFM copper PHY will be less than 100Mbit/s
- A mechanism is needed to match the PHY's intrinsically slower data rate with the MAC's faster fixed data rate

#### - <del>7</del>7 TALITY

### Rate matching using deference

- This presentation explains how to do rate matching using deference and why this method is preferable to other mechanisms
- Use 100Mb/s MAC with MII interface
- No changes to the MAC or the MII interface specifications
- MII is defined in IEEE Std 802.3 clause 22
- Deference is defined in IEEE Std 802.3 clause 4

### How does it work?



#### Configure the MAC for

- Half duplex (as defined in clause 4, the MAC is still permitted to transmit and receive at the same time)
- 100Mb/s operation (rx\_clk and tx\_clk inputs clocked at 25MHz)
- Use false carrier sense indication from the PHY to the MAC to throttle back transmission
- Store complete received frames in the PHY and then send to MAC at 100Mbps

### **Transmit operation**



- The MAC asserts tx\_en to signal frame start
- The EFM PHY asserts crs in response (see clause 4.3.3)
- The EFM PHY keeps crs asserted after tx\_en is de-asserted until it is ready to take another frame from the MAC
- The MAC will not transmit another frame until crs is deasserted
- This is deference (see clause 4.2.3.2.1)

# Transmit Frame buffering in the PHY



- Depending on the data rate of the PHY it will need to buffer almost an entire maximum size ethernet frame (1522 bytes)
- The PHY will receive data at a rate of 100Mbit/s from the MAC
- As soon as the PHY starts receiving data from the MAC it can start its own transmission
- Once the PHY has finished transmission and emptied its transmit buffer it can de-assert carrier sense to signal it is ready to receive another transmit frame from the MAC

### **Transmit Process**



| <br>IDLE<br>crs de-asserted (unless rx is active) |
|---------------------------------------------------|
| Tx_en active                                      |
| TRANSMIT                                          |
| crs asserted                                      |
| phy transmitting                                  |
| Tx_en inactive                                    |
| FINISH TRANSMIT                                   |
| crs asserted                                      |
| phy transmitting                                  |
| Transmit finished                                 |

### **Receive operation**



- If a MAC is implemented so that it can receive while it is transmitting in half duplex mode the PHY simply has to buffer a receive frame and then send it to the MAC when it has buffered an entire frame.
- For MAC's that are unable to receive while transmitting in halfduplex mode the PHY must wait for transmit to finish before sending a receive frame to the MAC.
- Also the PHY must be sure that the MAC is not about to start transmission before it sends a receive frame to the MAC.
- The PHY does this by asserting crs for 1120ns and making sure tx\_en is low before sending a receive frame to the MAC (delineated with rx\_dv)

## Receive frame buffering in the PHY



- The PHY will have to store an entire receive frame before sending it to the MAC
- If the MAC cannot receive and transmit simultaneously in halfduplex mode the PHY will also have to allow enough time for the MAC to finish any ongoing transmit before sending it receive data
- So additionally the PHY may need to buffer enough of a second receive frame to cope with a latency of two IPG's and a maximum length frame at 100Mbit/s, I.e. about 125us worth
- Define two modes of operation for the EFM PHY
  - One when it waits for MAC transmission to stop before sending it receive data
  - Another when it does not



# Why Wait 1120ns before sending receive data?



- Although the MAC checks crs before starting transmission there is window before it starts transmission when it stops checking crs.
- If crs is asserted during this window the MAC will start transmission regardless. Therefore the PHY must check for tx\_en low for a while to make sure it has not asserted crs during this window.
- This window is never greater than an IPG (960ns at 100Mbit/s)
- Clause 21.8 says 16 bit times (160ns at 100Mbit/s) should be allowed for the MAC to recognise crs
- 960 + 160 = 1120

## Benefits/Costs of half-duplex deferral



- Benefits
  - No change to existing MAC-PHY interface specification
  - No change to 802.3 MAC or MAC Control specification
  - All 10/100 MAC's already support half-duplex operation
  - Supports data rate of 100Mbps aggregate for all MAC's and 100Mbps full-duplex for MAC's that are capable of receiving while transmitting in half-duplex mode
- Costs
  - Need to buffer a transmit frame in the PHY (1522 bytes)
  - Need to buffer a receive frame (1522 bytes) plus part of the next receive frame in the PHY (125us worth)
  - Deferred transmission MIB counter becomes obsolete (see clauses 5.2.2.1.9 and 30.3.1.1.9)

## Other Proposals for rate matching



- Use of 802.3x pause frames
- IPG stretch similar to 802.3ae
- rx and tx clock stretching
- Discard of transmit packets
- Addition of extra flow control signals to the MAC-PHY interface



### **Benefits/Costs of Pause frames**

- Potential to use full duplex 100mbps data rate
- Costs
  - Phy needs to be able to generate pause frames
  - Architecturally impure
  - Need to buffer frames in the PHY
  - Not all MAC's recognize pause frames
  - Phy needs to block pause frames coming from link partner

# Benefits/Costs of IPG stretch (similar to 802.3ae)



- Potential to use full duplex 100mbps data rate
- Costs
  - Need to change MAC spec
  - Open loop control rather than closed loop
  - Need to define a way for the MAC and PHY to determine the data rate and maybe even change it dynamically
  - Need to buffer frames in the PHY

# Benefits/Costs of clock stretching



- Potential to use full duplex 100mbps data rate
- No need to buffer frames in the PHY
- Costs
  - Breaks IEEE Std 802.3 clause 22.2.2 specification.
  - Systems containing multiple MAC's working at different speeds might not work
  - Does not work with SMII and RMII (for half-duplex deferral to work with SMII and RMII the procedure has to be modified so that crs is not asserted while tx\_en is high)

### **Benefits/Costs of Packet** discard



- No change to existing MAC-PHY interface specification
- Potential to use full duplex 100mbps data rate
- Costs
  - It is unacceptable to drop packets
  - Need to buffer frames in the PHY
  - Only works with TCP (because TCP uses frame loss as its congestion indicator)

## Benefits/Costs of adding extra signals for flow control



- Potential to use full duplex 100mbps data rate
- No need to buffer frames in PHY
- Costs
  - Change to MAC and MII specification
  - Not supported by existing silicon

## Requirements for rate adaptation



- As few changes to existing MII spec as possible
- Ease of implementation
- Inter-operability with existing silicon
- Data rates of up to 100Mbps
- Low cost
- Does not drop packets

### Conclusion



- Considering the requirements for MAC-PHY rate adaptation the best solution is half-duplex deferral because
  - No changes to MAC or MII
  - Works with existing silicon
  - Does not drop frames
  - Gives adequate data rate
  - The EFM PHY is likely to be large. Buffering 4K bytes of data should not add significantly to its cost.