From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.6 required=3.0 tests=DKIM_INVALID,DKIM_SIGNED, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 98867CA9EB7 for ; Tue, 22 Oct 2019 14:48:34 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 4AEC4218AE for ; Tue, 22 Oct 2019 14:48:34 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=cmpxchg-org.20150623.gappssmtp.com header.i=@cmpxchg-org.20150623.gappssmtp.com header.b="FvZrlFyR" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 4AEC4218AE Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=cmpxchg.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 50CBE6B000E; Tue, 22 Oct 2019 10:48:25 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 4BE8E6B0010; Tue, 22 Oct 2019 10:48:25 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3D7CD6B0266; Tue, 22 Oct 2019 10:48:25 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0003.hostedemail.com [216.40.44.3]) by kanga.kvack.org (Postfix) with ESMTP id 166AB6B000E for ; Tue, 22 Oct 2019 10:48:25 -0400 (EDT) Received: from smtpin11.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay04.hostedemail.com (Postfix) with SMTP id 7CAAB247A for ; Tue, 22 Oct 2019 14:48:24 +0000 (UTC) X-FDA: 76071701328.11.debt46_6674bf5fd5f2b X-HE-Tag: debt46_6674bf5fd5f2b X-Filterd-Recvd-Size: 5546 Received: from mail-qk1-f193.google.com (mail-qk1-f193.google.com [209.85.222.193]) by imf43.hostedemail.com (Postfix) with ESMTP for ; Tue, 22 Oct 2019 14:48:23 +0000 (UTC) Received: by mail-qk1-f193.google.com with SMTP id u22so16453001qkk.11 for ; Tue, 22 Oct 2019 07:48:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cmpxchg-org.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=TcikxxhhZnd6YbZpIU4lRQd5AagmURIl+Vuyl9j6u4o=; b=FvZrlFyRQntoTimiufrW53mtj9qQm5Pfkmi6p9CvHGf4iR1aINMvfQGfKS5J6FOE6Q +a/mswPjs8yJdf44DISKKSp7pkEDXdEPHmpL5dPfkzMfKhGowvZmJntlFeptg/YT+M/4 F1yyqrA4p/pPpGQwEYO5wWe4v1QX3CFT8wrfa/IjioJDCqvPCRNx912M+Xg1uvyLIba4 UAI8qPBU/g32WGoLKqRcwfWhJ/8NtFsyvIIeW30mb8ztOxvbZzL7agXcNuzl+ePB6+7e nyCJPye+F9FgFZgkKIcjPyM7ig4P+P+beI6kZp4hAJ8urRBGbCg/vCRTdLEj/z9s2Ymk ndjA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=TcikxxhhZnd6YbZpIU4lRQd5AagmURIl+Vuyl9j6u4o=; b=owF9B5liEh3RUT9B0+dPSAYQG+TsbsnTXIhufSWZrsnq9jXF/SOd6HzYIvoAcAuKX2 pMQmT03mmuwOrpSBCODH+bUDHWlDKVVVJ1KY8VMJmTwuTqmry2KwHrEnjFzblbg69hU0 6OLg8dAWR69P/JDz+2oeL4nx4XWf7zlAISvIegYvpEi2fvpsTwYdMJKbmBRg/LbK0jrC KwDB7eglmrpb2NmTsVnfWa9sNyTXW+Lqi8S8di11kw8XlVb/B05tEiWJwCP7AeVWEWco TERF+XGFoXYnkabLstJzHSvQ64k3xyxMnHSIENRwajy4yzDFVvkfvGLZbX2pJyVkHxPw l16Q== X-Gm-Message-State: APjAAAVBakdaAHpCembgs4V/6CV0zVFFvFEUfBEldjpqP1sqiVlRBsMJ 0Gds5CO2uymtANA6EaE6Ar0XHBXGE/s= X-Google-Smtp-Source: APXvYqwd6CQlHw+mwJeGW1LxVFd0b0qCo4M2vpP4Ov/AangPWepYRJV0QsNC4KaEIrqRkOUKo/osTA== X-Received: by 2002:a37:8183:: with SMTP id c125mr3303192qkd.279.1571755703347; Tue, 22 Oct 2019 07:48:23 -0700 (PDT) Received: from localhost ([2620:10d:c091:500::3:10ad]) by smtp.gmail.com with ESMTPSA id b4sm3862311qtt.26.2019.10.22.07.48.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 22 Oct 2019 07:48:22 -0700 (PDT) From: Johannes Weiner To: Andrew Morton Cc: Michal Hocko , linux-mm@kvack.org, cgroups@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-team@fb.com Subject: [PATCH 7/8] mm: vmscan: split shrink_node() into node part and memcgs part Date: Tue, 22 Oct 2019 10:48:02 -0400 Message-Id: <20191022144803.302233-8-hannes@cmpxchg.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191022144803.302233-1-hannes@cmpxchg.org> References: <20191022144803.302233-1-hannes@cmpxchg.org> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: This function is getting long and unwieldy, split out the memcg bits. The updated shrink_node() handles the generic (node) reclaim aspects: - global vmpressure notifications - writeback and congestion throttling - reclaim/compaction management - kswapd giving up on unreclaimable nodes It then calls a new shrink_node_memcgs() which handles cgroup specifics: - the cgroup tree traversal - memory.low considerations - per-cgroup slab shrinking callbacks - per-cgroup vmpressure notifications Signed-off-by: Johannes Weiner --- mm/vmscan.c | 28 ++++++++++++++++++---------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/mm/vmscan.c b/mm/vmscan.c index db073b40c432..65baa89740dd 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -2722,18 +2722,10 @@ static bool pgdat_memcg_congested(pg_data_t *pgda= t, struct mem_cgroup *memcg) (memcg && memcg_congested(pgdat, memcg)); } =20 -static bool shrink_node(pg_data_t *pgdat, struct scan_control *sc) +static void shrink_node_memcgs(pg_data_t *pgdat, struct scan_control *sc= ) { - struct reclaim_state *reclaim_state =3D current->reclaim_state; struct mem_cgroup *root =3D sc->target_mem_cgroup; - unsigned long nr_reclaimed, nr_scanned; - bool reclaimable =3D false; struct mem_cgroup *memcg; -again: - memset(&sc->nr, 0, sizeof(sc->nr)); - - nr_reclaimed =3D sc->nr_reclaimed; - nr_scanned =3D sc->nr_scanned; =20 memcg =3D mem_cgroup_iter(root, NULL, NULL); do { @@ -2786,6 +2778,22 @@ static bool shrink_node(pg_data_t *pgdat, struct s= can_control *sc) sc->nr_reclaimed - reclaimed); =20 } while ((memcg =3D mem_cgroup_iter(root, memcg, NULL))); +} + +static bool shrink_node(pg_data_t *pgdat, struct scan_control *sc) +{ + struct reclaim_state *reclaim_state =3D current->reclaim_state; + struct mem_cgroup *root =3D sc->target_mem_cgroup; + unsigned long nr_reclaimed, nr_scanned; + bool reclaimable =3D false; + +again: + memset(&sc->nr, 0, sizeof(sc->nr)); + + nr_reclaimed =3D sc->nr_reclaimed; + nr_scanned =3D sc->nr_scanned; + + shrink_node_memcgs(pgdat, sc); =20 if (reclaim_state) { sc->nr_reclaimed +=3D reclaim_state->reclaimed_slab; @@ -2793,7 +2801,7 @@ static bool shrink_node(pg_data_t *pgdat, struct sc= an_control *sc) } =20 /* Record the subtree's reclaim efficiency */ - vmpressure(sc->gfp_mask, sc->target_mem_cgroup, true, + vmpressure(sc->gfp_mask, root, true, sc->nr_scanned - nr_scanned, sc->nr_reclaimed - nr_reclaimed); =20 --=20 2.23.0