The commit is pushed to "branch-rh7-3.10.0-514.16.1.vz7.30.x-ovz" and will 
appear at https://src.openvz.org/scm/ovz/vzkernel.git
after rh7-3.10.0-514.16.1.vz7.30.3
------>
commit ad6fbf96fe30f323e03b0f872e4eeffacbfbb264
Author: Andrey Ryabinin <aryabi...@virtuozzo.com>
Date:   Tue Apr 18 18:42:01 2017 +0400

    mm/tswap: make tswap work again
    
    The same issue as with tcache in "mm/tcache: make tcache work again"
    
    Tswap uses PF_MEMALLOC to distinguish memcg recalim from global reclaim,
    but sinche upstream commit 89a2848381b5 ("mm: memcontrol: do not recurse
    in direct reclaim") this is no longer works as PF_MEMALLOC also set during
    memcg reclaim.
    
    Use new PF_MEMCG_RECLAIM instead of PF_MEMALLOC to identify per-memcg
    recalim to avoid populating tswap during global reclaim
    
    https://jira.sw.ru/browse/PSBM-64725
    
    Signed-off-by: Andrey Ryabinin <aryabi...@virtuozzo.com>
---
 mm/tswap.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/mm/tswap.c b/mm/tswap.c
index 4c6c5bc..15f5adc 100644
--- a/mm/tswap.c
+++ b/mm/tswap.c
@@ -288,7 +288,7 @@ static int tswap_frontswap_store(unsigned type, pgoff_t 
offset,
        if (cache_page)
                goto copy;
 
-       if (current->flags & PF_MEMALLOC)
+       if (!(current->flags & PF_MEMCG_RECLAIM))
                return -1;
 
        cache_page = alloc_page(TSWAP_GFP_MASK | __GFP_HIGHMEM);
_______________________________________________
Devel mailing list
Devel@openvz.org
https://lists.openvz.org/mailman/listinfo/devel

Reply via email to