Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp277427ybj; Fri, 8 May 2020 11:34:18 -0700 (PDT) X-Google-Smtp-Source: APiQypI0FGPaFiQRSHlkmsV507AVrergABhn//7R9Np1dO8WO9UMhpYOYWauLt/NSi+4xNrpG8qK X-Received: by 2002:a05:6402:4a:: with SMTP id f10mr3476616edu.274.1588962858556; Fri, 08 May 2020 11:34:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588962858; cv=none; d=google.com; s=arc-20160816; b=ic0ztwVxjh4/ghJWbEymTqZuuPz6qJH/TxF2tXQMjbxr1asOrBZqp3TQ9hfTEXR1ym m7UAaCMVhcfSwVS2Yzq4bTTGi7qvhhN4hfW6fJMpK9u3w0y9jE3zEIfu5qfmCYFEPUeM SC42HqkqhjmOlp/t7uVXx0gf869pP+VBDrqY9i0uIqBNTR1xn6eTAUlmAtkR2Rd7NLPq IMt4HiXyEEWOubZ2EQcIZtqhvnSSdmgIwBP47jKE0R+dDZhesjRQuqSaVnSo8enkNnOp OOfPEEuSKlhXLSOvqEjNTQhGJ8Nssw/bvK5dGvnJpxImYwNu0Wiyfnf2w6EaLDrOLEIU wlmQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=OfCvK5ICX9RLV3lPlzIAY41JRodQH86fFkwrgQlSEf8=; b=pLGM7gd+VV7LhpkjT2Zpt7rQNi36gtaROQZcLAnKDylWRisk64a6vG5XU3cANIf8B6 OUjspgPLOU59hXwFPWPz5JkyXWaNjFgnOY3NbHcrbW03ShN9WI3O25dKViAx2n0Vtu9K VSDTh8msFPZB7NqVuDWC0JIsrnEUj1+qrTkjRgJSFc/LnFBE4aV2pxq52JKR+DUtFM7d HbDp9YyUYER3EU0j80t9bDDGpvLCmi7cioTgXA61teCMXlILUGw8Br11IKzhsQ7whuGQ 7UhG8YpSMpyXuoWDtnyFJ0umVlf419QVaKfRjW2D9dLCgZdHFtIqrMTPDB4mob3T047e 0dIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cmpxchg-org.20150623.gappssmtp.com header.s=20150623 header.b=CmwijAWG; 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=cmpxchg.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i28si1480446edj.224.2020.05.08.11.33.55; Fri, 08 May 2020 11:34:18 -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; dkim=pass header.i=@cmpxchg-org.20150623.gappssmtp.com header.s=20150623 header.b=CmwijAWG; 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=cmpxchg.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727932AbgEHSc0 (ORCPT + 99 others); Fri, 8 May 2020 14:32:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57798 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727912AbgEHScY (ORCPT ); Fri, 8 May 2020 14:32:24 -0400 Received: from mail-qk1-x742.google.com (mail-qk1-x742.google.com [IPv6:2607:f8b0:4864:20::742]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A72A1C05BD0B for ; Fri, 8 May 2020 11:32:24 -0700 (PDT) Received: by mail-qk1-x742.google.com with SMTP id s9so1725100qkm.6 for ; Fri, 08 May 2020 11:32:24 -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=OfCvK5ICX9RLV3lPlzIAY41JRodQH86fFkwrgQlSEf8=; b=CmwijAWGrB9GpiDIRRkJD4jSnT43gKAmAnGfjMaA25Kt/6/LLUOt4eOCmLPfSIMGOT aW9ShVJ6f895PpkJvDJVVoFWx5BgKEjpiM1k6aB0HHEse5SZQ2jgfYQwrhgGFc295/53 c0firhINkXK8AhvGbh6gPtL7EkztISznspA8/2XedHiWj27+y2kPRk+C3Qyyd37UqCb/ Llgeupzc7yudqB6GBoOzm51I3hJ4r0VphHkIxYSiDfkxQJHcvK4xfuG+CLwHYBO4dkIO LbKGvdO0IK037kd4xPNaYTmJxNke7bjWj88R1s0cINtHKjji7z8isPYV8KpPWPEjBxTw d/wg== 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=OfCvK5ICX9RLV3lPlzIAY41JRodQH86fFkwrgQlSEf8=; b=KAiIl5mnBBjJRjtCOokufO+pEv31/S2tTssu77Hx/5nxBCtZB5/tkmcfJEW84fEWxv Gqw4ouqXq98uhUIgb3F2G0QjoyNWpFiBicalOgj+xhOhS9/LMd22v6MAmX9OIHzVL14n G8j2P/81fy/5E1Qi0VyO93yrQ9PStJ+7AKxeprbmU4/yHwKgUdaUV6Q6DRWLlhqQw2Zh huYgNuN/cs+5rog3D+EhC44NwpzhZwA3MJELAdSvR/V+8jZGoABc8F2esnoy8IMWBacd uwsvSFNaRGB7MnBdz2UIp/dqLFG30ziSKGfv1H/dFLF4mi1WA1MfFB7B7rf20xa5vKt6 0ryQ== X-Gm-Message-State: AGi0PuYtuyOYvzQtru+0qqOQPAHPPusyJQjFMnaBtaxcW4b96AsX5aBy PSbTln4yR236VZy04vcHC8+RIA== X-Received: by 2002:a37:a417:: with SMTP id n23mr4055028qke.480.1588962743924; Fri, 08 May 2020 11:32:23 -0700 (PDT) Received: from localhost ([2620:10d:c091:480::1:2627]) by smtp.gmail.com with ESMTPSA id s4sm2145270qth.61.2020.05.08.11.32.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 08 May 2020 11:32:23 -0700 (PDT) From: Johannes Weiner To: Andrew Morton Cc: Alex Shi , Joonsoo Kim , Shakeel Butt , Hugh Dickins , Michal Hocko , "Kirill A. Shutemov" , Roman Gushchin , linux-mm@kvack.org, cgroups@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-team@fb.com Subject: [PATCH 07/19] mm: memcontrol: prepare move_account for removal of private page type counters Date: Fri, 8 May 2020 14:30:54 -0400 Message-Id: <20200508183105.225460-8-hannes@cmpxchg.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200508183105.225460-1-hannes@cmpxchg.org> References: <20200508183105.225460-1-hannes@cmpxchg.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When memcg uses the generic vmstat counters, it doesn't need to do anything at charging and uncharging time. It does, however, need to migrate counts when pages move to a different cgroup in move_account. Prepare the move_account function for the arrival of NR_FILE_PAGES, NR_ANON_MAPPED, NR_ANON_THPS etc. by having a branch for files and a branch for anon, which can then divided into sub-branches. Signed-off-by: Johannes Weiner Reviewed-by: Alex Shi Reviewed-by: Joonsoo Kim --- mm/memcontrol.c | 25 +++++++++++++------------ 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/mm/memcontrol.c b/mm/memcontrol.c index a5efdad77be4..fe4212db8411 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -5378,7 +5378,6 @@ static int mem_cgroup_move_account(struct page *page, struct pglist_data *pgdat; unsigned int nr_pages = compound ? hpage_nr_pages(page) : 1; int ret; - bool anon; VM_BUG_ON(from == to); VM_BUG_ON_PAGE(PageLRU(page), page); @@ -5396,25 +5395,27 @@ static int mem_cgroup_move_account(struct page *page, if (page->mem_cgroup != from) goto out_unlock; - anon = PageAnon(page); - pgdat = page_pgdat(page); from_vec = mem_cgroup_lruvec(from, pgdat); to_vec = mem_cgroup_lruvec(to, pgdat); lock_page_memcg(page); - if (!anon && page_mapped(page)) { - __mod_lruvec_state(from_vec, NR_FILE_MAPPED, -nr_pages); - __mod_lruvec_state(to_vec, NR_FILE_MAPPED, nr_pages); - } + if (!PageAnon(page)) { + if (page_mapped(page)) { + __mod_lruvec_state(from_vec, NR_FILE_MAPPED, -nr_pages); + __mod_lruvec_state(to_vec, NR_FILE_MAPPED, nr_pages); + } - if (!anon && PageDirty(page)) { - struct address_space *mapping = page_mapping(page); + if (PageDirty(page)) { + struct address_space *mapping = page_mapping(page); - if (mapping_cap_account_dirty(mapping)) { - __mod_lruvec_state(from_vec, NR_FILE_DIRTY, -nr_pages); - __mod_lruvec_state(to_vec, NR_FILE_DIRTY, nr_pages); + if (mapping_cap_account_dirty(mapping)) { + __mod_lruvec_state(from_vec, NR_FILE_DIRTY, + -nr_pages); + __mod_lruvec_state(to_vec, NR_FILE_DIRTY, + nr_pages); + } } } -- 2.26.2