Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2786031ybc; Wed, 13 Nov 2019 22:04:45 -0800 (PST) X-Google-Smtp-Source: APXvYqypkp/tJOW4SSNxMQ855q0rPc0uhxPNbA27MsJ98x4Ij3sUvr9KBrjWJxTW+dCg95e1GYMx X-Received: by 2002:a17:906:6403:: with SMTP id d3mr6759370ejm.258.1573711485395; Wed, 13 Nov 2019 22:04:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573711485; cv=none; d=google.com; s=arc-20160816; b=dY7es9cSs546qjRKuAeJkZergmgKXvVnjUOTKWP4kWl/emWHTYc5577iMhXOPxBtut cQJcrvFr7n8URNACBLT+qkqVjlY+aJqrmtULyNV7T1iOJLPZ0Xez7YkwvgDV9US2zdN9 izEq0iIJfo8iqleLY6yy/Ash5FCtyNJv6ojxh3ldF4loQIsGfe/8bpm8xdhqIXJgl17h UWMP/NZwnEHgmQy6u81sUwlSSOr3i3sXizutla+x4c2snrnc70MW8KAq/Dv6VTpzCqIW 2XgU0KMv5APtgk5+ULQpQDr9KMCqCqr4+1Pc51WnqHJ5K3a8B9Q2fHmobJjvfGd8jDhz EEKg== 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:in-reply-to :mime-version:user-agent:date:message-id:from:references:cc:to :subject; bh=COEoT/oGG37imaIjiG0dxxec6LYjgWykXukqoNR6Mdk=; b=Ey0A8FNBz9TYAjsSbafbeXX1VCEc9gtjDL2Dczs4tb0xtMNU81raKChX9YsARxxgWO 5soXxtPq61bE2FR9r7mFLKl6gsp6A2h5bAZ7hz8m86uWLZkI4M+HmN8I3ZR5UmA5Syy0 U5ea14hVdHrfWNUFJJ5dJkt0VN9YxvQhGBNH/IGdXCwyvxL5xfYQh33PtWA0I5JUFhMx 4bTdY0b5tAlZs9FFJx/QgJqqg8tMajKTDEMYFMUGXk9BXSAqGlYaMP2s6rM7SL7hC3QE jm/Epixw6CZ1Z23BiG6DHWAG2//U62j7IkDlVhU59wm1i0Sm9NKMxzZ226OQ3DjTlBQy Ve2w== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id z15si2810624eju.310.2019.11.13.22.04.20; Wed, 13 Nov 2019 22:04:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1726185AbfKNGBP (ORCPT + 99 others); Thu, 14 Nov 2019 01:01:15 -0500 Received: from out30-43.freemail.mail.aliyun.com ([115.124.30.43]:41196 "EHLO out30-43.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725601AbfKNGBP (ORCPT ); Thu, 14 Nov 2019 01:01:15 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R151e4;CH=green;DM=||false|;DS=|;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e07486;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=29;SR=0;TI=SMTPD_---0Ti1eLE7_1573711266; Received: from IT-FVFX43SYHV2H.local(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0Ti1eLE7_1573711266) by smtp.aliyun-inc.com(127.0.0.1); Thu, 14 Nov 2019 14:01:07 +0800 Subject: Re: [PATCH v2 4/8] mm/lru: only change the lru_lock iff page's lruvec is different To: Matthew Wilcox Cc: cgroups@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, 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, Johannes Weiner , Michal Hocko , Vladimir Davydov , Roman Gushchin , Shakeel Butt , Chris Down , Thomas Gleixner , Vlastimil Babka , Andrey Ryabinin , swkhack , "Potyra, Stefan" , Jason Gunthorpe , Mauro Carvalho Chehab , Peng Fan , Nikolay Borisov , Ira Weiny , Kirill Tkhai , Yafang Shao References: <1573567588-47048-1-git-send-email-alex.shi@linux.alibaba.com> <1573567588-47048-5-git-send-email-alex.shi@linux.alibaba.com> <20191112143624.GA7934@bombadil.infradead.org> <297ad71c-081c-f7e1-d640-8720a0eeeeba@linux.alibaba.com> <20191113134502.GD7934@bombadil.infradead.org> From: Alex Shi Message-ID: Date: Thu, 14 Nov 2019 14:01:06 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:60.0) Gecko/20100101 Thunderbird/60.9.1 MIME-Version: 1.0 In-Reply-To: <20191113134502.GD7934@bombadil.infradead.org> 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 在 2019/11/13 下午9:45, Matthew Wilcox 写道: >>> Why not simply: >>> >>> rcu_read_lock(); >>> lruvec = mem_cgroup_page_lruvec(page, pgdat); >>> rcu_read_unlock(); >>> >>> if (locked_lruvec == lruvec) >> The rcu_read_unlock here is for guarding the locked_lruvec/lruvec comparsion. >> Otherwise memcg/lruvec maybe changed, like, from memcg migration etc. I guess. > How does holding the RCU lock guard the comparison? You're comparing two > pointers for equality. Nothing any other CPU can do at this point will > change the results of that comparison. > Hi Matthew, Thanks for reply! The reason of guarding lruvec compasion here is a bit undistinct, in fact, it guards the page's memcg from free/migrate etc, since the lruvec is kind of binding to each of memcg. The detailed explanation could be found in lock_page_memcg(). Thanks Alex