chry_phy_rtl8201.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2024, sakumisu
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "chry_phy.h"
  7. #define RTL8201_RMSR_P7 16 /* RMII Mode Setting Register */
  8. #define RTL8201_PAGESEL 31 /* Page Select Register */
  9. /*
  10. * RG_RMII_CLKDIR (RW)
  11. *
  12. * This Bit Sets the Type of TXC in RMII Mode.
  13. * 0: Output
  14. * 1: Input
  15. */
  16. #define RTL8201_RMSR_P7_RG_RMII_CLKDIR_MASK (0x1000U)
  17. #define RTL8201_RMSR_P7_RG_RMII_CLKDIR_SHIFT (12U)
  18. #define RTL8201_RMSR_P7_RG_RMII_CLKDIR_SET(x) (((uint16_t)(x) << RTL8201_RMSR_P7_RG_RMII_CLKDIR_SHIFT) & RTL8201_RMSR_P7_RG_RMII_CLKDIR_MASK)
  19. #define RTL8201_RMSR_P7_RG_RMII_CLKDIR_GET(x) (((uint16_t)(x)&RTL8201_RMSR_P7_RG_RMII_CLKDIR_MASK) >> RTL8201_RMSR_P7_RG_RMII_CLKDIR_SHIFT)
  20. void rtl8201_phy_init(struct chry_phy_device *phydev, struct chry_phy_config *config)
  21. {
  22. uint16_t regval;
  23. phydev->mdio_write(phydev, phydev->phy_addr, RTL8201_PAGESEL, 7);
  24. regval = phydev->mdio_read(phydev, phydev->phy_addr, RTL8201_RMSR_P7);
  25. regval &= ~RTL8201_RMSR_P7_RG_RMII_CLKDIR_MASK;
  26. regval |= RTL8201_RMSR_P7_RG_RMII_CLKDIR_SET(1);
  27. phydev->mdio_write(phydev, phydev->phy_addr, RTL8201_RMSR_P7, regval);
  28. }
  29. void rtl8201_phy_get_status(struct chry_phy_device *phydev, struct chry_phy_status *status)
  30. {
  31. uint16_t regval;
  32. regval = phydev->mdio_read(phydev, phydev->phy_addr, MII_BMSR);
  33. status->link = regval & BMSR_LINKSTATUS;
  34. if (status->link) {
  35. regval = phydev->mdio_read(phydev, phydev->phy_addr, MII_BMCR);
  36. status->speed = regval & BMCR_SPEED100 ? 100 : 10;
  37. status->duplex = regval & BMCR_FULLDPLX;
  38. }
  39. }
  40. const struct chry_phy_driver rtl8201_driver = {
  41. .phy_id = 0x001CC810,
  42. .phy_id_mask = 0xFFFFFFF0,
  43. .phy_name = "RTL8201",
  44. .phy_desc = "REALTEK RTL8201 Ethernet PHY",
  45. .phy_init = rtl8201_phy_init,
  46. .phy_get_status = rtl8201_phy_get_status,
  47. };