On Mon, May 26, 2014 at 02:44:29PM -0700, Hugh Dickins wrote: > On Thu, 22 May 2014, Mel Gorman wrote: > > > This series is aimed at regressions noticed during reclaim activity. The > > first two patches are shrinker patches that were posted ages ago but never > > merged for reasons that are unclear to me. I'm posting them again to see if > > there was a reason they were dropped or if they just got lost. Dave? Time? > > The last patch adjusts proportional reclaim. Yuanhan Liu, can you retest > > the vm scalability test cases on a larger machine? Hugh, does this work > > for you on the memcg test cases? > > Yes it does, thank you. > > Though the situation is muddy, since on our current internal tree, I'm > surprised to find that the memcg test case no longer fails reliably > without our workaround and without your fix. > > "Something must have changed"; but it would take a long time to work > out what. If I travel back in time with git, to where we first applied > the "vindictive" patch, then yes that test case convincingly fails > without either (my or your) patch, and passes with either patch. > > And you have something that satisfies Yuanhan too, that's great. > > I'm also pleased to see Dave and Tim reduce the contention in > grab_super_passive(): that's a familiar symbol from livelock dumps. > > You might want to add this little 4/3, that we've had in for a > while; but with grab_super_passive() out of super_cache_count(), > it will have much less importance. > > > [PATCH 4/3] fs/superblock: Avoid counting without __GFP_FS > > Don't waste time counting objects in super_cache_count() if no __GFP_FS: > super_cache_scan() would only back out with SHRINK_STOP in that case. > > Signed-off-by: Hugh Dickins <hughd@xxxxxxxxxx> While you might think that's a good thing, it's not. The act of shrinking is kept separate from the accounting of how much shrinking needs to take place. The amount of work the shrinker can't do due to the reclaim context is deferred until the shrinker is called in a context where it can do work (eg. kswapd) Hence not accounting for work that can't be done immediately will adversely impact the balance of the system under memory intensive filesystem workloads. In these worklaods, almost all allocations are done in the GFP_NOFS or GFP_NOIO contexts so not deferring the work will will effectively stop superblock cache reclaim entirely.... Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx -- 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