Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp233575pxa; Tue, 18 Aug 2020 22:51:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxT5tqbRAEvurwU+NxpLthGJPNbZ9kQoWOdeEutHxbvjQnHcOHqnvIOgStIAlb194tmmOFd X-Received: by 2002:a17:906:7d6:: with SMTP id m22mr22677988ejc.229.1597816319262; Tue, 18 Aug 2020 22:51:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597816319; cv=none; d=google.com; s=arc-20160816; b=wU2X86AbBdc6rfb4fqWsHEkknYOk+geUvCE38tS3TNW7X3bc0WoslF/t3/f7AM+FJK VVuoXPTqz2ZRX7EVjFZ/MVGGiEEwrfdgishD2B4MqH8qcjbjDNsnx7WQ4cm/Q/4g8f2n 23NpCYfTEmL8uPmDI4ACdgSDfmjRmlCPDBslCskThCVIhlwzKQxhlgdIOLh7OacdAMb3 q4sql00v96HvZlDVXFssQOInfd3p50Q/EhtE+nUug12ji6Xnj5zVf90nTSYM/a0NJBUW 53H2FkhMyMOwPVV16sCQBFXCtvXpNGIaA+3PMDFhpjDAg3SKmniguNI+AZjNCrKGH0Pw BARQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=HVpzAramuDg2JhAz76qajoqqmXHsf3ryigSPMYU9qA0=; b=ireKlJgOl0YIignMVZMXo3gIXcQ+u+nrQVM1XsxmT/rc4XO9UoZ/ogd6yEjnhIeeeb +X/JFBM7BctRFmrhdJ9quuZduzybU77me5aBDoOV//O1Wf/6XG/6CUtOryLZ+QGF5ivd pREFPUwPpNOYn2ULe5lvuG66FWAwrXkyXSogCNL2iGPL/cdRrJr6klqff+3CrhcTdYfD mgzXUSWVTGU2/f5O4Mjxe/YDi6Hzna0yT1189lHyIGOyHezQ+S7ton/mBGGFjZNjTb69 mIjQ+Juyd0IjLWrgIAT9ais6zRyQMFTw+Duj61N1BF9qbCZnha4kJLSgG5iDHiD3qGhe cvBw== 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 q11si15765849ejt.551.2020.08.18.22.51.35; Tue, 18 Aug 2020 22:51:59 -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 S1726646AbgHSFs2 (ORCPT + 99 others); Wed, 19 Aug 2020 01:48:28 -0400 Received: from out30-43.freemail.mail.aliyun.com ([115.124.30.43]:40044 "EHLO out30-43.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726531AbgHSFs1 (ORCPT ); Wed, 19 Aug 2020 01:48:27 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R111e4;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=7;SR=0;TI=SMTPD_---0U6CFft4_1597816103; Received: from aliy80.localdomain(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0U6CFft4_1597816103) by smtp.aliyun-inc.com(127.0.0.1); Wed, 19 Aug 2020 13:48:24 +0800 From: Alex Shi To: Matthew Wilcox , David Hildenbrand Cc: Andrew Morton , Hugh Dickins , Alexander Duyck , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH v2 2/2] mm/pageblock: remove false sharing in pageblock_flags Date: Wed, 19 Aug 2020 13:47:55 +0800 Message-Id: <1597816075-61091-2-git-send-email-alex.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1597816075-61091-1-git-send-email-alex.shi@linux.alibaba.com> References: <1597816075-61091-1-git-send-email-alex.shi@linux.alibaba.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Current pageblock_flags is only 4 bits, so it has to share a char size in cmpxchg when get set, the false sharing cause perf drop. If we incrase the bits up to 8, false sharing would gone in cmpxchg. and the only cost is half char per pageblock, which is half char per 128MB on x86, 4 chars in 1 GB. Signed-off-by: Alex Shi Cc: Andrew Morton Cc: Hugh Dickins Cc: Alexander Duyck Cc: linux-kernel@vger.kernel.org Cc: linux-mm@kvack.org --- include/linux/pageblock-flags.h | 2 +- mm/page_alloc.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/include/linux/pageblock-flags.h b/include/linux/pageblock-flags.h index d189441568eb..f785c9d6d68c 100644 --- a/include/linux/pageblock-flags.h +++ b/include/linux/pageblock-flags.h @@ -25,7 +25,7 @@ enum pageblock_bits { * Assume the bits will always align on a word. If this assumption * changes then get/set pageblock needs updating. */ - NR_PAGEBLOCK_BITS + NR_PAGEBLOCK_BITS = BITS_PER_BYTE }; #ifdef CONFIG_HUGETLB_PAGE diff --git a/mm/page_alloc.c b/mm/page_alloc.c index f60071e8a4e1..65f692c762d5 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -517,7 +517,7 @@ void set_pfnblock_flags_mask(struct page *page, unsigned long flags, unsigned long bitidx, byte_bitidx; unsigned char old_byte, byte; - BUILD_BUG_ON(NR_PAGEBLOCK_BITS != 4); + BUILD_BUG_ON(NR_PAGEBLOCK_BITS != BITS_PER_BYTE); BUILD_BUG_ON(MIGRATE_TYPES > (1 << PB_migratetype_bits)); bitmap = get_pageblock_bitmap(page, pfn); -- 1.8.3.1