freebsd-skq/sys/dev/mdio/mdio_if.m
adrian af0e70ec17 [mdio] Add MDIO support for "extended" registers as defined by IEEE 802.3 Clause 45.
IEEE 802.3 Clause 45 added backwards-compatible support for 2^16 PHY registers
through the addition of an additional device address frame.

Clause 45 addressing is used in 10Gbe PHYs, 802.3az EEE registers, etc. It may
make sense to provide a similar extension to the miibus interface, but I've
refrained from unilaterally doing so here.

Submitted by:	Landon Fuller <landon@landonf.org>
Differential Revision:	https://reviews.freebsd.org/D4607
2015-12-26 17:22:02 +00:00

92 lines
1.8 KiB
Objective-C

# $FreeBSD$
#include <sys/bus.h>
INTERFACE mdio;
CODE {
#include <dev/mdio/mdio.h>
static int
mdio_null_readextreg(device_t dev, int phy, int devad, int reg)
{
if (devad == MDIO_DEVADDR_NONE)
return (MDIO_READREG(dev, phy, reg));
return (~0U);
}
static int
mdio_null_writeextreg(device_t dev, int phy, int devad, int reg,
int val)
{
if (devad == MDIO_DEVADDR_NONE)
return (MDIO_WRITEREG(dev, phy, reg, val));
return (EINVAL);
}
}
/**
* @brief Read register from device on MDIO bus.
*
* @param dev MDIO bus device.
* @param phy PHY address.
* @param reg The PHY register offset.
*/
METHOD int readreg {
device_t dev;
int phy;
int reg;
};
/**
* @brief Write register to device on MDIO bus.
*
* @param dev MDIO bus device.
* @param phy PHY address.
* @param reg The PHY register offset.
* @param val The value to write at offset @p reg.
*/
METHOD int writereg {
device_t dev;
int phy;
int reg;
int val;
};
/**
* @brief Read extended register from device on MDIO bus.
*
* @param dev MDIO bus device.
* @param phy PHY address.
* @param devad The MDIO IEEE 802.3 Clause 45 device address, or
* MDIO_DEVADDR_NONE to request Clause 22 register addressing.
* @param reg The PHY register offset.
*/
METHOD int readextreg {
device_t dev;
int phy;
int devad;
int reg;
} DEFAULT mdio_null_readextreg;
/**
* @brief Write extended register to device on MDIO bus.
*
* @param dev MDIO bus device.
* @param phy PHY address.
* @param devad The MDIO IEEE 802.3 Clause 45 device address, or
* MDIO_DEVADDR_NONE to request Clause 22 register addressing.
* @param reg The PHY register offset.
* @param val The value to write at offset @p reg.
*/
METHOD int writeextreg {
device_t dev;
int phy;
int devad;
int reg;
int val;
} DEFAULT mdio_null_writeextreg;