[RFC] Arch option to touch newly allocated pages

From: Jeff Dike (jdike@karaya.com)
Date: Sun Mar 03 2002 - 16:12:38 EST


What I'd like is for the arch to have __alloc_pages touch all pages that it
has allocated and is about to return.

The reason for this is that for UML, those pages are backed by host memory,
which may or may not be available when they are finally touched at some
arbitrary place in the kernel. I hit this by tmpfs running out of room
because my UMLs have their memory backed by tmpfs mounted on /tmp. So, I
want to be able to dirty those pages before they are seen by any other code.

My first guess at what I want in the code is for all the places that
__alloc_pages says this:

                        if (page)
                                return page;

to change to this:

                        if (page)
                                return arch_validate(page);

arch_validate would be defined as basically empty somewhere in a
include/linux/*.h unless the arch has defined one already. And I may want
to add order to the arg list if it can't be inferred from the page alignment.

My arch_validate would look something like this:

struct page_struct *arch_validate(page_struct *page)
{
        unsigned long zero = 0;
        unsigned long addr = page_address(page);

        set_fs(USER_DS);
        for(i = 0; i < 1 << order; i++){
                if(copy_to_user(addr + i * PAGE_SIZE, &zero, sizeof(zero))){
                        set_fs(KERNEL_DS);
                        free_pages(addr, order);
                        return(NULL);
                }
        }
        set_fs(KERNEL_DS);
        return(page);
}

The use of set_fs/copy_to_user is somewhat hokey, but that's exactly the
effect that I want. Is there a better way of doing that?

So, is this a reasonable thing to do, and is the above the right way of
getting it?

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



This archive was generated by hypermail 2b29 : Thu Mar 07 2002 - 21:00:28 EST