phy: cadence: Sierra: Change MAX_LANES of Sierra to 16
authorKishon Vijay Abraham I <kishon@ti.com>
Mon, 16 Dec 2019 09:57:08 +0000 (15:27 +0530)
committerKishon Vijay Abraham I <kishon@ti.com>
Wed, 8 Jan 2020 07:28:06 +0000 (12:58 +0530)
Sierra SERDES IP supports upto 16 lanes (though not all of it
will be enabled in a platform). Allow Sierra driver to support a
maximum of upto 16 lanes.

Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
drivers/phy/cadence/phy-cadence-sierra.c

index 62bff4b..665a6db 100644 (file)
 #define SIERRA_PHY_PLL_CFG                             0xe
 
 #define SIERRA_MACRO_ID                                        0x00007364
-#define SIERRA_MAX_LANES                               4
+#define SIERRA_MAX_LANES                               16
 #define PLL_LOCK_TIME                                  100000
 
 static const struct reg_field macro_id_type =
@@ -199,6 +199,7 @@ struct cdns_sierra_phy {
        struct regmap_field *pllctrl_lock[SIERRA_MAX_LANES];
        struct clk *clk;
        int nsubnodes;
+       u32 num_lanes;
        bool autoconf;
 };
 
@@ -235,6 +236,18 @@ static struct regmap_config cdns_sierra_lane_cdb_config[] = {
        SIERRA_LANE_CDB_REGMAP_CONF("1"),
        SIERRA_LANE_CDB_REGMAP_CONF("2"),
        SIERRA_LANE_CDB_REGMAP_CONF("3"),
+       SIERRA_LANE_CDB_REGMAP_CONF("4"),
+       SIERRA_LANE_CDB_REGMAP_CONF("5"),
+       SIERRA_LANE_CDB_REGMAP_CONF("6"),
+       SIERRA_LANE_CDB_REGMAP_CONF("7"),
+       SIERRA_LANE_CDB_REGMAP_CONF("8"),
+       SIERRA_LANE_CDB_REGMAP_CONF("9"),
+       SIERRA_LANE_CDB_REGMAP_CONF("10"),
+       SIERRA_LANE_CDB_REGMAP_CONF("11"),
+       SIERRA_LANE_CDB_REGMAP_CONF("12"),
+       SIERRA_LANE_CDB_REGMAP_CONF("13"),
+       SIERRA_LANE_CDB_REGMAP_CONF("14"),
+       SIERRA_LANE_CDB_REGMAP_CONF("15"),
 };
 
 static struct regmap_config cdns_sierra_common_cdb_config = {
@@ -548,6 +561,8 @@ static int cdns_sierra_phy_probe(struct platform_device *pdev)
                        }
                }
 
+               sp->num_lanes += sp->phys[node].num_lanes;
+
                gphy = devm_phy_create(dev, child, &ops);
 
                if (IS_ERR(gphy)) {
@@ -561,6 +576,11 @@ static int cdns_sierra_phy_probe(struct platform_device *pdev)
        }
        sp->nsubnodes = node;
 
+       if (sp->num_lanes > SIERRA_MAX_LANES) {
+               dev_err(dev, "Invalid lane configuration\n");
+               goto put_child2;
+       }
+
        /* If more than one subnode, configure the PHY as multilink */
        if (!sp->autoconf && sp->nsubnodes > 1)
                regmap_field_write(sp->phy_pll_cfg_1, 0x1);