Re: [PATCH] net: decnet handle a failure in neigh_parms_alloc (take 2)
Hi, On Wed, Jan 24, 2007 at 09:55:45PM -0700, Eric W. Biederman wrote: While enhancing the neighbour code to handle multiple network namespaces I noticed that decnet is assuming neigh_parms_alloc will allways succeed, which is clearly wrong. So handle the failure. Signed-off-by: Eric W. Biederman [EMAIL PROTECTED] Acked-by: Steven Whitehouse [EMAIL PROTECTED] Also you should cc Patrick as he is now the maintainer, Steve. --- net/decnet/dn_dev.c | 11 +-- 1 files changed, 9 insertions(+), 2 deletions(-) diff --git a/net/decnet/dn_dev.c b/net/decnet/dn_dev.c index 324eb47..913e25a 100644 --- a/net/decnet/dn_dev.c +++ b/net/decnet/dn_dev.c @@ -1140,16 +1140,23 @@ struct dn_dev *dn_dev_create(struct net_device *dev, int *err) init_timer(dn_db-timer); dn_db-uptime = jiffies; + + dn_db-neigh_parms = neigh_parms_alloc(dev, dn_neigh_table); + if (!dn_db-neigh_parms) { + dev-dn_ptr = NULL; + kfree(dn_db); + return NULL; + } + if (dn_db-parms.up) { if (dn_db-parms.up(dev) 0) { + neigh_parms_release(dn_neigh_table, dn_db-neigh_parms); dev-dn_ptr = NULL; kfree(dn_db); return NULL; } } - dn_db-neigh_parms = neigh_parms_alloc(dev, dn_neigh_table); - dn_dev_sysctl_register(dev, dn_db-parms); dn_dev_set_timer(dev); -- 1.4.4.1.g278f - To unsubscribe from this list: send the line unsubscribe netdev in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] net: decnet handle a failure in neigh_parms_alloc (take 2)
From: Steven Whitehouse [EMAIL PROTECTED] Date: Thu, 25 Jan 2007 11:43:18 + Hi, On Wed, Jan 24, 2007 at 09:55:45PM -0700, Eric W. Biederman wrote: While enhancing the neighbour code to handle multiple network namespaces I noticed that decnet is assuming neigh_parms_alloc will allways succeed, which is clearly wrong. So handle the failure. Signed-off-by: Eric W. Biederman [EMAIL PROTECTED] Acked-by: Steven Whitehouse [EMAIL PROTECTED] Applied, thanks everyone. Also you should cc Patrick as he is now the maintainer, Yep, would be a good idea in the future. - To unsubscribe from this list: send the line unsubscribe netdev in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html
[PATCH] net: decnet handle a failure in neigh_parms_alloc (take 2)
While enhancing the neighbour code to handle multiple network namespaces I noticed that decnet is assuming neigh_parms_alloc will allways succeed, which is clearly wrong. So handle the failure. Signed-off-by: Eric W. Biederman [EMAIL PROTECTED] --- net/decnet/dn_dev.c | 11 +-- 1 files changed, 9 insertions(+), 2 deletions(-) diff --git a/net/decnet/dn_dev.c b/net/decnet/dn_dev.c index 324eb47..913e25a 100644 --- a/net/decnet/dn_dev.c +++ b/net/decnet/dn_dev.c @@ -1140,16 +1140,23 @@ struct dn_dev *dn_dev_create(struct net_device *dev, int *err) init_timer(dn_db-timer); dn_db-uptime = jiffies; + + dn_db-neigh_parms = neigh_parms_alloc(dev, dn_neigh_table); + if (!dn_db-neigh_parms) { + dev-dn_ptr = NULL; + kfree(dn_db); + return NULL; + } + if (dn_db-parms.up) { if (dn_db-parms.up(dev) 0) { + neigh_parms_release(dn_neigh_table, dn_db-neigh_parms); dev-dn_ptr = NULL; kfree(dn_db); return NULL; } } - dn_db-neigh_parms = neigh_parms_alloc(dev, dn_neigh_table); - dn_dev_sysctl_register(dev, dn_db-parms); dn_dev_set_timer(dev); -- 1.4.4.1.g278f - To unsubscribe from this list: send the line unsubscribe netdev in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html