chry_phy_lan8720.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2024, sakumisu
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "chry_phy.h"
  7. #define LAN8720_PSCSR 31 /* PHY Special Control/Status Register */
  8. #define LAN8720_PSCSR_DUPLEX_STATUS (0x10U)
  9. /*
  10. * SPEED (RO)
  11. *
  12. * HCDSPEED value:
  13. * 01 = 10BASE-T
  14. * 10 = 100BASE-TX
  15. */
  16. #define LAN8720_PSCSR_SPEED_STATUS (0xCU)
  17. void lan8720_phy_init(struct chry_phy_device *phydev, struct chry_phy_config *config)
  18. {
  19. }
  20. void lan8720_phy_get_status(struct chry_phy_device *phydev, struct chry_phy_status *status)
  21. {
  22. uint16_t regval;
  23. regval = phydev->mdio_read(phydev, phydev->phy_addr, MII_BMSR);
  24. status->link = regval & BMSR_LINKSTATUS;
  25. if (status->link) {
  26. regval = phydev->mdio_read(phydev, phydev->phy_addr, LAN8720_PSCSR);
  27. status->duplex = regval & LAN8720_PSCSR_DUPLEX_STATUS;
  28. switch ((regval & LAN8720_PSCSR_SPEED_STATUS) >> 2) {
  29. case 1:
  30. status->speed = 10;
  31. break;
  32. case 2:
  33. status->speed = 100;
  34. break;
  35. default:
  36. break;
  37. }
  38. }
  39. }
  40. const struct chry_phy_driver lan8720_driver = {
  41. .phy_id = 0x0007C0F0,
  42. .phy_id_mask = 0xFFFFFFF0,
  43. .phy_name = "LAN8720",
  44. .phy_desc = "MICROCHIP LAN8720 Ethernet PHY",
  45. .phy_init = lan8720_phy_init,
  46. .phy_get_status = lan8720_phy_get_status,
  47. };