lwtunnel: check return value of nla_nest_start

Function nla_nest_start() may return a NULL pointer on error. However,
in function lwtunnel_fill_encap(), the return value of nla_nest_start()
is not validated before it is used. This patch checks the return value
of nla_nest_start() against NULL.

Signed-off-by: Pan Bian <bianpan2016@163.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Pan Bian 2017-04-23 14:28:37 +08:00 committed by David S. Miller
parent 09d36071cf
commit a50fe0ffd7

View File

@ -214,6 +214,8 @@ int lwtunnel_fill_encap(struct sk_buff *skb, struct lwtunnel_state *lwtstate)
ret = -EOPNOTSUPP; ret = -EOPNOTSUPP;
nest = nla_nest_start(skb, RTA_ENCAP); nest = nla_nest_start(skb, RTA_ENCAP);
if (!nest)
goto nla_put_failure;
rcu_read_lock(); rcu_read_lock();
ops = rcu_dereference(lwtun_encaps[lwtstate->type]); ops = rcu_dereference(lwtun_encaps[lwtstate->type]);
if (likely(ops && ops->fill_encap)) if (likely(ops && ops->fill_encap))