From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754698Ab1CUWOL (ORCPT ); Mon, 21 Mar 2011 18:14:11 -0400 Received: from kirsty.vergenet.net ([202.4.237.240]:48379 "EHLO kirsty.vergenet.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754601Ab1CUWOI (ORCPT ); Mon, 21 Mar 2011 18:14:08 -0400 Date: Tue, 22 Mar 2011 07:13:58 +0900 From: Simon Horman To: Eric Dumazet Cc: Ingo Molnar , David Miller , torvalds@linux-foundation.org, akpm@linux-foundation.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Peter Zijlstra , Thomas Gleixner , Arnd Bergmann , Pekka Enberg , Julian Anastasov Subject: Re: [slab poison overwritten] Re: [GIT] Networking Message-ID: <20110321221357.GF22625@verge.net.au> References: <20110320.195156.226769634.davem@davemloft.net> <20110321125320.GA23490@elte.hu> <1300714346.2884.284.camel@edumazet-laptop> <20110321161528.GA28580@elte.hu> <20110321164238.GA5303@elte.hu> <20110321173941.GB3892@elte.hu> <1300730838.2884.578.camel@edumazet-laptop> <1300738540.2837.5.camel@edumazet-laptop> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <1300738540.2837.5.camel@edumazet-laptop> Organisation: Horms Solutions Ltd. User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Mar 21, 2011 at 09:15:40PM +0100, Eric Dumazet wrote: > Le lundi 21 mars 2011 à 19:07 +0100, Eric Dumazet a écrit : > > Le lundi 21 mars 2011 à 18:39 +0100, Ingo Molnar a écrit : > > > here's the same but with kallsyms enabled. > > > > > > Thanks, > > > > > > Ingo > > > > > > [ 9.585627] initcall 0xffffffff81d5b806 returned 0 after 0 usecs > > > [ 9.588960] calling 0xffffffff81d5b9da @ 1 > > > [ 9.592303] IPVS: Creating netns size=1272 id=0 > > > [ 9.595646] IPVS: __ip_vs_control_init(): alloc_percpu. > > > [ 9.602298] IPVS: cannot register namespace. > > > [ 9.605627] IPVS: can't setup control > > > > It seems IPVS is busted in case of memory allocation error in > > __ip_vs_control_init() > > > > IPVS deinits its "struct netns_ipvs" space, but something (in IPVS) uses > > it after free. > > > > __ip_vs_init() seems to be called before ip_vs_init() completes > > correctly. We then keep in net->ipvs a pointer to some freed memory. > > > > Commit 14e405461e664b7 did some changes in this area > > > > Simon, any idea ? > > > > > > For the time being, we can avoid the false memory allocation error (and > leak) Sorry, that typo is my work. > Thanks > > [PATCH] ipvs: fix a typo in __ip_vs_control_init() > > Reported-by: Ingo Molnar > Signed-off-by: Eric Dumazet > Cc: Simon Horman > Cc: Julian Anastasov Acked-by: Simon Horman > --- > net/netfilter/ipvs/ip_vs_ctl.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/net/netfilter/ipvs/ip_vs_ctl.c b/net/netfilter/ipvs/ip_vs_ctl.c > index b799cea..33733c8 100644 > --- a/net/netfilter/ipvs/ip_vs_ctl.c > +++ b/net/netfilter/ipvs/ip_vs_ctl.c > @@ -3605,7 +3605,7 @@ int __net_init __ip_vs_control_init(struct net *net) > > /* procfs stats */ > ipvs->tot_stats.cpustats = alloc_percpu(struct ip_vs_cpu_stats); > - if (ipvs->tot_stats.cpustats) { > + if (!ipvs->tot_stats.cpustats) { > pr_err("%s(): alloc_percpu.\n", __func__); > return -ENOMEM; > } > >