phy: ti: phy-j721e-wiz: Add SGMII support in wiz driver for J7200
authorSiddharth Vadapalli <s-vadapalli@ti.com>
Tue, 28 Jun 2022 12:22:49 +0000 (15:22 +0300)
committerVinod Koul <vkoul@kernel.org>
Tue, 30 Aug 2022 05:12:57 +0000 (10:42 +0530)
Select the same mac divider for SGMII too as the one being used for
QSGMII.

Enable full rate divider configuration support for J721E_WIZ_10G for
SGMII.

Signed-off-by: Siddharth Vadapalli <s-vadapalli@ti.com>
Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
Signed-off-by: Roger Quadros <rogerq@kernel.org>
Link: https://lore.kernel.org/r/20220628122255.24265-2-rogerq@kernel.org
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/phy/ti/phy-j721e-wiz.c

index 70bac931f99ac24dc115304a8dae61ae51a523c7..8c10ee8e27079b682626f2b86e79a43ebee3f404 100644 (file)
@@ -325,7 +325,8 @@ static int wiz_p_mac_div_sel(struct wiz *wiz)
        int i;
 
        for (i = 0; i < num_lanes; i++) {
-               if (wiz->lane_phy_type[i] == PHY_TYPE_QSGMII) {
+               if (wiz->lane_phy_type[i] == PHY_TYPE_SGMII ||
+                   wiz->lane_phy_type[i] == PHY_TYPE_QSGMII) {
                        ret = regmap_field_write(wiz->p_mac_div_sel0[i], 1);
                        if (ret)
                                return ret;
@@ -1025,12 +1026,18 @@ static int wiz_phy_reset_assert(struct reset_controller_dev *rcdev,
 
 static int wiz_phy_fullrt_div(struct wiz *wiz, int lane)
 {
-       if (wiz->type != AM64_WIZ_10G)
+       switch (wiz->type) {
+       case AM64_WIZ_10G:
+               if (wiz->lane_phy_type[lane] == PHY_TYPE_PCIE)
+                       return regmap_field_write(wiz->p0_fullrt_div[lane], 0x1);
+               break;
+       case J721E_WIZ_10G:
+               if (wiz->lane_phy_type[lane] == PHY_TYPE_SGMII)
+                       return regmap_field_write(wiz->p0_fullrt_div[lane], 0x2);
+               break;
+       default:
                return 0;
-
-       if (wiz->lane_phy_type[lane] == PHY_TYPE_PCIE)
-               return regmap_field_write(wiz->p0_fullrt_div[lane], 0x1);
-
+       }
        return 0;
 }