Media-independent interface


The media-independent interface was originally defined as a standard interface to connect a Fast Ethernet medium access control block to a PHY chip. The MII is standardized by IEEE 802.3u and connects different types of PHYs to MACs. Being media independent means that different types of PHY devices for connecting to different media can be used without redesigning or replacing the MAC hardware. Thus any MAC may be used with any PHY, independent of the network signal transmission medium.
The MII can be used to connect a MAC to an external PHY using a pluggable connector or directly to a PHY chip on the same PCB. On older PCs the CNR connector Type B carried MII signals.
Network data on the interface is framed using the IEEE Ethernet standard. As such it consists of a preamble, start frame delimiter, Ethernet headers, protocol-specific data and a cyclic redundancy check. The original MII transfers network data using 4-bit nibbles in each direction. The data is clocked at 25 MHz to achieve throughput. The original MII design has been extended to support reduced signals and increased speeds. The aberration xMII stands for generic media-independent interface, which includes:
  • Reduced media-independent interface
  • Gigabit media-independent interface
  • Reduced gigabit media-independent interface
  • Serial media-independent interface
  • Serial gigabit media-independent interface
  • High serial gigabit media-independent interface
  • Quad serial gigabit media-independent interface
  • [|Penta serial gigabit media-independent interface]
  • 10-gigabit media-independent interface
The Management Data Input/Output serial bus is a subset of the MII that is used to transfer management information between MAC and PHY. At power up, using autonegotiation, the PHY usually adapts to whatever it is connected to unless settings are altered via the MDIO interface.

Standard MII

The standard MII features a small set of registers:
  • Basic Mode Configuration
  • Status Word
  • PHY Identifier
  • Auto-Negotiation Advertisement
  • Auto-Negotiation Link Partner Base Page Ability
  • Auto-Negotiation Expansion
  • Auto-Negotiation Next Page Transmit
  • Auto-Negotiation Link Partner Received Next Page
  • MASTER-SLAVE Control Register
  • MASTER-SLAVE Status Register
  • PSE Control register
  • PSE Status register
  • MMD Access Control Register
  • MMD Access Address Data Register
Register #15 is reserved; registers #16 through #31 are vendor-specific. The registers are used to configure the device and to query the current operating mode.
The MII Status Word is the most useful datum, since it may be used to detect whether an Ethernet NIC is connected to a network. It contains a bit field with the following information:
Bit valueMeaning
0x8000Capable of 100BASE-T4
0x6000Capable of 100BASE-TX full/half duplex
0x1800Capable of 10BASE-T full/half duplex
0x0600Capable of 100BASE-T2 full/half duplex
0x0100Extended status register exists
0x0080Capable of unidirectional operation
0x0040Management frame preamble suppression permitted
0x0020Autonegotiation complete
0x0010Remote fault
0x0008Capable of Autonegotiation
0x0004Link established
0x0002Jabber detected
0x0001Extended MII registers exist

Transmitter signals

The transmit clock is a free-running clock generated by the PHY based on the link speed. The remaining transmit signals are driven by the MAC synchronously on the rising edge of TX_CLK. This arrangement allows the MAC to operate without having to be aware of the link speed. The transmit enable signal is held high during frame transmission and low when the transmitter is idle.
Transmit error may be raised for one or more clock periods during frame transmission to request the PHY to deliberately corrupt the frame in some visible way that precludes it from being received as valid. This may be used to abort a frame when some problem is detected after transmission has already started. The MAC may omit the signal if it has no use for this functionality, in which case the signal should be tied low for the PHY.
More recently, raising transmit error outside frame transmission is used to indicate the transmit data lines are being used for special-purpose signalling. Specifically, the data value 0b0001 is used to request an EEE-capable PHY to enter low power mode.

Receiver signals

The first seven receiver signals are entirely analogous to the transmitter signals, except RX_ER is not optional and used to indicate the received signal could not be decoded to valid data. The receive clock is recovered from the incoming signal during frame reception. When no clock can be recovered, the PHY must present a free-running clock as a substitute.
The receive data valid signal is not required to go high immediately when the frame starts, but must do so in time to ensure the "start of frame delimiter" byte is included in the received data. Some of the preamble nibbles may be lost.
Similar to transmit, raising RX_ER outside a frame is used for special signaling. For receive, two data values are defined: 0b0001 to indicate the link partner is in EEE low power mode, and 0b1110 for a false carrier indication.
The CRS and COL signals are asynchronous to the receive clock, and are only meaningful in half-duplex mode. Carrier sense is high when transmitting, receiving, or the medium is otherwise sensed as being in use. If a collision is detected, COL also goes high while the collision persists.
In addition, the MAC may weakly pull-up the COL signal, allowing the combination of COL high with CRS low to serve as indication of an absent/disconnected PHY.

