* [PATCH v2] sky2: allow mac to come from dt
@ 2014-03-05 22:45 Tim Harvey
2014-03-05 23:45 ` Stephen Hemminger
2014-03-07 19:36 ` David Miller
0 siblings, 2 replies; 4+ messages in thread
From: Tim Harvey @ 2014-03-05 22:45 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 v1:
- simplified based on feedback
- fixed formatting
---
drivers/net/ethernet/marvell/sky2.c | 16 ++++++++++++++--
1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/drivers/net/ethernet/marvell/sky2.c b/drivers/net/ethernet/marvell/sky2.c
index 55a37ae..471473e 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));
+ unsigned char *iap, tmpaddr[ETH_ALEN];
if (!dev)
return NULL;
@@ -4805,8 +4808,17 @@ 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_fromio(&tmpaddr, hw->regs + B2_MAC_1 + port * 8,
+ ETH_ALEN);
+ iap = tmpaddr;
+ }
+ ether_addr_copy(dev->dev_addr, iap);
return dev;
}
--
1.8.3.2
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH v2] sky2: allow mac to come from dt
2014-03-05 22:45 [PATCH v2] sky2: allow mac to come from dt Tim Harvey
@ 2014-03-05 23:45 ` Stephen Hemminger
2014-03-07 19:36 ` David Miller
1 sibling, 0 replies; 4+ messages in thread
From: Stephen Hemminger @ 2014-03-05 23:45 UTC (permalink / raw)
To: Tim Harvey; +Cc: netdev, devicetree, Grant Likely, Rob Herring
On Wed, 5 Mar 2014 14:45:12 -0800
Tim Harvey <tharvey@gateworks.com> wrote:
> + unsigned char *iap, tmpaddr[ETH_ALEN];
>
> if (!dev)
> return NULL;
> @@ -4805,8 +4808,17 @@ 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_fromio(&tmpaddr, hw->regs + B2_MAC_1 + port * 8,
> + ETH_ALEN);
> + iap = tmpaddr;
> + }
> + ether_addr_copy(dev->dev_addr, iap);
Can be done without stack tmpaddr.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH v2] sky2: allow mac to come from dt
2014-03-05 22:45 [PATCH v2] sky2: allow mac to come from dt Tim Harvey
2014-03-05 23:45 ` Stephen Hemminger
@ 2014-03-07 19:36 ` David Miller
2014-03-07 20:08 ` Tim Harvey
1 sibling, 1 reply; 4+ messages in thread
From: David Miller @ 2014-03-07 19:36 UTC (permalink / raw)
To: tharvey; +Cc: stephen, netdev, devicetree, grant.likely, robh+dt
From: Tim Harvey <tharvey@gateworks.com>
Date: Wed, 5 Mar 2014 14:45:12 -0800
> @@ -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));
> + unsigned char *iap, tmpaddr[ETH_ALEN];
>
> if (!dev)
> return NULL;
> @@ -4805,8 +4808,17 @@ 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_fromio(&tmpaddr, hw->regs + B2_MAC_1 + port * 8,
> + ETH_ALEN);
> + iap = tmpaddr;
> + }
> + ether_addr_copy(dev->dev_addr, iap);
As Stephen Hemminger suggested do this like:
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);
That way you don't need the on-stack buffer.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH v2] sky2: allow mac to come from dt
2014-03-07 19:36 ` David Miller
@ 2014-03-07 20:08 ` Tim Harvey
0 siblings, 0 replies; 4+ messages in thread
From: Tim Harvey @ 2014-03-07 20:08 UTC (permalink / raw)
To: David Miller, Stephen Hemminger
Cc: netdev, devicetree@vger.kernel.org, Grant Likely, Rob Herring
On Fri, Mar 7, 2014 at 11:36 AM, David Miller <davem@davemloft.net> wrote:
> From: Tim Harvey <tharvey@gateworks.com>
> Date: Wed, 5 Mar 2014 14:45:12 -0800
>
>> @@ -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));
>> + unsigned char *iap, tmpaddr[ETH_ALEN];
>>
>> if (!dev)
>> return NULL;
>> @@ -4805,8 +4808,17 @@ 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_fromio(&tmpaddr, hw->regs + B2_MAC_1 + port * 8,
>> + ETH_ALEN);
>> + iap = tmpaddr;
>> + }
>> + ether_addr_copy(dev->dev_addr, iap);
>
> As Stephen Hemminger suggested do this like:
>
> 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);
>
> That way you don't need the on-stack buffer.
Thanks for the suggestion - I will re-send a v3 shortly.
Tim
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2014-03-07 20:08 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-03-05 22:45 [PATCH v2] sky2: allow mac to come from dt Tim Harvey
2014-03-05 23:45 ` Stephen Hemminger
2014-03-07 19:36 ` David Miller
2014-03-07 20:08 ` Tim Harvey
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).