提交 2e9526b3 编写于 作者: H Herbert Xu 提交者: David S. Miller

gre: Fix dev_addr clobbering for gretap

Nathan Neulinger noticed that gretap devices get their MAC address
from the local IP address, which results in invalid MAC addresses
half of the time.

This is because gretap is still using the tunnel netdev ops rather
than the correct tap netdev ops struct.

This patch also fixes changelink to not clobber the MAC address
for the gretap case.
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
Acked-by: NStephen Hemminger <shemminger@vyatta.com>
Tested-by: NNathan Neulinger <nneul@mst.edu>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 33cb7d33
...@@ -1464,7 +1464,7 @@ static void ipgre_tap_setup(struct net_device *dev) ...@@ -1464,7 +1464,7 @@ static void ipgre_tap_setup(struct net_device *dev)
ether_setup(dev); ether_setup(dev);
dev->netdev_ops = &ipgre_netdev_ops; dev->netdev_ops = &ipgre_tap_netdev_ops;
dev->destructor = free_netdev; dev->destructor = free_netdev;
dev->iflink = 0; dev->iflink = 0;
...@@ -1525,25 +1525,29 @@ static int ipgre_changelink(struct net_device *dev, struct nlattr *tb[], ...@@ -1525,25 +1525,29 @@ static int ipgre_changelink(struct net_device *dev, struct nlattr *tb[],
if (t->dev != dev) if (t->dev != dev)
return -EEXIST; return -EEXIST;
} else { } else {
unsigned nflags = 0;
t = nt; t = nt;
if (ipv4_is_multicast(p.iph.daddr)) if (dev->type != ARPHRD_ETHER) {
nflags = IFF_BROADCAST; unsigned nflags = 0;
else if (p.iph.daddr)
nflags = IFF_POINTOPOINT;
if ((dev->flags ^ nflags) & if (ipv4_is_multicast(p.iph.daddr))
(IFF_POINTOPOINT | IFF_BROADCAST)) nflags = IFF_BROADCAST;
return -EINVAL; else if (p.iph.daddr)
nflags = IFF_POINTOPOINT;
if ((dev->flags ^ nflags) &
(IFF_POINTOPOINT | IFF_BROADCAST))
return -EINVAL;
}
ipgre_tunnel_unlink(ign, t); ipgre_tunnel_unlink(ign, t);
t->parms.iph.saddr = p.iph.saddr; t->parms.iph.saddr = p.iph.saddr;
t->parms.iph.daddr = p.iph.daddr; t->parms.iph.daddr = p.iph.daddr;
t->parms.i_key = p.i_key; t->parms.i_key = p.i_key;
memcpy(dev->dev_addr, &p.iph.saddr, 4); if (dev->type != ARPHRD_ETHER) {
memcpy(dev->broadcast, &p.iph.daddr, 4); memcpy(dev->dev_addr, &p.iph.saddr, 4);
memcpy(dev->broadcast, &p.iph.daddr, 4);
}
ipgre_tunnel_link(ign, t); ipgre_tunnel_link(ign, t);
netdev_state_change(dev); netdev_state_change(dev);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册