net: at91_ether: add pinctrl support
authorJean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Sun, 4 Nov 2012 21:34:52 +0000 (21:34 +0000)
committerDavid S. Miller <davem@davemloft.net>
Tue, 6 Nov 2012 22:41:42 +0000 (17:41 -0500)
If no pinctrl available just report a warning as some architecture may not
need to do anything.

Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Tested-by: Joachim Eastwood <manabian@gmail.com>
Cc: Nicolas Ferre <nicolas.ferre@atmel.com>
Cc: netdev@vger.kernel.org
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/cadence/at91_ether.c

index 039e7ef6c50ec63366e5ee3f6dd4b8c8c8a03efc..6eb928ea276d9237f322396fcebf5342674478d0 100644 (file)
@@ -34,6 +34,7 @@
 #include <linux/of.h>
 #include <linux/of_device.h>
 #include <linux/of_net.h>
+#include <linux/pinctrl/consumer.h>
 
 #include "macb.h"
 
@@ -501,11 +502,21 @@ static int __init at91ether_probe(struct platform_device *pdev)
        struct phy_device *phydev;
        struct macb *lp;
        int res;
+       struct pinctrl *pinctrl;
 
        regs = platform_get_resource(pdev, IORESOURCE_MEM, 0);
        if (!regs)
                return -ENOENT;
 
+       pinctrl = devm_pinctrl_get_select_default(&pdev->dev);
+       if (IS_ERR(pinctrl)) {
+               res = PTR_ERR(pinctrl);
+               if (res == -EPROBE_DEFER)
+                       return res;
+
+               dev_warn(&pdev->dev, "No pinctrl provided\n");
+       }
+
        dev = alloc_etherdev(sizeof(struct macb));
        if (!dev)
                return -ENOMEM;