diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2013-10-07 10:43:04 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2013-10-07 10:43:04 -0400 |
commit | a56e74f546b64be93731e42d83baf5b538cc1b11 (patch) | |
tree | 18f6dee45d801e57ac9db2a31664b0d5c0762c50 /drivers/net/tun.c | |
parent | d08e2e09042bd3f7ef66a35cb4bb92794ab26bb2 (diff) | |
parent | e4e7f10bfc4069925e99cc4b428c3434e30b6c3f (diff) |
Merge branch 'arm-aesbs' of git://git.linaro.org/people/ardbiesheuvel/linux-arm into devel-stable
Diffstat (limited to 'drivers/net/tun.c')
-rw-r--r-- | drivers/net/tun.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/net/tun.c b/drivers/net/tun.c index a639de8401f8..807815fc9968 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c | |||
@@ -1641,11 +1641,11 @@ static int tun_set_iff(struct net *net, struct file *file, struct ifreq *ifr) | |||
1641 | INIT_LIST_HEAD(&tun->disabled); | 1641 | INIT_LIST_HEAD(&tun->disabled); |
1642 | err = tun_attach(tun, file, false); | 1642 | err = tun_attach(tun, file, false); |
1643 | if (err < 0) | 1643 | if (err < 0) |
1644 | goto err_free_dev; | 1644 | goto err_free_flow; |
1645 | 1645 | ||
1646 | err = register_netdevice(tun->dev); | 1646 | err = register_netdevice(tun->dev); |
1647 | if (err < 0) | 1647 | if (err < 0) |
1648 | goto err_free_dev; | 1648 | goto err_detach; |
1649 | 1649 | ||
1650 | if (device_create_file(&tun->dev->dev, &dev_attr_tun_flags) || | 1650 | if (device_create_file(&tun->dev->dev, &dev_attr_tun_flags) || |
1651 | device_create_file(&tun->dev->dev, &dev_attr_owner) || | 1651 | device_create_file(&tun->dev->dev, &dev_attr_owner) || |
@@ -1689,7 +1689,12 @@ static int tun_set_iff(struct net *net, struct file *file, struct ifreq *ifr) | |||
1689 | strcpy(ifr->ifr_name, tun->dev->name); | 1689 | strcpy(ifr->ifr_name, tun->dev->name); |
1690 | return 0; | 1690 | return 0; |
1691 | 1691 | ||
1692 | err_free_dev: | 1692 | err_detach: |
1693 | tun_detach_all(dev); | ||
1694 | err_free_flow: | ||
1695 | tun_flow_uninit(tun); | ||
1696 | security_tun_dev_free_security(tun->security); | ||
1697 | err_free_dev: | ||
1693 | free_netdev(dev); | 1698 | free_netdev(dev); |
1694 | return err; | 1699 | return err; |
1695 | } | 1700 | } |