On Wed, 8 Feb 2012, Mel Gorman wrote: > Ok, I looked into what is necessary to replace these with checking a page > flag and the cost shifts quite a bit and ends up being more expensive. That is only true if you go the slab route. Slab suffers from not having the page struct pointer readily available. The changes are likely already impacting slab performance without the virt_to_page patch. > In slub, it's sufficient to check kmem_cache_cpu to know whether the > objects in the list are pfmemalloc or not. We try to minimize the size of kmem_cache_cpu. The page pointer is readily available. We just removed the node field from kmem_cache_cpu because it was less expensive to get the node number from the struct page field. The same is certainly true for a PFMEMALLOC flag. > Yeah, you're right on the button there. I did my checking assuming that > PG_active+PG_slab were safe to use. The following is an untested patch that > I probably got details wrong in but it illustrates where virt_to_page() > starts cropping up. Yes you need to come up with a way to not use virt_to_page otherwise slab performance is significantly impacted. On NUMA we are already doing a page struct lookup on free in slab. If you would save the page struct pointer there and reuse it then you would not have an issue at least on free. You still would need to determine which "struct slab" pointer is in use which will also require similar lookups in varous places. Transfer of the pfmemalloc flags (guess you must have a pfmemalloc field in struct slab then) in slab is best be done when allocating and freeing a slab page from the page allocator. I think its rather trivial to add the support you want in a non intrusive way to slub. Slab would require some more thought and discussion. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>