704-include-linux-add-phy-hsgmii-mode.patch 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. From 9d9bf16aa8d966834ac1280f96c37d22552c33d1 Mon Sep 17 00:00:00 2001
  2. From: Birger Koblitz <[email protected]>
  3. Date: Wed, 8 Sep 2021 16:13:18 +0200
  4. Subject: phy: Add PHY hsgmii mode
  5. This adds RTL93xx-specific MAC configuration routines that allow also configuration
  6. of 10GBit links for phylink. There is support for the Realtek-specific HISGMI
  7. protocol.
  8. Submitted-by: Birger Koblitz <[email protected]>
  9. ---
  10. drivers/net/phy/phylink.c | 2 ++
  11. include/linux/phy.h | 3 +++
  12. 2 file changed, 5 insertions(+)
  13. --- a/drivers/net/phy/phy-core.c
  14. +++ b/drivers/net/phy/phy-core.c
  15. @@ -124,6 +124,7 @@ int phy_interface_num_ports(phy_interfac
  16. case PHY_INTERFACE_MODE_MOCA:
  17. case PHY_INTERFACE_MODE_TRGMII:
  18. case PHY_INTERFACE_MODE_USXGMII:
  19. + case PHY_INTERFACE_MODE_HSGMII:
  20. case PHY_INTERFACE_MODE_SGMII:
  21. case PHY_INTERFACE_MODE_SMII:
  22. case PHY_INTERFACE_MODE_1000BASEX:
  23. --- a/drivers/net/phy/phylink.c
  24. +++ b/drivers/net/phy/phylink.c
  25. @@ -410,6 +410,7 @@ void phylink_get_linkmodes(unsigned long
  26. case PHY_INTERFACE_MODE_XGMII:
  27. case PHY_INTERFACE_MODE_RXAUI:
  28. + case PHY_INTERFACE_MODE_HSGMII:
  29. case PHY_INTERFACE_MODE_XAUI:
  30. case PHY_INTERFACE_MODE_10GBASER:
  31. case PHY_INTERFACE_MODE_10GKR:
  32. @@ -665,6 +666,7 @@ static int phylink_parse_mode(struct phy
  33. fallthrough;
  34. case PHY_INTERFACE_MODE_USXGMII:
  35. case PHY_INTERFACE_MODE_10GKR:
  36. + case PHY_INTERFACE_MODE_HSGMII:
  37. case PHY_INTERFACE_MODE_10GBASER:
  38. phylink_set(pl->supported, 10baseT_Half);
  39. phylink_set(pl->supported, 10baseT_Full);
  40. --- a/include/linux/phy.h
  41. +++ b/include/linux/phy.h
  42. @@ -141,6 +141,7 @@ typedef enum {
  43. PHY_INTERFACE_MODE_XGMII,
  44. PHY_INTERFACE_MODE_XLGMII,
  45. PHY_INTERFACE_MODE_MOCA,
  46. + PHY_INTERFACE_MODE_HSGMII,
  47. PHY_INTERFACE_MODE_QSGMII,
  48. PHY_INTERFACE_MODE_TRGMII,
  49. PHY_INTERFACE_MODE_100BASEX,
  50. @@ -248,6 +249,8 @@ static inline const char *phy_modes(phy_
  51. return "xlgmii";
  52. case PHY_INTERFACE_MODE_MOCA:
  53. return "moca";
  54. + case PHY_INTERFACE_MODE_HSGMII:
  55. + return "hsgmii";
  56. case PHY_INTERFACE_MODE_QSGMII:
  57. return "qsgmii";
  58. case PHY_INTERFACE_MODE_TRGMII: