Re: [PATCH] mm/nommu.c:Dynamic alloc/free percpu area for nommu

From: Tejun Heo
Date: Sat Mar 20 2010 - 03:23:19 EST


Hello,

On 03/19/2010 06:02 PM, graff.yang@xxxxxxxxx wrote:
From: Graff Yang<graff.yang@xxxxxxxxx>

This patch supports dynamic alloc/free percpu area for nommu arch like
blackfin.
It allocates contiguous pages in funtion pcpu_get_vm_areas() instead of
getting none contiguous pages then vmap it in mmu arch.
As we can not get the real page structure through vmalloc_to_page(), so
it also modified the nommu version vmalloc_to_page()/vmalloc_to_pfn().

Signed-off-by: Graff Yang<graff.yang@xxxxxxxxx>

Heh heh... I've never imagined there would be a SMP architecture w/o
mmu. That's pretty interesting. I mean, there is real estate for
multiple cores but not for mmu?

diff --git a/mm/nommu.c b/mm/nommu.c
index 605ace8..98bbdf4 100644
--- a/mm/nommu.c
+++ b/mm/nommu.c
@@ -255,13 +255,15 @@ EXPORT_SYMBOL(vmalloc_user);

struct page *vmalloc_to_page(const void *addr)
{
- return virt_to_page(addr);
+ return (struct page *)
+ (virt_to_page(addr)->index) ? : virt_to_page(addr);

Nothing major but isn't it more usual to write ?: without the
intervening space?

+#ifdef CONFIG_SMP
+int map_kernel_range_noflush(unsigned long addr, unsigned long size,
+ pgprot_t prot, struct page **pages)
+{

More nitpicks.

+ int i, nr_page = size>> PAGE_SHIFT;

nr_pages = size >> PAGE_SHIFT;

+ for (i = 0; i< nr_page; i++, addr += PAGE_SIZE)

i < nr_pages

+ virt_to_page(addr)->index = (pgoff_t)pages[i];
+ return size>> PAGE_SHIFT;

return size >> PAGE_SHIFT;

I think checkpatch would whine about these too.

+void unmap_kernel_range_noflush(unsigned long addr, unsigned long size)
+{
+ int i, nr_page = size>> PAGE_SHIFT;
+ for (i = 0; i< nr_page; i++, addr += PAGE_SIZE)
+ virt_to_page(addr)->index = 0;
+}
+
+struct vm_struct **pcpu_get_vm_areas(const unsigned long *offsets,
+ const size_t *sizes, int nr_vms,
+ size_t align, gfp_t gfp_mask)

Hmmm... in general, one of the reasons the percpu allocation is
complex is to avoid contiguous allocations while avoiding additional
TLB / NUMA overhead on machines with rather complex memory
configuration (which is pretty common these days). If the memory has
to be allocated contiguous anyway, it probably would be much simpler
to hook at higher level and simply allocate each chunk contiguously.
I'll look into it.

Thanks.

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