735-v5.14-09-net-dsa-qca8k-add-support-for-qca8327-switch.patch 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. From 6e82a457e06252b59102486767539cc9c2aba60b Mon Sep 17 00:00:00 2001
  2. From: Ansuel Smith <[email protected]>
  3. Date: Fri, 14 May 2021 22:59:59 +0200
  4. Subject: [PATCH] net: dsa: qca8k: add support for qca8327 switch
  5. qca8327 switch is a low tier version of the more recent qca8337.
  6. It does share the same regs used by the qca8k driver and can be
  7. supported with minimal change.
  8. Signed-off-by: Ansuel Smith <[email protected]>
  9. Reviewed-by: Andrew Lunn <[email protected]>
  10. Reviewed-by: Vladimir Oltean <[email protected]>
  11. Reviewed-by: Florian Fainelli <[email protected]>
  12. Signed-off-by: David S. Miller <[email protected]>
  13. ---
  14. drivers/net/dsa/qca8k.c | 23 ++++++++++++++++++++---
  15. drivers/net/dsa/qca8k.h | 6 ++++++
  16. 2 files changed, 26 insertions(+), 3 deletions(-)
  17. --- a/drivers/net/dsa/qca8k.c
  18. +++ b/drivers/net/dsa/qca8k.c
  19. @@ -1533,6 +1533,7 @@ static const struct dsa_switch_ops qca8k
  20. static int
  21. qca8k_sw_probe(struct mdio_device *mdiodev)
  22. {
  23. + const struct qca8k_match_data *data;
  24. struct qca8k_priv *priv;
  25. u32 id;
  26. @@ -1560,6 +1561,11 @@ qca8k_sw_probe(struct mdio_device *mdiod
  27. gpiod_set_value_cansleep(priv->reset_gpio, 0);
  28. }
  29. + /* get the switches ID from the compatible */
  30. + data = of_device_get_match_data(&mdiodev->dev);
  31. + if (!data)
  32. + return -ENODEV;
  33. +
  34. /* read the switches ID register */
  35. id = qca8k_read(priv, QCA8K_REG_MASK_CTRL);
  36. if (id < 0)
  37. @@ -1567,8 +1573,10 @@ qca8k_sw_probe(struct mdio_device *mdiod
  38. id >>= QCA8K_MASK_CTRL_ID_S;
  39. id &= QCA8K_MASK_CTRL_ID_M;
  40. - if (id != QCA8K_ID_QCA8337)
  41. + if (id != data->id) {
  42. + dev_err(&mdiodev->dev, "Switch id detected %x but expected %x", id, data->id);
  43. return -ENODEV;
  44. + }
  45. priv->ds = devm_kzalloc(&mdiodev->dev, sizeof(*priv->ds), GFP_KERNEL);
  46. if (!priv->ds)
  47. @@ -1634,9 +1642,18 @@ static int qca8k_resume(struct device *d
  48. static SIMPLE_DEV_PM_OPS(qca8k_pm_ops,
  49. qca8k_suspend, qca8k_resume);
  50. +static const struct qca8k_match_data qca832x = {
  51. + .id = QCA8K_ID_QCA8327,
  52. +};
  53. +
  54. +static const struct qca8k_match_data qca833x = {
  55. + .id = QCA8K_ID_QCA8337,
  56. +};
  57. +
  58. static const struct of_device_id qca8k_of_match[] = {
  59. - { .compatible = "qca,qca8334" },
  60. - { .compatible = "qca,qca8337" },
  61. + { .compatible = "qca,qca8327", .data = &qca832x },
  62. + { .compatible = "qca,qca8334", .data = &qca833x },
  63. + { .compatible = "qca,qca8337", .data = &qca833x },
  64. { /* sentinel */ },
  65. };
  66. --- a/drivers/net/dsa/qca8k.h
  67. +++ b/drivers/net/dsa/qca8k.h
  68. @@ -15,6 +15,8 @@
  69. #define QCA8K_NUM_PORTS 7
  70. #define QCA8K_MAX_MTU 9000
  71. +#define PHY_ID_QCA8327 0x004dd034
  72. +#define QCA8K_ID_QCA8327 0x12
  73. #define PHY_ID_QCA8337 0x004dd036
  74. #define QCA8K_ID_QCA8337 0x13
  75. @@ -213,6 +215,10 @@ struct ar8xxx_port_status {
  76. int enabled;
  77. };
  78. +struct qca8k_match_data {
  79. + u8 id;
  80. +};
  81. +
  82. struct qca8k_priv {
  83. struct regmap *regmap;
  84. struct mii_bus *bus;