Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 17 Nov 2010 13:45:06 +0100
From:      Marko Zec <zec@icir.org>
To:        freebsd-virtualization@freebsd.org
Cc:        Thierry Herbelot <thierry.herbelot@free.fr>, "Bjoern A. Zeeb" <bzeeb-lists@lists.zabbadoz.net>, freebsd-current <freebsd-current@freebsd.org>
Subject:   Re: VIMAGE: Freed UMA keg was not empty
Message-ID:  <201011171345.06789.zec@icir.org>
In-Reply-To: <20101117055208.S24596@maildrop.int.zabbadoz.net>
References:  <201011170627.28025.thierry.herbelot@free.fr> <20101117055208.S24596@maildrop.int.zabbadoz.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Wednesday 17 November 2010 06:57:53 Bjoern A. Zeeb wrote:
> On Wed, 17 Nov 2010, Thierry Herbelot wrote:
>
> Hi,
>
> first of all freebsd-virtualization@ is the better list for this; Cc:ed.
>
> > We are using FreeBSD + VIMAGE at work, and we have seen an annoying
> > problem : there seems to be a memory leak in the kernel, which eventually
> > causes a panic.
> >
> > (yes, we have seen the following message : "WARNING: VIMAGE (virtualized
> > network stack) is a highly experimental feature.")
> >
> > Configuring a network interface in a jail with vnet enabled, then
> > removing that jail causes these messages. In dmesg:
> >
> > [...]
> > Freed UMA keg was not empty (203 items).  Lost 1 pages of memory.
> > Freed UMA keg was not empty (36 items).  Lost 2 pages of memory.
> >
> > The issue happens in a GENERIC FreeBSD 8.1 kernel, with VIMAGE enabled
> > (with attached VIMAGE kernel config file).
> >
> > The following commands reproduce the bug:
> >
> > jail -l -u root -c path=/ name=foo persist vnet &&
> > jexec foo ifconfig lo0 127.0.0.1/8 &&
> > jail -r foo
> >
> > Running it too many times exhausts kernel memory and crashes the machine.
> >
> > The probleme is seen on 8.1-release kernel, 8-stable from SVN and SVN
> > -head.
>
> The problem has been present since day 1 and is still present up to
> HEAD.  This is about type stability and teardown.  So far we are no
> able to actually free TCP (and UDP in SVN) states as they might still
> be accesses after "free".  It's a general problem in the network stack
> and has been implemented as a measure to circumvent panics in those
> cases.

Actually, we never seriously discussed or revisited the issue with separate 
UMA pools for each vnet instance.

My original motivation when O introduced separate UMA pools was primarily in 
making it easier to spot resource leaks, and to prove the correctness of the 
whole VIMAGE / VNET thing.  Having more or less achieved those goals, perhaps 
the time has come to move on.  Having said that, and given that the current 
VIMAGE resource allocation model is far from being optimal (a lot of memory 
sits reserved but 99% unused, and cannot be reclaimed later on vnet 
teardown), perhaps it's time that we reconsider using unified UMA pools.

Note that the original VIMAGE prototype on FreeBSD 4.x from 2002 or 2003 used 
(mostly) unified memory zones, so there's no technical reason why this 
couldn't work again in FreeBSD current or 8-stable.

Cheers,

Marko


> I am not sure if that's actually what's biting you wrt to memory or
> if it's something else.  Unfortunately boot logs and kernel configs
> don't help much; enable ddb and get show uma and show malloc reports
> after the crash (or watch vmstat -z and vmstat -m) after every 50 jail
> restarts.  I might have some patches for a couple of things but cannot
> (yet) help with the additional (duplicate) UMA zones showing up at
> each iteration (for the -z case).
>
> /bz



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201011171345.06789.zec>