* [PATCH v3] sky2: allow mac to come from dt
@ 2014-03-08 4:59 Tim Harvey
2014-03-10 15:36 ` Rob Herring
2014-03-10 19:40 ` David Miller
0 siblings, 2 replies; 3+ messages in thread
From: Tim Harvey @ 2014-03-08 4:59 UTC (permalink / raw)
To: Stephen Hemminger; +Cc: netdev, devicetree, Grant Likely, Rob Herring
The driver reads the mac address from the device registers which would
need to have been programmed by the bootloader. This patch adds
the ability to pull the mac from devicetree via the pci device dt node.
Signed-off-by: Tim Harvey <tharvey@gateworks.com>
Cc: netdev@vger.kernel.org
Cc: devicetree@vger.kernel.org
Cc: Grant Likely <grant.likely@linaro.org>
Cc: Rob Herring <robh+dt@kernel.org>
Changes since v2:
- eliminated use of stack tmpaddr per feedback
Changes since v1:
- simplified based on feedback
- fixed formatting
---
drivers/net/ethernet/marvell/sky2.c | 15 +++++++++++++--
1 file changed, 13 insertions(+), 2 deletions(-)
diff --git a/drivers/net/ethernet/marvell/sky2.c b/drivers/net/ethernet/marvell/sky2.c
index 55a37ae..2434611 100644
--- a/drivers/net/ethernet/marvell/sky2.c
+++ b/drivers/net/ethernet/marvell/sky2.c
@@ -44,6 +44,8 @@
#include <linux/prefetch.h>
#include <linux/debugfs.h>
#include <linux/mii.h>
+#include <linux/of_device.h>
+#include <linux/of_net.h>
#include <asm/irq.h>
@@ -4748,6 +4750,7 @@ static struct net_device *sky2_init_netdev(struct sky2_hw *hw, unsigned port,
{
struct sky2_port *sky2;
struct net_device *dev = alloc_etherdev(sizeof(*sky2));
+ const void *iap;
if (!dev)
return NULL;
@@ -4805,8 +4808,16 @@ static struct net_device *sky2_init_netdev(struct sky2_hw *hw, unsigned port,
dev->features |= dev->hw_features;
- /* read the mac address */
- memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8, ETH_ALEN);
+ /* try to get mac address in the following order:
+ * 1) from device tree data
+ * 2) from internal registers set by bootloader
+ */
+ iap = of_get_mac_address(hw->pdev->dev.of_node);
+ if (iap)
+ memcpy(dev->dev_addr, iap, ETH_ALEN);
+ else
+ memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8,
+ ETH_ALEN);
return dev;
}
--
1.8.3.2
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH v3] sky2: allow mac to come from dt
2014-03-08 4:59 [PATCH v3] sky2: allow mac to come from dt Tim Harvey
@ 2014-03-10 15:36 ` Rob Herring
2014-03-10 19:40 ` David Miller
1 sibling, 0 replies; 3+ messages in thread
From: Rob Herring @ 2014-03-10 15:36 UTC (permalink / raw)
To: Tim Harvey
Cc: Stephen Hemminger, netdev, devicetree@vger.kernel.org,
Grant Likely, Rob Herring
On Fri, Mar 7, 2014 at 10:59 PM, Tim Harvey <tharvey@gateworks.com> wrote:
> The driver reads the mac address from the device registers which would
> need to have been programmed by the bootloader. This patch adds
> the ability to pull the mac from devicetree via the pci device dt node.
>
> Signed-off-by: Tim Harvey <tharvey@gateworks.com>
> Cc: netdev@vger.kernel.org
> Cc: devicetree@vger.kernel.org
> Cc: Grant Likely <grant.likely@linaro.org>
> Cc: Rob Herring <robh+dt@kernel.org>
Acked-by: Rob Herring <robh@kernel.org>
>
> Changes since v2:
> - eliminated use of stack tmpaddr per feedback
>
> Changes since v1:
> - simplified based on feedback
> - fixed formatting
> ---
> drivers/net/ethernet/marvell/sky2.c | 15 +++++++++++++--
> 1 file changed, 13 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/net/ethernet/marvell/sky2.c b/drivers/net/ethernet/marvell/sky2.c
> index 55a37ae..2434611 100644
> --- a/drivers/net/ethernet/marvell/sky2.c
> +++ b/drivers/net/ethernet/marvell/sky2.c
> @@ -44,6 +44,8 @@
> #include <linux/prefetch.h>
> #include <linux/debugfs.h>
> #include <linux/mii.h>
> +#include <linux/of_device.h>
> +#include <linux/of_net.h>
>
> #include <asm/irq.h>
>
> @@ -4748,6 +4750,7 @@ static struct net_device *sky2_init_netdev(struct sky2_hw *hw, unsigned port,
> {
> struct sky2_port *sky2;
> struct net_device *dev = alloc_etherdev(sizeof(*sky2));
> + const void *iap;
>
> if (!dev)
> return NULL;
> @@ -4805,8 +4808,16 @@ static struct net_device *sky2_init_netdev(struct sky2_hw *hw, unsigned port,
>
> dev->features |= dev->hw_features;
>
> - /* read the mac address */
> - memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8, ETH_ALEN);
> + /* try to get mac address in the following order:
> + * 1) from device tree data
> + * 2) from internal registers set by bootloader
> + */
> + iap = of_get_mac_address(hw->pdev->dev.of_node);
> + if (iap)
> + memcpy(dev->dev_addr, iap, ETH_ALEN);
> + else
> + memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8,
> + ETH_ALEN);
>
> return dev;
> }
> --
> 1.8.3.2
>
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [PATCH v3] sky2: allow mac to come from dt
2014-03-08 4:59 [PATCH v3] sky2: allow mac to come from dt Tim Harvey
2014-03-10 15:36 ` Rob Herring
@ 2014-03-10 19:40 ` David Miller
1 sibling, 0 replies; 3+ messages in thread
From: David Miller @ 2014-03-10 19:40 UTC (permalink / raw)
To: tharvey; +Cc: stephen, netdev, devicetree, grant.likely, robh+dt
From: Tim Harvey <tharvey@gateworks.com>
Date: Fri, 7 Mar 2014 20:59:53 -0800
> The driver reads the mac address from the device registers which would
> need to have been programmed by the bootloader. This patch adds
> the ability to pull the mac from devicetree via the pci device dt node.
>
> Signed-off-by: Tim Harvey <tharvey@gateworks.com>
> Cc: netdev@vger.kernel.org
> Cc: devicetree@vger.kernel.org
> Cc: Grant Likely <grant.likely@linaro.org>
> Cc: Rob Herring <robh+dt@kernel.org>
>
> Changes since v2:
> - eliminated use of stack tmpaddr per feedback
>
> Changes since v1:
> - simplified based on feedback
> - fixed formatting
Applied to net-next, thanks.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2014-03-10 19:40 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-03-08 4:59 [PATCH v3] sky2: allow mac to come from dt Tim Harvey
2014-03-10 15:36 ` Rob Herring
2014-03-10 19:40 ` David Miller
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).