Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1413730pxk; Mon, 31 Aug 2020 19:52:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyExA1AKgw53O4e6ufZumuq8vz36sF1V0MlbyFcHsG/tMjJMFS4IRZS21sGVqW0sQ+K/mE9 X-Received: by 2002:a17:906:c0d1:: with SMTP id bn17mr1242709ejb.311.1598928745456; Mon, 31 Aug 2020 19:52:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598928745; cv=none; d=google.com; s=arc-20160816; b=a8dXQ2nvmiPDjnm6CI/XwXlkJlD0HGPZtpBaAsSotMxxmz7WPozvc5Kgc5FBMNG1wn CGGxbHgKeary+YfIqs2kxdxrGWDYsUO0WmSyM2kSJkc9ANnXvm3jtgzIP5dJccdI2iGt juzmH37pFZ0piommj2dO1GYzAzy3cRSIn6lvQHtg3lUDXb9+Fom1SY48gB4gKJx4mcn0 qFXUY/bstrIUH6HHEOVYbWEvcNmwDkSXaWgHhwrT6GHJ7lH3rAhbmRwtBaFmSoXOKYLz Gtd8N7uca/KfhP47iZtKjNfeuE0cwfBwMD+8lhkpvMiCIy7OIc6N78sPs9bbJtnPTuO/ iHPA== 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=k89r7fRpIYZn4Fho7DSEJRL7sKofy8DUbS4WF6Eu9XY=; b=IQvr2uI7Dcosh2Z7+8JWRQOGyBe7FnuOQN0zVxQNlzY2RCbP0dVSwxsY+IDyJq3I9m 4i7cnsG6h1Cya4U5ZPtNql0Hs2JDG5bCf95+BjglXuEOs08oYLbi/uGFUVqlYbhgPIuA 0AY9+sOhx/kNJe5NnyD6qsJ5j5NVsj1dBq3H0p50rP3VAkJ2uBuQ/HGebOpuCAh3AfVZ I/Ps5oZdGrAxlkycxh7PoW2ncqpsA3JFmiT6h/I+z3ZvfbiCUIbT2veI62YWVPzPvdfN PwltFOENA5RBrXW7yzSlNwtl6PU9U+BgwtbqUhfoLk2FhcC1fwing1g03/SNzN0AdNCJ W02w== 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 jw7si5880501ejb.53.2020.08.31.19.52.02; Mon, 31 Aug 2020 19:52:25 -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 S1726068AbgIACu0 (ORCPT + 99 others); Mon, 31 Aug 2020 22:50:26 -0400 Received: from out30-44.freemail.mail.aliyun.com ([115.124.30.44]:33885 "EHLO out30-44.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725987AbgIACu0 (ORCPT ); Mon, 31 Aug 2020 22:50:26 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R131e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01419;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=7;SR=0;TI=SMTPD_---0U7Txrtg_1598928621; Received: from aliy80.localdomain(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0U7Txrtg_1598928621) by smtp.aliyun-inc.com(127.0.0.1); Tue, 01 Sep 2020 10:50:22 +0800 From: Alex Shi To: Anshuman Khandual , David Hildenbrand , Matthew Wilcox Cc: Andrew Morton , Mel Gorman , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH v3 2/3] mm/pageblock: remove false sharing in pageblock_flags Date: Tue, 1 Sep 2020 10:50:11 +0800 Message-Id: <1598928612-68996-2-git-send-email-alex.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1598928612-68996-1-git-send-email-alex.shi@linux.alibaba.com> References: <1598928612-68996-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: Mel Gorman 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 81e96d4d9c42..60342e764090 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