Skip to content

Commit

Permalink
netns: returns always an id in __peernet2id()
Browse files Browse the repository at this point in the history
All callers of this function expect a nsid, not an error.
Thus, returns NETNSA_NSID_NOT_ASSIGNED in case of error so that callers
don't have to convert the error to NETNSA_NSID_NOT_ASSIGNED.

Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Acked-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Nicolas Dichtel authored and David S. Miller committed May 10, 2015
1 parent 43996fd commit 109582a
Showing 1 changed file with 8 additions and 11 deletions.
19 changes: 8 additions & 11 deletions net/core/net_namespace.c
Original file line number Diff line number Diff line change
Expand Up @@ -192,10 +192,12 @@ static int __peernet2id(struct net *net, struct net *peer, bool alloc)
if (id > 0)
return id;

if (alloc)
return alloc_netid(net, peer, -1);
if (alloc) {
id = alloc_netid(net, peer, -1);
return id >= 0 ? id : NETNSA_NSID_NOT_ASSIGNED;
}

return -ENOENT;
return NETNSA_NSID_NOT_ASSIGNED;
}

/* This function returns the id of a peer netns. If no id is assigned, one will
Expand All @@ -204,10 +206,8 @@ static int __peernet2id(struct net *net, struct net *peer, bool alloc)
int peernet2id(struct net *net, struct net *peer)
{
bool alloc = atomic_read(&peer->count) == 0 ? false : true;
int id;

id = __peernet2id(net, peer, alloc);
return id >= 0 ? id : NETNSA_NSID_NOT_ASSIGNED;
return __peernet2id(net, peer, alloc);
}
EXPORT_SYMBOL(peernet2id);

Expand Down Expand Up @@ -554,13 +554,10 @@ static int rtnl_net_fill(struct sk_buff *skb, u32 portid, u32 seq, int flags,
rth = nlmsg_data(nlh);
rth->rtgen_family = AF_UNSPEC;

if (nsid >= 0) {
if (nsid >= 0)
id = nsid;
} else {
else
id = __peernet2id(net, peer, false);
if (id < 0)
id = NETNSA_NSID_NOT_ASSIGNED;
}
if (nla_put_s32(skb, NETNSA_NSID, id))
goto nla_put_failure;

Expand Down

0 comments on commit 109582a

Please sign in to comment.