Commit c384b8a7 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by David S. Miller

ipv4: streamline ipmr_new_tunnel

Reduce a few level of indentation to simplify the function.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent befb270f
...@@ -471,17 +471,16 @@ static bool ipmr_init_vif_indev(const struct net_device *dev) ...@@ -471,17 +471,16 @@ static bool ipmr_init_vif_indev(const struct net_device *dev)
static struct net_device *ipmr_new_tunnel(struct net *net, struct vifctl *v) static struct net_device *ipmr_new_tunnel(struct net *net, struct vifctl *v)
{ {
struct net_device *dev; struct net_device *tunnel_dev, *new_dev;
struct ip_tunnel_parm p = { };
dev = __dev_get_by_name(net, "tunl0"); mm_segment_t oldfs = get_fs();
if (dev) {
const struct net_device_ops *ops = dev->netdev_ops;
int err;
struct ifreq ifr; struct ifreq ifr;
struct ip_tunnel_parm p; int err;
tunnel_dev = __dev_get_by_name(net, "tunl0");
if (!tunnel_dev)
goto out;
memset(&p, 0, sizeof(p));
p.iph.daddr = v->vifc_rmt_addr.s_addr; p.iph.daddr = v->vifc_rmt_addr.s_addr;
p.iph.saddr = v->vifc_lcl_addr.s_addr; p.iph.saddr = v->vifc_lcl_addr.s_addr;
p.iph.version = 4; p.iph.version = 4;
...@@ -490,31 +489,31 @@ static struct net_device *ipmr_new_tunnel(struct net *net, struct vifctl *v) ...@@ -490,31 +489,31 @@ static struct net_device *ipmr_new_tunnel(struct net *net, struct vifctl *v)
sprintf(p.name, "dvmrp%d", v->vifc_vifi); sprintf(p.name, "dvmrp%d", v->vifc_vifi);
ifr.ifr_ifru.ifru_data = (__force void __user *)&p; ifr.ifr_ifru.ifru_data = (__force void __user *)&p;
if (ops->ndo_do_ioctl) { if (!tunnel_dev->netdev_ops->ndo_do_ioctl)
mm_segment_t oldfs = get_fs(); goto out;
set_fs(KERNEL_DS); set_fs(KERNEL_DS);
err = ops->ndo_do_ioctl(dev, &ifr, SIOCADDTUNNEL); err = tunnel_dev->netdev_ops->ndo_do_ioctl(tunnel_dev, &ifr,
SIOCADDTUNNEL);
set_fs(oldfs); set_fs(oldfs);
} else { if (err)
err = -EOPNOTSUPP; goto out;
}
dev = NULL;
if (err == 0 && new_dev = __dev_get_by_name(net, p.name);
(dev = __dev_get_by_name(net, p.name)) != NULL) { if (!new_dev)
dev->flags |= IFF_MULTICAST; goto out;
if (!ipmr_init_vif_indev(dev))
goto failure;
if (dev_open(dev, NULL))
goto failure;
dev_hold(dev);
}
}
return dev;
failure: new_dev->flags |= IFF_MULTICAST;
unregister_netdevice(dev); if (!ipmr_init_vif_indev(new_dev))
goto out_unregister;
if (dev_open(new_dev, NULL))
goto out_unregister;
dev_hold(new_dev);
return new_dev;
out_unregister:
unregister_netdevice(new_dev);
out:
return NULL; return NULL;
} }
......
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