Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4705690pxu; Mon, 21 Dec 2020 21:23:22 -0800 (PST) X-Google-Smtp-Source: ABdhPJwK9Ve7S4GjoW1ANcD3aZ9v2lmKg9WjKNmfoKmFltUivler/veJapsHAAbBApdMEy8WCN7l X-Received: by 2002:a17:906:2681:: with SMTP id t1mr18480217ejc.29.1608614602487; Mon, 21 Dec 2020 21:23:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608614602; cv=none; d=google.com; s=arc-20160816; b=L1ncFaCGf4teBuXRxoF/YXPUzAF+OzWV7iLH/tGbkk20F8r4VOPoeYNiJLjRaUzSEP PD8WSc/hvgoOySkHGdVqP5Nmd1pqqMwhJUSNS5Ht29WALtZci7cnKVTXxQsWMe2lFXUC 2/PHKVVnPF8X14nmVIGI7jGow1WlydECVB0sd3hvcJ1rh8tAyxfDgTqzfS3p7TBFmi9/ NYSsUn0+SvHjjVF7m0SdoHthEiu3e7E15QWOwAIYQAq01NK+Zu/XFDqWk5pDPXsljsKs 6xT2wviag4G19D5F1XYVLXYOn2M06kuWrnL6UvxuySkeRkvvcVwdoFzq4IY7FA+JamGk PQQg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=YVbuI3w1GqeDMv5nM5zfUoGOD7VysXmaYmJ6tPdCHlQ=; b=UvDL64Ik8UX2E9mVKwvjcZVXjdRrOSWA65BWbkUdszq9AMRfKl8LwY4gIrC5HCZAGS 5Qva45tBWPKyxWgQRhG4GJiasyMFgXcJ+IvL4Ob3zWAp6C2zGztNlxtoesAjiFDV8dan qUtr9WJ786lao3gkHmxHwGu09RIoPZOMOTPVFMwUysHT6f5xFgplJmAeaUWRH3VLXpvh 1vHdOO6EDF5xK6peAXqA1LUlx4vhsheFEjEorjbfDLudjLm7yvD3BjmBIEraGpSM0QFJ 4/ZmXdeXqYgHE5Jc3nonlzSJ4bUozeeKG1MBcmN1W0ibO7wY/agNJAh5hwi/VWeZmnhT 53Kw== 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 dn20si11233141ejc.748.2020.12.21.21.23.00; Mon, 21 Dec 2020 21:23:22 -0800 (PST) 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 S1725826AbgLVFVr (ORCPT + 99 others); Tue, 22 Dec 2020 00:21:47 -0500 Received: from out30-133.freemail.mail.aliyun.com ([115.124.30.133]:35224 "EHLO out30-133.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725782AbgLVFVr (ORCPT ); Tue, 22 Dec 2020 00:21:47 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R741e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04395;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=8;SR=0;TI=SMTPD_---0UJPqUQy_1608614460; Received: from aliy80.localdomain(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0UJPqUQy_1608614460) by smtp.aliyun-inc.com(127.0.0.1); Tue, 22 Dec 2020 13:21:00 +0800 From: Alex Shi To: hughd@google.com Cc: Johannes Weiner , Michal Hocko , Vladimir Davydov , Andrew Morton , cgroups@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 2/3] mm/memcg: remove rcu locking for lock_page_lruvec function series Date: Tue, 22 Dec 2020 13:20:52 +0800 Message-Id: <1608614453-10739-2-git-send-email-alex.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1608614453-10739-1-git-send-email-alex.shi@linux.alibaba.com> References: <1608614453-10739-1-git-send-email-alex.shi@linux.alibaba.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org lock_page_lruvec() and its variants used rcu_read_lock() with the intention of safeguarding against the mem_cgroup being destroyed concurrently; but so long as they are called under the specified conditions (as they are), there is no way for the page's mem_cgroup to be destroyed. Delete the unnecessary rcu_read_lock() and _unlock(). Hugh Dickin's polished the commit log, Thanks a lot! Signed-off-by: Alex Shi Acked-by: Hugh Dickins Cc: Hugh Dickins Cc: Johannes Weiner Cc: Michal Hocko Cc: Vladimir Davydov Cc: Andrew Morton Cc: cgroups@vger.kernel.org Cc: linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org --- mm/memcontrol.c | 6 ------ 1 file changed, 6 deletions(-) diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 8d400efc81b9..0af13c4fe4b3 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -1356,10 +1356,8 @@ struct lruvec *lock_page_lruvec(struct page *page) struct lruvec *lruvec; struct pglist_data *pgdat = page_pgdat(page); - rcu_read_lock(); lruvec = mem_cgroup_page_lruvec(page, pgdat); spin_lock(&lruvec->lru_lock); - rcu_read_unlock(); lruvec_memcg_debug(lruvec, page); @@ -1371,10 +1369,8 @@ struct lruvec *lock_page_lruvec_irq(struct page *page) struct lruvec *lruvec; struct pglist_data *pgdat = page_pgdat(page); - rcu_read_lock(); lruvec = mem_cgroup_page_lruvec(page, pgdat); spin_lock_irq(&lruvec->lru_lock); - rcu_read_unlock(); lruvec_memcg_debug(lruvec, page); @@ -1386,10 +1382,8 @@ struct lruvec *lock_page_lruvec_irqsave(struct page *page, unsigned long *flags) struct lruvec *lruvec; struct pglist_data *pgdat = page_pgdat(page); - rcu_read_lock(); lruvec = mem_cgroup_page_lruvec(page, pgdat); spin_lock_irqsave(&lruvec->lru_lock, *flags); - rcu_read_unlock(); lruvec_memcg_debug(lruvec, page); -- 2.29.GIT