Management signals

Signal nameDescriptionDirection
MDIOManagement dataBidirectional
MDCManagement data clockMAC to PHY

MDC and MDIO constitute a synchronous serial data interface similar to I²C. As with I²C, the interface is a multidrop bus so MDC and MDIO can be shared among multiple PHYs.

Limitations

The interface requires 18 signals, out of which only two can be shared among multiple PHYs. This presents a problem, especially for multiport devices; for example, an eight-port switch using MII would need 8 × 16 + 2 = 130 signals.

Reduced media-independent interface

Reduced media-independent interface is a standard which was developed to reduce the number of signals required to connect a PHY to a MAC. This helps reduce cost and complexity for network hardware, especially in the context of microcontrollers with built-in MAC, FPGAs, multiport switches or repeaters, and PC motherboard chipsets. The following changes from the MII standard cut the number of required signals from 18 in half to only 9:
  • MII's two clocks are replaced by a single clock used as a reference for both receiver and transmitter signals.
  • The clock frequency is doubled from 25 MHz to 50 MHz, while both data paths are halved from 4 bits to 2 bits. Data is clocked out 2 bits at a time or 1 bit at a time for serial network interface mode. Data is still sampled on the rising edge only.
  • RXDV and CRS signals are multiplexed into one signal.
  • The COL signal is removed.
  • RX_ER became optional.
Additionally on multiport devices, MDIO, MDC, and REF_CLK may be shared, leaving 6 or 7 pins per port.
Signal nameDescriptionDirection
REF_CLKContinuous 50 MHz reference clockReference clock may be an input on both devices from an external clock source, or may be driven from the MAC to the PHY, or may be driven from the PHY to the MAC
TXD0Transmit data bit 0 MAC to PHY
TXD1Transmit data bit 1MAC to PHY
TX_ENWhen high, clock data on TXD0 and TXD1 to the transmitterMAC to PHY
RXD0Receive data bit 0 PHY to MAC
RXD1Receive data bit 1PHY to MAC
CRS_DVCarrier Sense and RX_Data Valid multiplexed on alternate clock cycles. In mode, it alternates every 10 clock cycles.PHY to MAC
RX_ERReceive error PHY to MAC
MDIOManagement dataBidirectional
MDCManagement data clock.MAC to PHY

Note: the REF_CLK operates at 50 MHz in both mode and mode. The transmitting side must keep all signals valid for 10 clock cycles in mode. The receiver samples the input signals only every 10 cycles in mode.

Limitations

There is no signal which defines whether the interface is in full or half duplex mode, but both the MAC and the PHY need to agree. This must instead be communicated over the serial MDIO/MDC interface. There is also no signal which defines whether the interface is in 10 or mode, so this must also be handled using the MDIO/MDC interface. Version 1.2 of the RMII Consortium specification states that its MDIO/MDC interface is identical to that specified for MII in IEEE 802.3u. Current revisions of IEEE 802.3 specify a standard MDIO/MDC mechanism for negotiating and configuring the link's speed and duplex mode, but it is possible that older PHY devices might have been designed against obsolete versions of the standard, and may therefore use proprietary methods to set speed and duplex.
The lack of the RX_ER signal which is not connected on some MACs is dealt with by data replacement on some PHYs to invalidate the CRC. The missing COL signal is derived from AND-ing together the TX_EN and the decoded CRS signal from the CRS_DV line in half duplex mode. This means a slight modification of the definition of CRS: On MII, CRS is asserted for both Rx and Tx frames; on RMII only for Rx frames. This has the consequence that on RMII the two error conditions no carrier and lost carrier cannot be detected, and it is difficult or impossible to support shared media such as 10BASE2 or 10BASE5.
Since the RMII standard neglected to stipulate that TX_EN should only be sampled on alternate clock cycles, it is not symmetric with CRS_DV and two RMII PHY devices cannot be connected back to back to form a repeater; this is possible, however, with the National DP83848 which supplies the decoded RX_DV as a supplemental signal in RMII mode.