Management Data Input/Output

From Infogalactic: the planetary knowledge core
(Redirected from MDIO)
Jump to: navigation, search

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

Management Data Input/Output (MDIO), also known as Serial Management Interface (SMI) or Media Independent Interface Management (MIIM), is a serial bus defined for the Ethernet family of IEEE 802.3 standards for the Media Independent Interface, or MII. The MII connects Media Access Control (MAC) devices with Ethernet physical layer (PHY) circuits. The MAC device controlling the MDIO is called the Station Management Entity (SME).

Relationship with MII

MII has two signal interfaces:

  • A Data interface to the Ethernet MAC, for sending and receiving Ethernet frame data.
  • A PHY management interface, MDIO, used to read and write the control and status registers of the PHY which are used to configure each PHY before operation, and to monitor link status during operation.

Electrical specification

The MDIO interface is implemented by two signals:

  • MDC clock: driven by the MAC device to the PHY.
  • MDIO data: bidirectional, the PHY drives it to provide register data at the end of a read operation.

The bus only supports a single MAC as the master, and can have up to 32 PHY slaves.

The MDC can be periodic, with a minimum period of 400 ns, which corresponds to a maximum frequency of 2.5 MHz. Newer chips, however, allow faster accesses.

The MDIO requires a specific pull-up resistor of 1.5 kΩ to 10 kΩ, taking into account the total worst-case leakage current of 32 PHYs and one MAC.

Bus timing

Before a register access, PHY devices generally require a preamble of 32 ones to be sent by the MAC on the MDIO line. The access consists of 16 control bits, followed by 16 data bits. The control bits consist of 2 start bits, 2 access type bits (read or write), the PHY address (5 bits), the register address (5 bits), and 2 "turnaround" bits.

During a write command, the MAC provides address and data. For a read command, the PHY takes over the MDIO line during the turnaround bit times, supplies the MAC with the register data requested, then releases the MDIO line.

MIIM write and read access

When the MAC drives the MDIO line, it has to guarantee a stable value 10 ns (setup time) before the rising edge of the clock MDC. Further, MDIO has to remain stable 10 ns (hold time) after the rising edge of MDC.

When the PHY drives the MDIO line, the PHY has to provide the MDIO signal between 0 and 300 ns after the rising edge of the clock.[1] Hence, with a minimum clock period of 400 ns (2.5 MHz maximum clock rate) the MAC can safely sample MDIO during the second half of the low cycle of the clock..

MDIO Packet Format

PRE_32 32-bits of '1'
ST 2-bits of '01'
OP 2-bits of Opcode
PA5 5-bits of port address
DA5 5-bits of device address
TA 2-bits of turn-around
D16 16-bits of address or data (depending on OP)
Z tristate MDIO

Commands

IEEE 802.3 Part [2] use different opcodes and start sequences. Opcodes 00(set address) and 11(read)/01(write)/10(read increment) are used as two serial transactions to read and write registers.

References

  1. Lua error in package.lua at line 80: module 'strict' not found.
  2. Lua error in package.lua at line 80: module 'strict' not found.