stmmac: pci: Make stmmac_pci_find_phy_addr truly generic
authorJan Kiszka <jan.kiszka@siemens.com>
Thu, 22 Jun 2017 06:17:59 +0000 (08:17 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 22 Jun 2017 17:39:56 +0000 (13:39 -0400)
Move the special case for the early Galileo firmware into
quark_default_setup. This allows to use stmmac_pci_find_phy_addr for
non-quark cases.

Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/stmicro/stmmac/stmmac_pci.c

index d3d74e526e17d4cf343687617a2796483dd66a1d..f44ae49eb11cb0e974696103b222ddf20ecadfa0 100644 (file)
@@ -51,12 +51,8 @@ static int stmmac_pci_find_phy_addr(struct pci_dev *pdev,
        unsigned int func = PCI_FUNC(pdev->devfn);
        struct stmmac_pci_dmi_data *dmi;
 
-       /*
-        * Galileo boards with old firmware don't support DMI. We always return
-        * 1 here, so at least first found MAC controller would be probed.
-        */
        if (!name)
-               return 1;
+               return -ENODEV;
 
        for (dmi = info->dmi; dmi->name && *dmi->name; dmi++) {
                if (!strcmp(dmi->name, name) && dmi->func == func) {
@@ -136,8 +132,18 @@ static int quark_default_data(struct pci_dev *pdev,
         * does not connect to any PHY interface.
         */
        ret = stmmac_pci_find_phy_addr(pdev, info);
-       if (ret < 0)
-               return ret;
+       if (ret < 0) {
+               /* Return error to the caller on DMI enabled boards. */
+               if (dmi_get_system_info(DMI_BOARD_NAME))
+                       return ret;
+
+               /*
+                * Galileo boards with old firmware don't support DMI. We always
+                * use 1 here as PHY address, so at least the first found MAC
+                * controller would be probed.
+                */
+               ret = 1;
+       }
 
        plat->bus_id = PCI_DEVID(pdev->bus->number, pdev->devfn);
        plat->phy_addr = ret;