On Wed, 19 Sep 2007, Andi Kleen wrote: > > alloc_page(GFP_VFALLBACK, order, ....) > > Is there a reason this needs to be a GFP flag versus a wrapper > around alloc_page/free_page ? page_alloc.c is already too complicated > and it's better to keep new features separated. The only drawback > would be that free_pages would need a different call, but that > doesn't seem like a big problem. I tried to make this a wrapper but there is a lot of logic in __alloc_pages() that would have to be replicated. Also there are specific places in __alloc_pages() were we can establish that we have enough memory but its the memory fragmentation that prevents us from satisfying the request for a larger page. > I'm also a little dubious about your attempts to do vmalloc in > interrupt context. Is that really needed? GFP_ATOMIC allocations of > large areas seem to be extremly unreliable to me and not design. Even > if it works sometimes free probably wouldn't work there due to the > flushes, which is very nasty. It would be better to drop that. The flushes are only done on virtuall mapped architectures (xtensa) and are simple ASM code that can run in an interrupt context - To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html