2023-11-07 13:47:15 +00:00
|
|
|
From 1d37f4ee9b9588a62bfc87419c8a6d9ef989aa9c Mon Sep 17 00:00:00 2001
|
2022-08-20 10:30:50 +00:00
|
|
|
From: Robert Marko <robimarko@gmail.com>
|
2023-11-07 13:47:15 +00:00
|
|
|
Date: Tue, 7 Nov 2023 12:23:09 +0100
|
|
|
|
Subject: [PATCH 1/3] qca807x: add a LED quirk for Xiaomi AX9000
|
2022-08-20 10:30:50 +00:00
|
|
|
|
|
|
|
Xiaomi AX9000 has a single LED for each of 4 gigabit ethernet ports that
|
|
|
|
are connected to QCA8075, and that LED is connected to the 100M LED pin.
|
|
|
|
|
|
|
|
So, by default it will only work when in 10 or 100Mbit mode, this is quite
|
|
|
|
annoying and makes no sense(If they have connected it to the 1000Mbit LED
|
|
|
|
pin then it would have worked for 10/100 by default as well).
|
|
|
|
|
|
|
|
So, to solve this add a check for system compatible as we cant parse if
|
|
|
|
from DTS in any other way and set the 100M LED to blink on 1000Base-T
|
|
|
|
as well.
|
|
|
|
|
|
|
|
Signed-off-by: Robert Marko <robimarko@gmail.com>
|
|
|
|
---
|
2023-11-07 13:47:15 +00:00
|
|
|
include/hsl/phy/malibu_phy.h | 2 ++
|
|
|
|
src/hsl/phy/malibu_phy.c | 9 +++++++++
|
|
|
|
2 files changed, 11 insertions(+)
|
2022-08-20 10:30:50 +00:00
|
|
|
|
|
|
|
--- a/include/hsl/phy/malibu_phy.h
|
|
|
|
+++ b/include/hsl/phy/malibu_phy.h
|
|
|
|
@@ -94,6 +94,7 @@ extern "C"
|
|
|
|
#define MALIBU_DAC_CTRL_MASK 0x380
|
|
|
|
#define MALIBU_DAC_CTRL_VALUE 0x280
|
|
|
|
#define MALIBU_LED_1000_CTRL1_100_10_MASK 0x30
|
|
|
|
+#define MALIBU_LED_100_CTRL1_1000_MASK 0x40
|
|
|
|
|
|
|
|
#define MALIBU_PHY_EEE_ADV_100M 0x0002
|
|
|
|
#define MALIBU_PHY_EEE_ADV_1000M 0x0004
|
|
|
|
@@ -118,6 +119,7 @@ extern "C"
|
|
|
|
#define MALIBU_PHY_MMD7_EGRESS_COUNTER_HIGH 0x802d
|
|
|
|
#define MALIBU_PHY_MMD7_EGRESS_COUNTER_LOW 0x802e
|
|
|
|
#define MALIBU_PHY_MMD7_EGRESS_ERROR_COUNTER 0x802f
|
|
|
|
+#define MALIBU_PHY_MMD7_LED_100_CTRL1 0x8074
|
|
|
|
#define MALIBU_PHY_MMD7_LED_1000_CTRL1 0x8076
|
|
|
|
|
|
|
|
|
|
|
|
--- a/src/hsl/phy/malibu_phy.c
|
|
|
|
+++ b/src/hsl/phy/malibu_phy.c
|
|
|
|
@@ -15,6 +15,8 @@
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
+#include <linux/of.h>
|
|
|
|
+
|
|
|
|
#include "sw.h"
|
|
|
|
#include "fal_port_ctrl.h"
|
|
|
|
#include "hsl_api.h"
|
2023-11-07 13:47:15 +00:00
|
|
|
@@ -1809,6 +1811,13 @@ malibu_phy_hw_init(a_uint32_t dev_id, a_
|
|
|
|
hsl_phy_modify_mmd(dev_id, phy_addr, A_FALSE, MALIBU_PHY_MMD7_NUM,
|
|
|
|
MALIBU_PHY_MMD7_LED_1000_CTRL1, MALIBU_LED_1000_CTRL1_100_10_MASK,
|
|
|
|
MALIBU_LED_1000_CTRL1_100_10_MASK);
|
2022-08-20 10:30:50 +00:00
|
|
|
+ if (of_machine_is_compatible("xiaomi,ax9000")) {
|
|
|
|
+ /* add 1000M link LED behavior for Xiaomi AX9000 */
|
2023-11-07 13:47:15 +00:00
|
|
|
+ hsl_phy_modify_mmd(dev_id, phy_addr, A_FALSE, MALIBU_PHY_MMD7_NUM,
|
|
|
|
+ MALIBU_PHY_MMD7_LED_100_CTRL1,
|
|
|
|
+ MALIBU_LED_100_CTRL1_1000_MASK,
|
|
|
|
+ MALIBU_LED_100_CTRL1_1000_MASK);
|
2022-08-20 10:30:50 +00:00
|
|
|
+ }
|
|
|
|
/*disable Extended next page*/
|
2023-11-07 13:47:15 +00:00
|
|
|
hsl_phy_modify_mii(dev_id, phy_addr, MALIBU_AUTONEG_ADVERT,
|
|
|
|
MALIBU_EXTENDED_NEXT_PAGE_EN, 0);
|