diff options
| author | David S. Miller <davem@davemloft.net> | 2018-01-17 08:00:25 +0300 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2018-01-17 08:10:42 +0300 | 
| commit | c02b3741eb99a1ec733e6134c53ba59e43e19e97 (patch) | |
| tree | ff7dd96c32dec2abe530e7101378443dabcb8962 /net/tipc | |
| parent | 7018d1b3f20fb4308ed9bc577160cb8ffb79b62a (diff) | |
| parent | 8cbab92dff778e516064c13113ca15d4869ec883 (diff) | |
| download | linux-c02b3741eb99a1ec733e6134c53ba59e43e19e97.tar.xz | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Overlapping changes all over.
The mini-qdisc bits were a little bit tricky, however.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/tipc')
| -rw-r--r-- | net/tipc/node.c | 26 | 
1 files changed, 14 insertions, 12 deletions
diff --git a/net/tipc/node.c b/net/tipc/node.c index 507017fe0f1b..9036d8756e73 100644 --- a/net/tipc/node.c +++ b/net/tipc/node.c @@ -1880,36 +1880,38 @@ int tipc_nl_node_get_link(struct sk_buff *skb, struct genl_info *info)  	if (strcmp(name, tipc_bclink_name) == 0) {  		err = tipc_nl_add_bc_link(net, &msg); -		if (err) { -			nlmsg_free(msg.skb); -			return err; -		} +		if (err) +			goto err_free;  	} else {  		int bearer_id;  		struct tipc_node *node;  		struct tipc_link *link;  		node = tipc_node_find_by_name(net, name, &bearer_id); -		if (!node) -			return -EINVAL; +		if (!node) { +			err = -EINVAL; +			goto err_free; +		}  		tipc_node_read_lock(node);  		link = node->links[bearer_id].link;  		if (!link) {  			tipc_node_read_unlock(node); -			nlmsg_free(msg.skb); -			return -EINVAL; +			err = -EINVAL; +			goto err_free;  		}  		err = __tipc_nl_add_link(net, &msg, link, 0);  		tipc_node_read_unlock(node); -		if (err) { -			nlmsg_free(msg.skb); -			return err; -		} +		if (err) +			goto err_free;  	}  	return genlmsg_reply(msg.skb, info); + +err_free: +	nlmsg_free(msg.skb); +	return err;  }  int tipc_nl_node_reset_link_stats(struct sk_buff *skb, struct genl_info *info)  | 
