On Wed, 2006-03-15 at 17:51 -0800, Roland Dreier wrote:
> However, we turn on the VM_* flag christmas
> > tree, in a frenzied effort to make the kernel pay no attention:
> > VM_DONTCOPY | VM_DONTEXPAND | VM_IO | VM_SHM | VM_LOCKED.
>
> I don't think you need to do anything beyond io_remap_pfn_range().
> Look at the comment inside remap_pfn_range() in mm/memory.c.
> You may want VM_DONTCOPY for fork() handling I guess.
I think we need VM_DONTCOPY for fork, as you say, and probably
VM_DONTEXPAND (for mremap). I don't know why VM_LOCKED is there, since
it seems to be internal to the mm machinery. It looks like it might be
the kernel's equivalent of MCL_FUTURE?
> As a side note, why do you use both dma_alloc_coherent() and
> pci_alloc_consistent()?
I use dma_alloc_coherent when I need to specify the GFP flags,
pci_alloc_consistent when I don't. If you'd rather see only one used,
I'll just drop pci_alloc_consistent.
> You probably want VM_RESERVED.
I'll try it.
> I don't think you want VM_IO (these
> pages are in RAM),
Probably not. The reason some of these flags crept in is that other
drivers use them to try and keep the kernel from paging the pages in
question. I'm pretty sure VM_IO is in that category, and likely
VM_LOCKED as mentioned above, too.
> and there's not much point to VM_SHM, since it's
> currently defined as:
>
> #define VM_SHM 0x00000000 /* Means nothing: delete it later */
I think that's another everyone-else-is-doing-it flag. It only became
zero in 2.6.15-rcX.
> > The nopage handler looks very normal, except it does a get_page on
> > pages marked with IPATH_VM_PIOAVAILREGS, but not on others. Presumably
> > this is because they've had SetPageReserved set on them.
>
> I think you should always be doing a get_page().
Yeah. I think so too, but when I do it, I get an oops.
<b
-
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]