On Tue, Apr 30, 2013 at 05:31:32PM +0400, Glauber Costa wrote: > On 04/30/2013 05:22 PM, Mel Gorman wrote: > > On Sat, Apr 27, 2013 at 03:18:58AM +0400, Glauber Costa wrote: > >> In very low free kernel memory situations, it may be the case that we > >> have less objects to free than our initial batch size. If this is the > >> case, it is better to shrink those, and open space for the new workload > >> then to keep them and fail the new allocations. > >> > >> More specifically, this happens because we encode this in a loop with > >> the condition: "while (total_scan >= batch_size)". So if we are in such > >> a case, we'll not even enter the loop. > >> > >> This patch modifies turns it into a do () while {} loop, that will > >> guarantee that we scan it at least once, while keeping the behaviour > >> exactly the same for the cases in which total_scan > batch_size. > >> > >> Signed-off-by: Glauber Costa <glommer@xxxxxxxxxx> > >> Reviewed-by: Dave Chinner <david@xxxxxxxxxxxxx> > >> Reviewed-by: Carlos Maiolino <cmaiolino@xxxxxxxxxx> > >> CC: "Theodore Ts'o" <tytso@xxxxxxx> > >> CC: Al Viro <viro@xxxxxxxxxxxxxxxxxx> > > > > There are two cases where this *might* cause a problem and worth keeping > > an eye out for. > > > > Any test case that you envision that could help bringing those issues > forward should they exist ? (aside from getting it into upstream trees > early?) > hmm. fsmark multi-threaded in a small-memory machine with a small number of very large files greater than the size of physical memory might trigger it. There should be a small number of inodes active so less than the 128 that would have been ignored before the patch. As the files are larger than memory, kswapd will be awake and calling shrinkers so if the shrinker is really discarding active inodes then the performance will degrade. -- Mel Gorman SUSE Labs -- 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>