mirror of
https://github.com/bolucat/Archive.git
synced 2026-04-22 16:07:49 +08:00
92 lines
2.4 KiB
Diff
92 lines
2.4 KiB
Diff
From 9155098547fb1172d4fa536f3f6bc9d42f59d08c Mon Sep 17 00:00:00 2001
|
|
From: Daniel Golle <daniel@makrotopia.org>
|
|
Date: Sat, 22 Apr 2023 03:26:01 +0100
|
|
Subject: [PATCH] net: phy: realtek: setup ALDPS on RTL822x
|
|
|
|
Setup Link Down Power Saving Mode according the DTS property
|
|
just like for RTL821x 1GE PHYs.
|
|
|
|
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|
---
|
|
drivers/net/phy/realtek/realtek_main.c | 11 +++++++++++
|
|
1 file changed, 11 insertions(+)
|
|
|
|
--- a/drivers/net/phy/realtek/realtek_main.c
|
|
+++ b/drivers/net/phy/realtek/realtek_main.c
|
|
@@ -129,6 +129,10 @@
|
|
*/
|
|
#define RTL822X_VND2_C22_REG(reg) (0xa400 + 2 * (reg))
|
|
|
|
+#define RTL8221B_PHYCR1 0xa430
|
|
+#define RTL8221B_PHYCR1_ALDPS_EN BIT(2)
|
|
+#define RTL8221B_PHYCR1_ALDPS_XTAL_OFF_EN BIT(12)
|
|
+
|
|
#define RTL8366RB_POWER_SAVE 0x15
|
|
#define RTL8366RB_POWER_SAVE_ON BIT(12)
|
|
|
|
@@ -175,6 +179,10 @@ struct rtl821x_priv {
|
|
u32 saved_wolopts;
|
|
};
|
|
|
|
+struct rtl822x_priv {
|
|
+ bool enable_aldps;
|
|
+};
|
|
+
|
|
static int rtl821x_read_page(struct phy_device *phydev)
|
|
{
|
|
return __phy_read(phydev, RTL821x_PAGE_SELECT);
|
|
@@ -1025,6 +1033,18 @@ static int rtl822x_write_mmd(struct phy_
|
|
|
|
static int rtl822x_probe(struct phy_device *phydev)
|
|
{
|
|
+ struct device *dev = &phydev->mdio.dev;
|
|
+ struct rtl822x_priv *priv;
|
|
+
|
|
+ priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
|
|
+ if (!priv)
|
|
+ return -ENOMEM;
|
|
+
|
|
+ priv->enable_aldps = of_property_read_bool(dev->of_node,
|
|
+ "realtek,aldps-enable");
|
|
+
|
|
+ phydev->priv = priv;
|
|
+
|
|
if (IS_ENABLED(CONFIG_REALTEK_PHY_HWMON) &&
|
|
phydev->phy_id != RTL_GENERIC_PHYID)
|
|
return rtl822x_hwmon_init(phydev);
|
|
@@ -1032,6 +1052,19 @@ static int rtl822x_probe(struct phy_devi
|
|
return 0;
|
|
}
|
|
|
|
+static int rtl822x_init_phycr1(struct phy_device *phydev, bool no_aldps)
|
|
+{
|
|
+ struct rtl822x_priv *priv = phydev->priv;
|
|
+ u16 val = 0;
|
|
+
|
|
+ if (priv->enable_aldps && !no_aldps)
|
|
+ val = RTL8221B_PHYCR1_ALDPS_EN | RTL8221B_PHYCR1_ALDPS_XTAL_OFF_EN;
|
|
+
|
|
+ return phy_modify_mmd_changed(phydev, MDIO_MMD_VEND2, RTL8221B_PHYCR1,
|
|
+ RTL8221B_PHYCR1_ALDPS_EN |
|
|
+ RTL8221B_PHYCR1_ALDPS_XTAL_OFF_EN, val);
|
|
+}
|
|
+
|
|
static int rtl822xb_config_init(struct phy_device *phydev)
|
|
{
|
|
bool has_2500, has_sgmii;
|
|
@@ -1108,6 +1141,14 @@ static int rtl822xb_config_init(struct p
|
|
if (ret < 0)
|
|
return ret;
|
|
|
|
+ ret = phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x6f11, 0x8020);
|
|
+ if (ret < 0)
|
|
+ return ret;
|
|
+
|
|
+ ret = rtl822x_init_phycr1(phydev, false);
|
|
+ if (ret < 0)
|
|
+ return ret;
|
|
+
|
|
return 0;
|
|
}
|
|
|