Re: [PATCH] slab: introduce kmem_cache_zalloc allocator

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Pekka J Enberg wrote:

On Tue, 21 Mar 2006, Andrew Morton wrote:
I've always felt that this was an odd design.  Because

a) All that cache-warmth which we get from the constructor's zeroing can
  be lost by the time we get around to using an individual object and

b) The object may be cache-cold by the time we free it, and we'll take
  cache misses just putting it back into a constructed state for
  kmem_cache_free().  And we'll lose that cache warmth by the time we use
  this object again.

So from that POV I think (in my simple way) that this is a good patch.  But
IIRC, Manfred has reasons why it might not be?

I assume the design comes from Bonwick's paper which states that the purpose of object constructor is to support one-time initialization of objects which we're _not_ doing in this case.

I agree - memset just before use is the Right Thing (tm).

One minor point: There are two cache_alloc entry points: __cache_alloc, which is a forced inline function, and kmem_cache_alloc, which is just a wrapper for __cache_alloc. Is it really necessary to call __cache_alloc? The idea is that __cache_alloc is used just by the two high-performance paths: kmem_cache_alloc and kmalloc. Noone else should use __cache_alloc directly.

--
   Manfred
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux