Commit df9d6985be2a7e7683c46e4c6ea608fc69f02b45

Authored by Christoph Lameter
Committed by Linus Torvalds
1 parent e0c23279c9

mm: do not drain pagevecs for mlockall(MCL_FUTURE)

MCL_FUTURE does not move pages between lru list and draining the LRU per
cpu pagevecs is a nasty activity.  Avoid doing it unecessarily.

Signed-off-by: Christoph Lameter <cl@gentwo.org>
Cc: David Rientjes <rientjes@google.com>
Reviewed-by: Minchan Kim <minchan.kim@gmail.com>
Acked-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Cc: Mel Gorman <mel@csn.ul.ie>
Acked-by: Johannes Weiner <jweiner@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>

Showing 1 changed file with 2 additions and 1 deletions Side-by-side Diff

... ... @@ -549,7 +549,8 @@
549 549 if (!can_do_mlock())
550 550 goto out;
551 551  
552   - lru_add_drain_all(); /* flush pagevec */
  552 + if (flags & MCL_CURRENT)
  553 + lru_add_drain_all(); /* flush pagevec */
553 554  
554 555 down_write(&current->mm->mmap_sem);
555 556