* looking for help with details of mapping pages to kernel and userspace
@ 2004-09-07 15:47 Chris Friesen
0 siblings, 0 replies; only message in thread
From: Chris Friesen @ 2004-09-07 15:47 UTC (permalink / raw)
To: Linux kernel
I have a box with 1.5GB of memory and HIGHMEM enabled.
I would like to have a page of memory accessable from userspace, regular kernel
space, and late asm code on return from exceptions with no valid C context. As
far as I can see, this implies that the page tables need to be in lowmem since
having to do a kmap_atomic in asm would be painful.
It has been suggested that we could do something like the following, where this
is running on behalf of userspace which passed in a desired mapping address:
mypage = __get_free_page(GFP_KERNEL);
SetPageReserved(virt_to_page(mypage));
remap_page_range(vma->vm_start, virt_to_phys((void *) mypage), PAGE_SIZE,
vma->vm_page_prot);
This seems to work, but I'm concerned about cleanup. When the task dies, how
much cleanup will be done on the page? Does the memory subsystem handle
everything, or do I need to explicitly do something like:
reservedClearPageReserved(virt_to_page(mypage));
free_page(mypage);
Is there a better way of doing this? I had considered mmap(), but I think that
could give me pages with their page tables up in high memory.
Thanks,
Chris
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2004-09-07 17:49 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-09-07 15:47 looking for help with details of mapping pages to kernel and userspace Chris Friesen
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox