Thread (13 messages) 13 messages, 6 authors, 2013-01-04

Re: TUN problems (regression?)

From: Jason Wang <jasowang@redhat.com>
Date: 2012-12-21 04:27:02

On 12/21/2012 11:39 AM, Eric Dumazet wrote:
On Fri, 2012-12-21 at 11:32 +0800, Jason Wang wrote:
quoted
On 12/21/2012 07:50 AM, Stephen Hemminger wrote:
quoted
On Thu, 20 Dec 2012 15:38:17 -0800
Eric Dumazet [off-list ref] wrote:
quoted
On Thu, 2012-12-20 at 18:16 -0500, Paul Moore wrote:
quoted
[CC'ing netdev in case this is a known problem I just missed ...]

Hi Jason,

I started doing some more testing with the multiqueue TUN changes and I ran 
into a problem when running tunctl: running it once w/o arguments works as 
expected, but running it a second time results in failure and a 
kmem_cache_sanity_check() failure.  The problem appears to be very repeatable 
on my test VM and happens independent of the LSM/SELinux fixup patches.

Have you seen this before?
Obviously code in tun_flow_init() is wrong...

static int tun_flow_init(struct tun_struct *tun)
{
        int i;

        tun->flow_cache = kmem_cache_create("tun_flow_cache",
                                            sizeof(struct tun_flow_entry), 0, 0,
                                            NULL);
        if (!tun->flow_cache)
                return -ENOMEM;
...
}


I have no idea why we would need a kmem_cache per tun_struct,
and why we even need a kmem_cache.
Normally flow malloc/free should be good enough.
It might make sense to use private kmem_cache if doing hlist_nulls.


Acked-by: Stephen Hemminger <redacted>
Should be at least a global cache, I thought I can get some speed-up by
using kmem_cache.

Acked-by: Jason Wang <jasowang@redhat.com>
Was it with SLUB or SLAB ?

Using generic kmalloc-64 is better than a dedicated kmem_cache of 48
bytes per object, as we guarantee each object is on a single cache line.
Right, thanks for the explanation.
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help