Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3186253ybt; Sat, 4 Jul 2020 08:48:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxdeJbZQOQVEhI5EQe4ZTxMrRzGL5FmflN1kKltoysewoz4T1Oqis3MCFjhqPs3EK78OP5x X-Received: by 2002:a50:da44:: with SMTP id a4mr41120248edk.379.1593877702842; Sat, 04 Jul 2020 08:48:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593877702; cv=none; d=google.com; s=arc-20160816; b=WwXY/d0Pt7AoII8yXrwRqzPZx0Qajb0auR18WdHzBK0xJQ1lhykNznPUBViVAXkWqV yM+xQMPHJNM7Bm/Hngv4oDlqg0keNHs3iS0c60Tfpfyqa7KMbVvicHDq6FBCyLZIjv7n dlRD3PaGtgiz6S7Hco6/2Iu40DlCU2EemtlQO0U32XMS4d8+x5iEOhR9EcZN+zUL3Wlt alwlfeJyiFhBVjfafpvXDWKIuaDjQjuHblnjb1QLDOTRkqZa8qHs7nUSep/pnUf1BUuV 0pKbWG7A74oLkz8fJLx2zsiINqxxdF96C/G4b3Im3ALDxgFkUlSdd2okytzAGp6LyhsR jwMA== 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=A9p8OhYbT8mDkuUAmTHp/5LSPJF9O1fvl+eQdut5zY4=; b=Chbo4TqUNrSpcNwRQYxrFeScY0LLyITs4NlQsq0faUdgZfVU+F0np44EDugVuLSpHq w6vET0mtvrpCd3XpEwCC4pzsr7czccTEFLR/KqPxx/2OJCYQrASpxgb/QysCJCPY6Koy 5WxWHEfQAFOKZWVdWuswDWhTIjJXzhObz8tr8y3ulYIcUcxkZvxIWLZd9CXVmCsIg8Zg UIQRj158TyyeNNPSb/0HcbJVz6CKChKKP9GxC/swhXqItjRel/SxRATHnQauNbroVVUs qrO6Z27zt8IwARci88Hs1LGBBojAh45kew/gY9YlGLLEe63vKPas5f/26euaze05Hm5W 0Nkw== 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 i26si9605797ejy.58.2020.07.04.08.47.59; Sat, 04 Jul 2020 08:48:22 -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 S1726922AbgGDPry (ORCPT + 99 others); Sat, 4 Jul 2020 11:47:54 -0400 Received: from out30-43.freemail.mail.aliyun.com ([115.124.30.43]:47953 "EHLO out30-43.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726501AbgGDPry (ORCPT ); Sat, 4 Jul 2020 11:47:54 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R381e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04357;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=17;SR=0;TI=SMTPD_---0U1ffIy7_1593877655; Received: from IT-FVFX43SYHV2H.lan(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0U1ffIy7_1593877655) by smtp.aliyun-inc.com(127.0.0.1); Sat, 04 Jul 2020 23:47:36 +0800 Subject: Re: [PATCH v14 15/20] mm/swap: serialize memcg changes during pagevec_lru_move_fn To: Matthew Wilcox Cc: Konstantin Khlebnikov , Andrew Morton , Mel Gorman , Tejun Heo , Hugh Dickins , =?UTF-8?B?0JrQvtC90YHRgtCw0L3RgtC40L0g0KXQu9C10LHQvdC40LrQvtCy?= , daniel.m.jordan@oracle.com, yang.shi@linux.alibaba.com, Johannes Weiner , lkp@intel.com, linux-mm@kvack.org, Linux Kernel Mailing List , Cgroups , shakeelb@google.com, Joonsoo Kim , richard.weiyang@gmail.com References: <1593752873-4493-1-git-send-email-alex.shi@linux.alibaba.com> <1593752873-4493-16-git-send-email-alex.shi@linux.alibaba.com> <56e395c6-81e7-7163-0d4f-42b91573289f@linux.alibaba.com> <20200704113944.GN25523@casper.infradead.org> <20200704133330.GP25523@casper.infradead.org> From: Alex Shi Message-ID: <4a42888e-4d7e-0d76-358c-9a073e6e4794@linux.alibaba.com> Date: Sat, 4 Jul 2020 23:47:11 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200704133330.GP25523@casper.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 在 2020/7/4 下午9:33, Matthew Wilcox 写道: > On Sat, Jul 04, 2020 at 09:12:46PM +0800, Alex Shi wrote: >> 在 2020/7/4 下午7:39, Matthew Wilcox 写道: >>> On Sat, Jul 04, 2020 at 07:34:59PM +0800, Alex Shi wrote: >>>> That's a great idea! Guess what the new struct we need would be like this? >>>> I like to try this. :) >>>> >>>> >>>> diff --git a/include/linux/pagevec.h b/include/linux/pagevec.h >>>> index 081d934eda64..d62778c8c184 100644 >>>> --- a/include/linux/pagevec.h >>>> +++ b/include/linux/pagevec.h >>>> @@ -20,7 +20,7 @@ >>>> struct pagevec { >>>> unsigned char nr; >>>> bool percpu_pvec_drained; >>>> - struct page *pages[PAGEVEC_SIZE]; >>>> + struct list_head veclist; >>>> }; >>> >>> pagevecs are used not just for LRU. If you want to use a list_head for >>> LRU then define a new structure. >> >> yes, there are much page don't use page->lru, like slab etc. we need a new struct> > That's not what I mean. Slab pages aren't on the LRU anyway. Right. I mean, that's reason for a new struct if we change to list. > > Consider the callers of page_cache_delete_batch(). These use a pagevec > for a non-LRU purpose, and they will be much slower with a list_head than > with an array. > Thanks for the info. If the list is slower than pagevec, maybe it's not worth to do the change. Since pagevec could handle any kind of pages, anon/file, non-active/active, but one list only fit for just one kind of list. 5 kinds of list adding would increase the complexity. Consider this, I am wondering if it's worth? Thanks Alex