|
@@ -1316,6 +1316,10 @@ static int do_setlink(struct net_device *dev, struct ifinfomsg *ifm,
|
|
|
err = PTR_ERR(net);
|
|
|
goto errout;
|
|
|
}
|
|
|
+ if (!ns_capable(net->user_ns, CAP_NET_ADMIN)) {
|
|
|
+ err = -EPERM;
|
|
|
+ goto errout;
|
|
|
+ }
|
|
|
err = dev_change_net_namespace(dev, net, ifname);
|
|
|
put_net(net);
|
|
|
if (err)
|
|
@@ -1547,9 +1551,6 @@ static int rtnl_setlink(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|
|
struct nlattr *tb[IFLA_MAX+1];
|
|
|
char ifname[IFNAMSIZ];
|
|
|
|
|
|
- if (!capable(CAP_NET_ADMIN))
|
|
|
- return -EPERM;
|
|
|
-
|
|
|
err = nlmsg_parse(nlh, sizeof(*ifm), tb, IFLA_MAX, ifla_policy);
|
|
|
if (err < 0)
|
|
|
goto errout;
|
|
@@ -1593,9 +1594,6 @@ static int rtnl_dellink(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|
|
int err;
|
|
|
LIST_HEAD(list_kill);
|
|
|
|
|
|
- if (!capable(CAP_NET_ADMIN))
|
|
|
- return -EPERM;
|
|
|
-
|
|
|
err = nlmsg_parse(nlh, sizeof(*ifm), tb, IFLA_MAX, ifla_policy);
|
|
|
if (err < 0)
|
|
|
return err;
|
|
@@ -1726,9 +1724,6 @@ static int rtnl_newlink(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|
|
struct nlattr *linkinfo[IFLA_INFO_MAX+1];
|
|
|
int err;
|
|
|
|
|
|
- if (!capable(CAP_NET_ADMIN))
|
|
|
- return -EPERM;
|
|
|
-
|
|
|
#ifdef CONFIG_MODULES
|
|
|
replay:
|
|
|
#endif
|