net: mediatek: remove superfluous pin setup for MT7622 SoC
authorSean Wang <sean.wang@mediatek.com>
Wed, 20 Dec 2017 09:47:06 +0000 (17:47 +0800)
committerDavid S. Miller <davem@davemloft.net>
Tue, 26 Dec 2017 17:05:46 +0000 (12:05 -0500)
Remove superfluous pin setup to get out of accessing invalid I/O pin
registers because the way for pin configuring tends to be different from
various SoCs and thus it should be better being managed and controlled by
the pinctrl driver which MT7622 already can support.

Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mediatek/mtk_eth_soc.c
drivers/net/ethernet/mediatek/mtk_eth_soc.h

index fc67e35b253e4e59c12227c3e24da9c0f5bae311..29826dd152044fffb4b3658311f0ec54a7e3deaf 100644 (file)
@@ -1952,14 +1952,16 @@ static int mtk_hw_init(struct mtk_eth *eth)
        }
        regmap_write(eth->ethsys, ETHSYS_SYSCFG0, val);
 
-       /* Set GE2 driving and slew rate */
-       regmap_write(eth->pctl, GPIO_DRV_SEL10, 0xa00);
+       if (eth->pctl) {
+               /* Set GE2 driving and slew rate */
+               regmap_write(eth->pctl, GPIO_DRV_SEL10, 0xa00);
 
-       /* set GE2 TDSEL */
-       regmap_write(eth->pctl, GPIO_OD33_CTRL8, 0x5);
+               /* set GE2 TDSEL */
+               regmap_write(eth->pctl, GPIO_OD33_CTRL8, 0x5);
 
-       /* set GE2 TUNE */
-       regmap_write(eth->pctl, GPIO_BIAS_CTRL, 0x0);
+               /* set GE2 TUNE */
+               regmap_write(eth->pctl, GPIO_BIAS_CTRL, 0x0);
+       }
 
        /* Set linkdown as the default for each GMAC. Its own MCR would be set
         * up with the more appropriate value when mtk_phy_link_adjust call is
@@ -2538,11 +2540,13 @@ static int mtk_probe(struct platform_device *pdev)
                }
        }
 
-       eth->pctl = syscon_regmap_lookup_by_phandle(pdev->dev.of_node,
-                                                   "mediatek,pctl");
-       if (IS_ERR(eth->pctl)) {
-               dev_err(&pdev->dev, "no pctl regmap found\n");
-               return PTR_ERR(eth->pctl);
+       if (eth->soc->required_pctl) {
+               eth->pctl = syscon_regmap_lookup_by_phandle(pdev->dev.of_node,
+                                                           "mediatek,pctl");
+               if (IS_ERR(eth->pctl)) {
+                       dev_err(&pdev->dev, "no pctl regmap found\n");
+                       return PTR_ERR(eth->pctl);
+               }
        }
 
        for (i = 0; i < 3; i++) {
@@ -2668,17 +2672,20 @@ static int mtk_remove(struct platform_device *pdev)
 
 static const struct mtk_soc_data mt2701_data = {
        .caps = MTK_GMAC1_TRGMII,
-       .required_clks = MT7623_CLKS_BITMAP
+       .required_clks = MT7623_CLKS_BITMAP,
+       .required_pctl = true,
 };
 
 static const struct mtk_soc_data mt7622_data = {
        .caps = MTK_DUAL_GMAC_SHARED_SGMII | MTK_GMAC1_ESW,
-       .required_clks = MT7622_CLKS_BITMAP
+       .required_clks = MT7622_CLKS_BITMAP,
+       .required_pctl = false,
 };
 
 static const struct mtk_soc_data mt7623_data = {
        .caps = MTK_GMAC1_TRGMII,
-       .required_clks = MT7623_CLKS_BITMAP
+       .required_clks = MT7623_CLKS_BITMAP,
+       .required_pctl = true,
 };
 
 const struct of_device_id of_mtk_match[] = {
index a3af4660de81cc1f3379d18e714eabdcdd595af9..672b8c353c47d92357722d728d7f0aa922c310b6 100644 (file)
@@ -573,10 +573,13 @@ struct mtk_rx_ring {
  * @caps                       Flags shown the extra capability for the SoC
  * @required_clks              Flags shown the bitmap for required clocks on
  *                             the target SoC
+ * @required_pctl              A bool value to show whether the SoC requires
+ *                             the extra setup for those pins used by GMAC.
  */
 struct mtk_soc_data {
        u32             caps;
        u32             required_clks;
+       bool            required_pctl;
 };
 
 /* currently no SoC has more than 2 macs */