net: phy: mediatek: Add token ring clear bit operation support
authorSky Huang <skylake.huang@mediatek.com>
Thu, 13 Feb 2025 08:05:52 +0000 (16:05 +0800)
committerJakub Kicinski <kuba@kernel.org>
Tue, 18 Feb 2025 00:22:36 +0000 (16:22 -0800)
Similar to __mtk_tr_set_bits() support. Previously in mtk-ge-soc.c,
we clear some register bits via token ring, which were also implemented
in three __phy_write(). Now we can do the same thing via
__mtk_tr_clr_bits() helper.

Signed-off-by: Sky Huang <skylake.huang@mediatek.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://patch.msgid.link/20250213080553.921434-5-SkyLake.Huang@mediatek.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/phy/mediatek/mtk-ge-soc.c
drivers/net/phy/mediatek/mtk-phy-lib.c
drivers/net/phy/mediatek/mtk.h

index 37777ad104d87ad2db547dcd3e2ffb6339cf924d..9de6fbb45564ef8d57c33522cab2075f4dc4c376 100644 (file)
 /* FfeUpdGainForce */
 #define FFE_UPDATE_GAIN_FORCE                  BIT(6)
 
+/* ch_addr = 0x2, node_addr = 0xd, data_addr = 0x3 */
+/* TrFreeze */
+#define TR_FREEZE_MASK                         GENMASK(11, 0)
+
 /* ch_addr = 0x2, node_addr = 0xd, data_addr = 0x6 */
 /* SS: Steady-state, KP: Proportional Gain */
 /* SSTrKp100 */
 /* SSTrKf1000Slv */
 #define SS_TR_KF1000_SLAVE_MASK                        GENMASK(6, 4)
 
+/* ch_addr = 0x2, node_addr = 0xd, data_addr = 0x8 */
+/* clear this bit if wanna select from AFE */
+/* Regsigdet_sel_1000 */
+#define EEE1000_SELECT_SIGNAL_DETECTION_FROM_DFE       BIT(4)
+
 /* ch_addr = 0x2, node_addr = 0xd, data_addr = 0xd */
 /* RegEEE_st2TrKf1000 */
 #define EEE1000_STAGE2_TR_KF_MASK              GENMASK(13, 11)
 /* RegEEE100Stg1_tar */
 #define EEE100_LPSYNC_STAGE1_UPDATE_TIMER_MASK GENMASK(8, 0)
 
+/* ch_addr = 0x2, node_addr = 0xd, data_addr = 0x25 */
+/* REGEEE_wake_slv_tr_wait_dfesigdet_en */
+#define WAKE_SLAVE_TR_WAIT_DFE_DETECTION_EN    BIT(11)
+
 #define ANALOG_INTERNAL_OPERATION_MAX_US       20
 #define TXRESERVE_MIN                          0
 #define TXRESERVE_MAX                          7
@@ -805,10 +818,7 @@ static void mt798x_phy_common_finetune(struct phy_device *phydev)
                        FIELD_PREP(FFE_UPDATE_GAIN_FORCE_VAL_MASK, 0x4) |
                                   FFE_UPDATE_GAIN_FORCE);
 
-       /* TrFreeze = 0 (mt7988 default) */
-       __phy_write(phydev, 0x11, 0x0);
-       __phy_write(phydev, 0x12, 0x0);
-       __phy_write(phydev, 0x10, 0x9686);
+       __mtk_tr_clr_bits(phydev, 0x2, 0xd, 0x3, TR_FREEZE_MASK);
 
        __mtk_tr_modify(phydev, 0x2, 0xd, 0x6,
                        SS_TR_KP100_MASK | SS_TR_KF100_MASK |
@@ -1009,10 +1019,8 @@ static void mt798x_phy_eee(struct phy_device *phydev)
                         MTK_PHY_TR_READY_SKIP_AFE_WAKEUP);
 
        phy_select_page(phydev, MTK_PHY_PAGE_EXTENDED_52B5);
-       /* Regsigdet_sel_1000 = 0 */
-       __phy_write(phydev, 0x11, 0xb);
-       __phy_write(phydev, 0x12, 0x0);
-       __phy_write(phydev, 0x10, 0x9690);
+       __mtk_tr_clr_bits(phydev, 0x2, 0xd, 0x8,
+                         EEE1000_SELECT_SIGNAL_DETECTION_FROM_DFE);
 
        __mtk_tr_modify(phydev, 0x2, 0xd, 0xd,
                        EEE1000_STAGE2_TR_KF_MASK,
@@ -1036,10 +1044,8 @@ static void mt798x_phy_eee(struct phy_device *phydev)
                        FIELD_PREP(EEE100_LPSYNC_STAGE1_UPDATE_TIMER_MASK,
                                   0x10));
 
-       /* REGEEE_wake_slv_tr_wait_dfesigdet_en = 0 */
-       __phy_write(phydev, 0x11, 0x1463);
-       __phy_write(phydev, 0x12, 0x0);
-       __phy_write(phydev, 0x10, 0x96ca);
+       __mtk_tr_clr_bits(phydev, 0x2, 0xd, 0x25,
+                         WAKE_SLAVE_TR_WAIT_DFE_DETECTION_EN);
 
        __mtk_tr_modify(phydev, 0x1, 0xf, 0x0,
                        DFE_TAIL_EANBLE_VGA_TRHESH_1000,
index df8fdadcc0f45357e359eac4b2c2f2712fc1a28c..dfd0f4e439a214343e66b7bd0abb7ace8ddc36c6 100644 (file)
@@ -76,6 +76,13 @@ void __mtk_tr_set_bits(struct phy_device *phydev, u8 ch_addr, u8 node_addr,
 }
 EXPORT_SYMBOL_GPL(__mtk_tr_set_bits);
 
+void __mtk_tr_clr_bits(struct phy_device *phydev, u8 ch_addr, u8 node_addr,
+                      u8 data_addr, u32 clr)
+{
+       __mtk_tr_modify(phydev, ch_addr, node_addr, data_addr, clr, 0);
+}
+EXPORT_SYMBOL_GPL(__mtk_tr_clr_bits);
+
 int mtk_phy_read_page(struct phy_device *phydev)
 {
        return __phy_read(phydev, MTK_EXT_PAGE_ACCESS);
index 2d8e5b934a024f6d8466b4c82a8eb7b5132ba5bb..4e4468dc0234411e0bd0919be8ef2b93c01f303e 100644 (file)
@@ -74,6 +74,8 @@ void mtk_tr_modify(struct phy_device *phydev, u8 ch_addr, u8 node_addr,
                   u8 data_addr, u32 mask, u32 set);
 void __mtk_tr_set_bits(struct phy_device *phydev, u8 ch_addr, u8 node_addr,
                       u8 data_addr, u32 set);
+void __mtk_tr_clr_bits(struct phy_device *phydev, u8 ch_addr, u8 node_addr,
+                      u8 data_addr, u32 clr);
 
 int mtk_phy_read_page(struct phy_device *phydev);
 int mtk_phy_write_page(struct phy_device *phydev, int page);