提交 b194c1f1 编写于 作者: J Jiri Pirko 提交者: David S. Miller

neigh: fix setting of default gc_* values

This patch fixes bug introduced by:
commit 1d4c8c29
"neigh: restore old behaviour of default parms values"

The thing is that in neigh_sysctl_register, extra1 and extra2 which were
previously set for NEIGH_VAR_GC_* are overwritten. That leads to
nonsense int limits for gc_* variables. So fix this by not touching
extra* fields for gc_* variables.
Signed-off-by: NJiri Pirko <jiri@resnulli.us>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 f5ddcbbb
...@@ -3046,7 +3046,7 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, ...@@ -3046,7 +3046,7 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,
if (!t) if (!t)
goto err; goto err;
for (i = 0; i < ARRAY_SIZE(t->neigh_vars); i++) { for (i = 0; i < NEIGH_VAR_GC_INTERVAL; i++) {
t->neigh_vars[i].data += (long) p; t->neigh_vars[i].data += (long) p;
t->neigh_vars[i].extra1 = dev; t->neigh_vars[i].extra1 = dev;
t->neigh_vars[i].extra2 = p; t->neigh_vars[i].extra2 = p;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册