Re: [PATCH] fs: fcntl_setlease defies lease_init assumptions

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

 



Pekka J Enberg wrote:

I think you mean

static inline struct kmem_cache *slab_get_cache(const void *obj)
{
       struct kmem_cache **p = (void *)((unsigned long) obj & ~(PAGE_SIZE-1));
       return *p;
}

Of course.

On Tue, 9 May 2006, Manfred Spraul wrote:
The result would be a few small restrictions: all objects must start in the
first page of a slab (there are no exceptions on my 2.6.16 system), and
PAGE_SIZE'd caches are very expensive. Replacing the names_cache with
get_free_page is trivial. That leaves the pgd cache.

Your plan makes sense for slabs that have slab management structures embedded within.

No - it would only make sense if it could be used for all slabs. Otherwise: How should kfree figure out if it's called for a slab with embedded pointers or not?

We already have enough free space there for one pointer due to
   colour_off += cachep->slab_size;

in the alloc_slabmgmt() function, I think. Are you planning to kill external slab management allocation completely by switching to get_free_pages() for those cases? I'd much rather make the switch to page allocator under the hood so kmalloc(PAGE_SIZE*n) would still work because it's much nicer API.
How many kmalloc(PAGE_SIZE*n) users are there?

--
   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