#define REALTEK_PHY_ID_RTL8261N 0x001CCAF3
#define REALTEK_PHY_ID_RTL8264B 0x001CC813
+#define REALTEK_PHY_ID_RTL8264 0x001CCAF2
static int rtl826xb_get_features(struct phy_device *phydev)
{
{
case REALTEK_PHY_ID_RTL8261N:
case REALTEK_PHY_ID_RTL8264B:
- phydev_info(phydev, "%s:%u [RTL8261N/RTL826XB] phy_id: 0x%X PHYAD:%d\n", __FUNCTION__, __LINE__, phydev->drv->phy_id, phydev->mdio.addr);
+ case REALTEK_PHY_ID_RTL8264:
+ phydev_info(phydev, "%s:%u [RTL8261N/RTL8264/RTL826XB] phy_id: 0x%X PHYAD:%d\n", __FUNCTION__, __LINE__, phydev->drv->phy_id, phydev->mdio.addr);
#if 1 /* toggle reset */
.aneg_done = rtkphy_c45_aneg_done,
.read_status = rtkphy_c45_read_status,
},
+ {
+ PHY_ID_MATCH_EXACT(REALTEK_PHY_ID_RTL8264),
+ .name = "Realtek RTL8264",
+ .get_features = rtl826xb_get_features,
+ .config_init = rtkphy_config_init,
+ .probe = rtl826xb_probe,
+ .suspend = rtkphy_c45_suspend,
+ .resume = rtkphy_c45_resume,
+ .config_aneg = rtkphy_c45_config_aneg,
+ .aneg_done = rtkphy_c45_aneg_done,
+ .read_status = rtkphy_c45_read_status,
+ },
};
module_phy_driver(rtk_phy_drivers);
static struct mdio_device_id __maybe_unused rtk_phy_tbl[] = {
{ PHY_ID_MATCH_EXACT(REALTEK_PHY_ID_RTL8261N) },
{ PHY_ID_MATCH_EXACT(REALTEK_PHY_ID_RTL8264B) },
+ { PHY_ID_MATCH_EXACT(REALTEK_PHY_ID_RTL8264) },
{ },
};