Re: [PATCH 1/2] Generic Virtual Memmap suport for SPARSEMEM

From: Christoph Lameter
Date: Mon Apr 02 2007 - 17:54:00 EST


On Mon, 2 Apr 2007, Dave Hansen wrote:

> > The slab allocator purposes is to deliver small sub page sized chunks.
> > The page allocator is there to allocate pages. Both are optimized for its
> > purpose.
>
> I understand that, in general, but how does that optimization help,
> here, exactly? My argument is that if we use the slab, it means more
> code sharing with existing code in sparse.c. Other than ideology, what
> practical reasons are there in this case that keep us from doing that
> otherwise attractive code sharing.

F.e. you are wasting memory that the slab needs to uselessly track these
allocations. You would need to create a special slab that has page sized
(or huge page sized) alignment to have the proper allocation behavior. Not
good.

The rest of sparse is not MMU bound. So you may be fine. I'd recommend
though to use the page allocator if you are doing large allocations. I do
not see the point of using slab there.

> I don't think the pagetable walks are generic enough to ever get used on
> ppc, unless they start walking the Linux pagetables for the kernel
> virtual address area. I was trying to poke you into getting the
> pagetable walks out of sparse.c. ;)

If I would be doing that then we would end up adding these pagetable walks
to multiple architectures. I already need to cover IA64 and x86_64 and
this will also do i386. Lets try to keep them generic. PPC may need to
disable these walks and do its own thing.

> > Well think about how to handle the case that the allocatiopn of a page
> > table page or a vmemmap block fails. Once we have that sorted out then we
> > can cleanup the higher layers.
>
> I think it is best to just completely replace
> sparse_early_mem_map_alloc() for the vmemmap case. It really is a
> completely different beast. You'd never, for instance, have
> alloc_remap() come into play.

What is the purpose of alloc_remap? Could not figure that one out.

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