chry_phy_yt8522.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. /*
  2. * Copyright (c) 2024, sakumisu
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "chry_phy.h"
  7. #define YT8522_PHYSTS 0x11 /* PHY Status Register */
  8. #define YT8522_PHYSTS_LINK_STATUS (0x400U)
  9. /*
  10. * SPEED (RO)
  11. *
  12. * Link Speed.
  13. * 11: Reserved 10: 1000Mbps
  14. * 01: 100Mbps 00: 10Mbps
  15. */
  16. #define YT8522_PHYSTS_SPEED_STATUS (0xC000U)
  17. #define YT8522_PHYSTS_DUPLEX_STATUS (0x2000U)
  18. void yt8522_phy_init(struct chry_phy_device *phydev, struct chry_phy_config *config)
  19. {
  20. }
  21. void yt8522_phy_get_status(struct chry_phy_device *phydev, struct chry_phy_status *status)
  22. {
  23. uint16_t regval;
  24. regval = phydev->mdio_read(phydev, phydev->phy_addr, YT8522_PHYSTS);
  25. status->link = regval & YT8522_PHYSTS_LINK_STATUS;
  26. if (status->link) {
  27. status->duplex = regval & YT8522_PHYSTS_DUPLEX_STATUS;
  28. switch ((regval & YT8522_PHYSTS_SPEED_STATUS) >> 14) {
  29. case 0:
  30. status->speed = 10;
  31. break;
  32. case 1:
  33. status->speed = 100;
  34. break;
  35. case 2:
  36. status->speed = 1000;
  37. break;
  38. default:
  39. break;
  40. }
  41. }
  42. }
  43. const struct chry_phy_driver yt8522_driver = {
  44. .phy_id = 0x4F51E900,
  45. .phy_id_mask = 0xFFFFFFC0,
  46. .phy_name = "YT8512/YT8522/YT8531",
  47. .phy_desc = "MOTOR COMM YT8512/YT8522/YT8531 Ethernet PHY",
  48. .phy_init = yt8522_phy_init,
  49. .phy_get_status = yt8522_phy_get_status,
  50. };