Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp970312ybt; Fri, 10 Jul 2020 18:03:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZpR+n0FvDbMHgi6yQeIwInxhe6Z8NvcvQzRMwqL5IAmSR7+Lbz4Yv12TMaGrr5cOna5ol X-Received: by 2002:a17:906:95d6:: with SMTP id n22mr63694070ejy.138.1594429421720; Fri, 10 Jul 2020 18:03:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594429421; cv=none; d=google.com; s=arc-20160816; b=cunV+M81ZTbzh8YBHLI/YM79dBkgWS/4sRao+r0/UR//My6w7VVktPdODiFJt151en 1+mvjolZDVjSD9ZPS+qQpGZDnWfJ8VFVRcMtWlBiA3y9cCuFfGACp6qAicBMPv/E/Mtn mBXbA0VpW4JQymSTdjbKueRB7xD83G/f7u8tMuGcU7cO6GUjStk5RM94FcW4hW6Ia4Vo Qt7yBoXxYSSwO2GyTviwvkmFAQuD8fLeJRFtbBUV3W8/KVQDQRtUdVXFBjbcBRsc5jm8 1hAAxZU8zC9xnNyq7GShernrmlTPOK/HU+4y8UXnfhUpUHZPuBtwlvqcdzso7gHylD6m 5dQQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:to:from; bh=RPQ1RSTgZCN7q+PYnDlBG6Mdppo4TEJqwEOtkj5CDV0=; b=wpj72rmV0dDRKFQaT2r+V6S5nxr1XGEDNoomiWkp151r81LWfHk2wmM8N+tlaJY502 16o6RhLQ+O3Mf7NvKZDjaDhTQzyeCcSTV9EwUMunC8cQxAURTvFHRCM1vvGpj+ZmdPyo Tr0Mr5VfO+q0QZ+Ofg7isAlKWzWmWgFEM3cvuiNxzSGsC64NIOHvKAFzYbFv1RSWHiCU WbyvZ4ZydXla87Pjx56LnvO6gxSVHbp+8PbhWbFFWCT3k/HikB+l8KPXroAnW/1Lxz2g heCCyvxBBagCIlYOj6Qc00420tmpfq8fOP+FmegfsCjoEuY/WNWcmRYa2Aro4dVCvaS7 P4KQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k23si5119257eds.14.2020.07.10.18.03.18; Fri, 10 Jul 2020 18:03:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728135AbgGKBAW (ORCPT + 99 others); Fri, 10 Jul 2020 21:00:22 -0400 Received: from out30-42.freemail.mail.aliyun.com ([115.124.30.42]:48885 "EHLO out30-42.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726606AbgGKA7F (ORCPT ); Fri, 10 Jul 2020 20:59:05 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R221e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01f04427;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=17;SR=0;TI=SMTPD_---0U2KGAZr_1594429139; Received: from alexshi-test.localdomain(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0U2KGAZr_1594429139) by smtp.aliyun-inc.com(127.0.0.1); Sat, 11 Jul 2020 08:58:59 +0800 From: Alex Shi To: akpm@linux-foundation.org, mgorman@techsingularity.net, tj@kernel.org, hughd@google.com, khlebnikov@yandex-team.ru, daniel.m.jordan@oracle.com, yang.shi@linux.alibaba.com, willy@infradead.org, hannes@cmpxchg.org, lkp@intel.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org, cgroups@vger.kernel.org, shakeelb@google.com, iamjoonsoo.kim@lge.com, richard.weiyang@gmail.com, kirill@shutemov.name Subject: [PATCH v16 00/22] per memcg lru_lock Date: Sat, 11 Jul 2020 08:58:34 +0800 Message-Id: <1594429136-20002-1-git-send-email-alex.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The new version which bases on v5.8-rc4. Add 2 more patchs: 'mm/thp: remove code path which never got into' 'mm/thp: add tail pages into lru anyway in split_huge_page()' and modified 'mm/mlock: reorder isolation sequence during munlock' Current lru_lock is one for each of node, pgdat->lru_lock, that guard for lru lists, but now we had moved the lru lists into memcg for long time. Still using per node lru_lock is clearly unscalable, pages on each of memcgs have to compete each others for a whole lru_lock. This patchset try to use per lruvec/memcg lru_lock to repleace per node lru lock to guard lru lists, make it scalable for memcgs and get performance gain. Currently lru_lock still guards both lru list and page's lru bit, that's ok. but if we want to use specific lruvec lock on the page, we need to pin down the page's lruvec/memcg during locking. Just taking lruvec lock first may be undermined by the page's memcg charge/migration. To fix this problem, we could take out the page's lru bit clear and use it as pin down action to block the memcg changes. That's the reason for new atomic func TestClearPageLRU. So now isolating a page need both actions: TestClearPageLRU and hold the lru_lock. The typical usage of this is isolate_migratepages_block() in compaction.c we have to take lru bit before lru lock, that serialized the page isolation in memcg page charge/migration which will change page's lruvec and new lru_lock in it. The above solution suggested by Johannes Weiner, and based on his new memcg charge path, then have this patchset. (Hugh Dickins tested and contributed much code from compaction fix to general code polish, thanks a lot!). The patchset includes 3 parts: 1, some code cleanup and minimum optimization as a preparation. 2, use TestCleanPageLRU as page isolation's precondition 3, replace per node lru_lock with per memcg per node lru_lock Following Daniel Jordan's suggestion, I have run 208 'dd' with on 104 containers on a 2s * 26cores * HT box with a modefied case: https://git.kernel.org/pub/scm/linux/kernel/git/wfg/vm-scalability.git/tree/case-lru-file-readtwice With this patchset, the readtwice performance increased about 80% in concurrent containers. Thanks Hugh Dickins and Konstantin Khlebnikov, they both brought this idea 8 years ago, and others who give comments as well: Daniel Jordan, Mel Gorman, Shakeel Butt, Matthew Wilcox etc. Thanks for Testing support from Intel 0day and Rong Chen, Fengguang Wu, and Yun Wang. Hugh Dickins also shared his kbuild-swap case. Thanks! Alex Shi (20): mm/vmscan: remove unnecessary lruvec adding mm/page_idle: no unlikely double check for idle page counting mm/compaction: correct the comments of compact_defer_shift mm/compaction: rename compact_deferred as compact_should_defer mm/thp: move lru_add_page_tail func to huge_memory.c mm/thp: clean up lru_add_page_tail mm/thp: remove code path which never got into mm/thp: narrow lru locking mm/memcg: add debug checking in lock_page_memcg mm/swap: fold vm event PGROTATED into pagevec_move_tail_fn mm/lru: move lru_lock holding in func lru_note_cost_page mm/lru: move lock into lru_note_cost mm/lru: introduce TestClearPageLRU mm/thp: add tail pages into lru anyway in split_huge_page() mm/compaction: do page isolation first in compaction mm/mlock: reorder isolation sequence during munlock mm/swap: serialize memcg changes during pagevec_lru_move_fn mm/lru: replace pgdat lru_lock with lruvec lock mm/lru: introduce the relock_page_lruvec function mm/pgdat: remove pgdat lru_lock Hugh Dickins (2): mm/vmscan: use relock for move_pages_to_lru mm/lru: revise the comments of lru_lock Documentation/admin-guide/cgroup-v1/memcg_test.rst | 15 +- Documentation/admin-guide/cgroup-v1/memory.rst | 21 +-- Documentation/trace/events-kmem.rst | 2 +- Documentation/vm/unevictable-lru.rst | 22 +-- include/linux/compaction.h | 4 +- include/linux/memcontrol.h | 98 +++++++++++ include/linux/mm_types.h | 2 +- include/linux/mmzone.h | 6 +- include/linux/page-flags.h | 1 + include/linux/swap.h | 4 +- include/trace/events/compaction.h | 2 +- mm/compaction.c | 113 ++++++++---- mm/filemap.c | 4 +- mm/huge_memory.c | 47 +++-- mm/memcontrol.c | 71 +++++++- mm/memory.c | 3 - mm/mlock.c | 93 +++++----- mm/mmzone.c | 1 + mm/page_alloc.c | 1 - mm/page_idle.c | 8 - mm/rmap.c | 4 +- mm/swap.c | 189 ++++++++------------- mm/swap_state.c | 2 - mm/vmscan.c | 174 ++++++++++--------- mm/workingset.c | 2 - 25 files changed, 524 insertions(+), 365 deletions(-) -- 1.8.3.1