Commit 3c607bbb authored by Pavel Emelyanov's avatar Pavel Emelyanov Committed by David S. Miller

[NEIGH]: Cleanup the neigh_sysctl_register

This mainly removes the err variable, as this call always
return the same error code (-ENOBUFS).

Besides, I moved the call to kmalloc() from the *t declaration
into the code (this is confusing when a variable is initialized
with the result of some call) and removed unneeded comment near
the error path.
Signed-off-by: default avatarPavel Emelyanov <xemul@openvz.org>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1597fbc0
...@@ -2652,14 +2652,14 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, ...@@ -2652,14 +2652,14 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,
int p_id, int pdev_id, char *p_name, int p_id, int pdev_id, char *p_name,
proc_handler *handler, ctl_handler *strategy) proc_handler *handler, ctl_handler *strategy)
{ {
struct neigh_sysctl_table *t = kmemdup(&neigh_sysctl_template, struct neigh_sysctl_table *t;
sizeof(*t), GFP_KERNEL);
const char *dev_name_source = NULL; const char *dev_name_source = NULL;
char *dev_name = NULL; char *dev_name = NULL;
int err = 0;
t = kmemdup(&neigh_sysctl_template, sizeof(*t), GFP_KERNEL);
if (!t) if (!t)
return -ENOBUFS; goto err;
t->neigh_vars[0].data = &p->mcast_probes; t->neigh_vars[0].data = &p->mcast_probes;
t->neigh_vars[1].data = &p->ucast_probes; t->neigh_vars[1].data = &p->ucast_probes;
t->neigh_vars[2].data = &p->app_probes; t->neigh_vars[2].data = &p->app_probes;
...@@ -2717,10 +2717,8 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, ...@@ -2717,10 +2717,8 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,
} }
dev_name = kstrdup(dev_name_source, GFP_KERNEL); dev_name = kstrdup(dev_name_source, GFP_KERNEL);
if (!dev_name) { if (!dev_name)
err = -ENOBUFS;
goto free; goto free;
}
t->neigh_dev[0].procname = dev_name; t->neigh_dev[0].procname = dev_name;
...@@ -2735,20 +2733,18 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, ...@@ -2735,20 +2733,18 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,
t->neigh_root_dir[0].child = t->neigh_proto_dir; t->neigh_root_dir[0].child = t->neigh_proto_dir;
t->sysctl_header = register_sysctl_table(t->neigh_root_dir); t->sysctl_header = register_sysctl_table(t->neigh_root_dir);
if (!t->sysctl_header) { if (!t->sysctl_header)
err = -ENOBUFS;
goto free_procname; goto free_procname;
}
p->sysctl_table = t; p->sysctl_table = t;
return 0; return 0;
/* error path */ free_procname:
free_procname:
kfree(dev_name); kfree(dev_name);
free: free:
kfree(t); kfree(t);
err:
return err; return -ENOBUFS;
} }
void neigh_sysctl_unregister(struct neigh_parms *p) void neigh_sysctl_unregister(struct neigh_parms *p)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment