]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
net: phy: mediatek-ge-soc: Propagate error code correctly in cal_cycle()
authorSkyLake.Huang <skylake.huang@mediatek.com>
Thu, 17 Oct 2024 03:22:13 +0000 (11:22 +0800)
committerAndrew Lunn <andrew@lunn.ch>
Sun, 20 Oct 2024 16:06:47 +0000 (11:06 -0500)
This patch propagates error code correctly in cal_cycle()
and improve with FIELD_GET().

Signed-off-by: SkyLake.Huang <skylake.huang@mediatek.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Signed-off-by: Andrew Lunn <andrew@lunn.ch>
drivers/net/phy/mediatek-ge-soc.c

index 1d7719b6c35196bb0223e5da395e38522b64ad01..a931832b14183e9143f4291e84bf95282cb44965 100644 (file)
 #define   MTK_PHY_CR_TX_AMP_OFFSET_D_MASK      GENMASK(6, 0)
 
 #define MTK_PHY_RG_AD_CAL_COMP                 0x17a
-#define   MTK_PHY_AD_CAL_COMP_OUT_SHIFT                (8)
+#define   MTK_PHY_AD_CAL_COMP_OUT_MASK         GENMASK(8, 8)
 
 #define MTK_PHY_RG_AD_CAL_CLK                  0x17b
 #define   MTK_PHY_DA_CAL_CLK                   BIT(0)
@@ -351,8 +351,10 @@ static int cal_cycle(struct phy_device *phydev, int devad,
 
        phy_clear_bits_mmd(phydev, MDIO_MMD_VEND1, MTK_PHY_RG_AD_CALIN,
                           MTK_PHY_DA_CALIN_FLAG);
-       ret = phy_read_mmd(phydev, MDIO_MMD_VEND1, MTK_PHY_RG_AD_CAL_COMP) >>
-                          MTK_PHY_AD_CAL_COMP_OUT_SHIFT;
+       ret = phy_read_mmd(phydev, MDIO_MMD_VEND1, MTK_PHY_RG_AD_CAL_COMP);
+       if (ret < 0)
+               return ret;
+       ret = FIELD_GET(MTK_PHY_AD_CAL_COMP_OUT_MASK, ret);
        phydev_dbg(phydev, "cal_val: 0x%x, ret: %d\n", cal_val, ret);
 
        return ret;