On Thu, Nov 21, 2013 at 10:18:44PM -0800, Dave Hansen wrote: > On 11/21/2013 09:22 PM, Johannes Weiner wrote: > >> > It's a 8-socket/160-thread (one NUMA node per socket) system that is not > >> > under memory pressure during the test. The latencies are also such that > >> > vm.zone_reclaim_mode=0. > > The change will definitely spread allocations out to all nodes then > > and it's plausible that the remote references will hurt kernel object > > allocations in a tight loop. Just to confirm, could you rerun the > > test with zone_reclaim_mode enabled to make the allocator stay in the > > local zones? > > Yeah, setting vm.zone_reclaim_mode=1 fixes it pretty instantaneously. > > For what it's worth, I'm pretty convinced that the numbers folks put in > the SLIT tables are, at best, horribly inconsistent from system to > system. At worst, they're utter fabrications not linked at all to the > reality of the actual latencies. You mean the reported distances should probably be bigger on this particular machine? But even when correct, zone_reclaim_mode might not be the best predictor. Just because it's not worth yet to invest direct reclaim efforts to stay local does not mean that remote references are free. I'm currently running some tests with the below draft to see if this would still leave us with enough fairness. Does the patch restore performance even with zone_reclaim_mode disabled? --- diff --git a/mm/page_alloc.c b/mm/page_alloc.c index dd886fa..c77cead 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -1926,7 +1926,8 @@ zonelist_scan: * back to remote zones that do not partake in the * fairness round-robin cycle of this zonelist. */ - if (alloc_flags & ALLOC_WMARK_LOW) { + if ((alloc_flags & ALLOC_WMARK_LOW) && + (gfp_mask & GFP_MOVABLE_MASK)) { if (zone_page_state(zone, NR_ALLOC_BATCH) <= 0) continue; if (zone_reclaim_mode && -- 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/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>