Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 109582af authored by Nicolas Dichtel's avatar Nicolas Dichtel Committed by David S. Miller
Browse files

netns: returns always an id in __peernet2id()



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: default avatarNicolas Dichtel <nicolas.dichtel@6wind.com>
Acked-by: default avatarThomas Graf <tgraf@suug.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 43996fdd
Loading
Loading
Loading
Loading
+8 −11
Original line number Diff line number Diff line
@@ -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
@@ -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);

@@ -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;