提交 2055a99d 编写于 作者: J Jia-Ju Bai 提交者: David S. Miller

net: bonding: fix error return code of bond_neigh_init()

When slave is NULL or slave_ops->ndo_neigh_setup is NULL, no error
return code of bond_neigh_init() is assigned.
To fix this bug, ret is assigned with -EINVAL in these cases.

Fixes: 9e99bfef ("bonding: fix bond_neigh_init()")
Reported-by: NTOTE Robot <oslab@tsinghua.edu.cn>
Signed-off-by: NJia-Ju Bai <baijiaju1990@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 29d98f54
...@@ -3978,11 +3978,15 @@ static int bond_neigh_init(struct neighbour *n) ...@@ -3978,11 +3978,15 @@ static int bond_neigh_init(struct neighbour *n)
rcu_read_lock(); rcu_read_lock();
slave = bond_first_slave_rcu(bond); slave = bond_first_slave_rcu(bond);
if (!slave) if (!slave) {
ret = -EINVAL;
goto out; goto out;
}
slave_ops = slave->dev->netdev_ops; slave_ops = slave->dev->netdev_ops;
if (!slave_ops->ndo_neigh_setup) if (!slave_ops->ndo_neigh_setup) {
ret = -EINVAL;
goto out; goto out;
}
/* TODO: find another way [1] to implement this. /* TODO: find another way [1] to implement this.
* Passing a zeroed structure is fragile, * Passing a zeroed structure is fragile,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册