mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 02:33:57 +00:00
ip: fix error handling in ip_finish_output2()
__neigh_create() returns either a pointer to struct neighbour or PTR_ERR().
But the caller expects it to return either a pointer or NULL. Replace
the NULL check with IS_ERR() check.
The bug was introduced in a263b30936
("ipv4: Make neigh lookups directly in output packet path.").
Signed-off-by: Vasily Kulikov <segoon@openwall.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
91d27a8650
commit
9871f1ad67
@ -197,7 +197,7 @@ static inline int ip_finish_output2(struct sk_buff *skb)
|
||||
neigh = __ipv4_neigh_lookup_noref(dev, nexthop);
|
||||
if (unlikely(!neigh))
|
||||
neigh = __neigh_create(&arp_tbl, &nexthop, dev, false);
|
||||
if (neigh) {
|
||||
if (!IS_ERR(neigh)) {
|
||||
int res = dst_neigh_output(dst, neigh, skb);
|
||||
|
||||
rcu_read_unlock_bh();
|
||||
|
Loading…
Reference in New Issue
Block a user