Commit a159aaa3 authored by Ralf Baechle's avatar Ralf Baechle Committed by David S. Miller

[AX.25]: Fix unchecked rose_add_loopback_node uses

Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a4282717
...@@ -93,20 +93,34 @@ static int rose_rebuild_header(struct sk_buff *skb) ...@@ -93,20 +93,34 @@ static int rose_rebuild_header(struct sk_buff *skb)
static int rose_set_mac_address(struct net_device *dev, void *addr) static int rose_set_mac_address(struct net_device *dev, void *addr)
{ {
struct sockaddr *sa = addr; struct sockaddr *sa = addr;
int err;
rose_del_loopback_node((rose_address *)dev->dev_addr); if (!memcpy(dev->dev_addr, sa->sa_data, dev->addr_len))
return 0;
memcpy(dev->dev_addr, sa->sa_data, dev->addr_len); if (dev->flags & IFF_UP) {
err = rose_add_loopback_node((rose_address *)dev->dev_addr);
if (err)
return err;
rose_del_loopback_node((rose_address *)dev->dev_addr);
}
rose_add_loopback_node((rose_address *)dev->dev_addr); memcpy(dev->dev_addr, sa->sa_data, dev->addr_len);
return 0; return 0;
} }
static int rose_open(struct net_device *dev) static int rose_open(struct net_device *dev)
{ {
int err;
err = rose_add_loopback_node((rose_address *)dev->dev_addr);
if (err)
return err;
netif_start_queue(dev); netif_start_queue(dev);
rose_add_loopback_node((rose_address *)dev->dev_addr);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment