Lines Matching full:phydev
122 static int dp83822_ack_interrupt(struct phy_device *phydev) in dp83822_ack_interrupt() argument
126 err = phy_read(phydev, MII_DP83822_MISR1); in dp83822_ack_interrupt()
130 err = phy_read(phydev, MII_DP83822_MISR2); in dp83822_ack_interrupt()
137 static int dp83822_set_wol(struct phy_device *phydev, in dp83822_set_wol() argument
140 struct net_device *ndev = phydev->attached_dev; in dp83822_set_wol()
153 phy_write_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_DA1, in dp83822_set_wol()
155 phy_write_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_DA2, in dp83822_set_wol()
157 phy_write_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_DA3, in dp83822_set_wol()
160 value = phy_read_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
168 phy_write_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
171 phy_write_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
174 phy_write_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
183 phy_read(phydev, MII_DP83822_MISR2); in dp83822_set_wol()
188 return phy_write_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
191 return phy_clear_bits_mmd(phydev, DP83822_DEVADDR, in dp83822_set_wol()
196 static void dp83822_get_wol(struct phy_device *phydev, in dp83822_get_wol() argument
205 value = phy_read_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_CFG); in dp83822_get_wol()
211 sopass_val = phy_read_mmd(phydev, DP83822_DEVADDR, in dp83822_get_wol()
216 sopass_val = phy_read_mmd(phydev, DP83822_DEVADDR, in dp83822_get_wol()
221 sopass_val = phy_read_mmd(phydev, DP83822_DEVADDR, in dp83822_get_wol()
234 static int dp83822_config_intr(struct phy_device *phydev) in dp83822_config_intr() argument
236 struct dp83822_private *dp83822 = phydev->priv; in dp83822_config_intr()
241 if (phydev->interrupts == PHY_INTERRUPT_ENABLED) { in dp83822_config_intr()
242 misr_status = phy_read(phydev, MII_DP83822_MISR1); in dp83822_config_intr()
256 err = phy_write(phydev, MII_DP83822_MISR1, misr_status); in dp83822_config_intr()
260 misr_status = phy_read(phydev, MII_DP83822_MISR2); in dp83822_config_intr()
274 err = phy_write(phydev, MII_DP83822_MISR2, misr_status); in dp83822_config_intr()
278 physcr_status = phy_read(phydev, MII_DP83822_PHYSCR); in dp83822_config_intr()
285 err = phy_write(phydev, MII_DP83822_MISR1, 0); in dp83822_config_intr()
289 err = phy_write(phydev, MII_DP83822_MISR2, 0); in dp83822_config_intr()
293 physcr_status = phy_read(phydev, MII_DP83822_PHYSCR); in dp83822_config_intr()
300 return phy_write(phydev, MII_DP83822_PHYSCR, physcr_status); in dp83822_config_intr()
303 static int dp8382x_disable_wol(struct phy_device *phydev) in dp8382x_disable_wol() argument
305 return phy_clear_bits_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_CFG, in dp8382x_disable_wol()
310 static int dp83822_read_status(struct phy_device *phydev) in dp83822_read_status() argument
312 struct dp83822_private *dp83822 = phydev->priv; in dp83822_read_status()
313 int status = phy_read(phydev, MII_DP83822_PHYSTS); in dp83822_read_status()
319 phydev->speed = SPEED_UNKNOWN; in dp83822_read_status()
320 phydev->duplex = DUPLEX_UNKNOWN; in dp83822_read_status()
322 ctrl2 = phy_read(phydev, MII_DP83822_CTRL_2); in dp83822_read_status()
327 ret = phy_write(phydev, MII_DP83822_CTRL_2, in dp83822_read_status()
335 ret = genphy_read_status(phydev); in dp83822_read_status()
343 phydev->duplex = DUPLEX_FULL; in dp83822_read_status()
345 phydev->duplex = DUPLEX_HALF; in dp83822_read_status()
348 phydev->speed = SPEED_10; in dp83822_read_status()
350 phydev->speed = SPEED_100; in dp83822_read_status()
355 static int dp83822_config_init(struct phy_device *phydev) in dp83822_config_init() argument
357 struct dp83822_private *dp83822 = phydev->priv; in dp83822_config_init()
358 struct device *dev = &phydev->mdio.dev; in dp83822_config_init()
365 if (phy_interface_is_rgmii(phydev)) { in dp83822_config_init()
366 rx_int_delay = phy_get_internal_delay(phydev, dev, NULL, 0, in dp83822_config_init()
374 tx_int_delay = phy_get_internal_delay(phydev, dev, NULL, 0, in dp83822_config_init()
382 err = phy_set_bits_mmd(phydev, DP83822_DEVADDR, in dp83822_config_init()
390 err = phy_modify(phydev, MII_DP83822_CTRL_2, in dp83822_config_init()
396 linkmode_and(phydev->advertising, phydev->advertising, in dp83822_config_init()
397 phydev->supported); in dp83822_config_init()
400 phydev->supported); in dp83822_config_init()
402 phydev->advertising); in dp83822_config_init()
404 phydev->supported); in dp83822_config_init()
406 phydev->supported); in dp83822_config_init()
408 phydev->advertising); in dp83822_config_init()
410 phydev->advertising); in dp83822_config_init()
413 bmcr = phy_read(phydev, MII_BMCR); in dp83822_config_init()
418 err = phy_modify(phydev, MII_BMCR, BMCR_ANENABLE, 0); in dp83822_config_init()
422 phydev->autoneg = AUTONEG_DISABLE; in dp83822_config_init()
424 phydev->supported); in dp83822_config_init()
426 phydev->advertising); in dp83822_config_init()
429 err = phy_modify_changed(phydev, MII_ADVERTISE, in dp83822_config_init()
437 err = phy_set_bits_mmd(phydev, DP83822_DEVADDR, in dp83822_config_init()
444 return dp8382x_disable_wol(phydev); in dp83822_config_init()
447 static int dp8382x_config_init(struct phy_device *phydev) in dp8382x_config_init() argument
449 return dp8382x_disable_wol(phydev); in dp8382x_config_init()
452 static int dp83822_phy_reset(struct phy_device *phydev) in dp83822_phy_reset() argument
456 err = phy_write(phydev, MII_DP83822_RESET_CTRL, DP83822_SW_RESET); in dp83822_phy_reset()
460 return phydev->drv->config_init(phydev); in dp83822_phy_reset()
464 static int dp83822_of_init(struct phy_device *phydev) in dp83822_of_init() argument
466 struct dp83822_private *dp83822 = phydev->priv; in dp83822_of_init()
467 struct device *dev = &phydev->mdio.dev; in dp83822_of_init()
483 static int dp83822_of_init(struct phy_device *phydev) in dp83822_of_init() argument
489 static int dp83822_read_straps(struct phy_device *phydev) in dp83822_read_straps() argument
491 struct dp83822_private *dp83822 = phydev->priv; in dp83822_read_straps()
495 val = phy_read_mmd(phydev, DP83822_DEVADDR, MII_DP83822_SOR1); in dp83822_read_straps()
514 static int dp83822_probe(struct phy_device *phydev) in dp83822_probe() argument
519 dp83822 = devm_kzalloc(&phydev->mdio.dev, sizeof(*dp83822), in dp83822_probe()
524 phydev->priv = dp83822; in dp83822_probe()
526 ret = dp83822_read_straps(phydev); in dp83822_probe()
530 dp83822_of_init(phydev); in dp83822_probe()
533 phydev->port = PORT_FIBRE; in dp83822_probe()
538 static int dp83822_suspend(struct phy_device *phydev) in dp83822_suspend() argument
542 value = phy_read_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_CFG); in dp83822_suspend()
545 genphy_suspend(phydev); in dp83822_suspend()
550 static int dp83822_resume(struct phy_device *phydev) in dp83822_resume() argument
554 genphy_resume(phydev); in dp83822_resume()
556 value = phy_read_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_CFG); in dp83822_resume()
558 phy_write_mmd(phydev, DP83822_DEVADDR, MII_DP83822_WOL_CFG, value | in dp83822_resume()