Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1676858pxa; Sun, 16 Aug 2020 07:12:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzsNTLTraEzNFleiuqzi4FcJ+tlLtPDcY+l24+YzqDJV88l0LtcCrizOYqmAYFn2Ix6yjHL X-Received: by 2002:a17:906:7d6:: with SMTP id m22mr10578982ejc.229.1597587140138; Sun, 16 Aug 2020 07:12:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597587140; cv=none; d=google.com; s=arc-20160816; b=aiNg7N6v8cnP+Pk80ybOlX/9mQIBueoaJFZ3v/h3ekMeIogqp4TbfeixxY3jY3iSt1 RN4HECGqmd0TkxTxmiYCVm3ORs1Ddz+Ga1+DpKl8Z2XkXwQCfDWbKoGVuDzRYR9VDxLq AzImSnckKg9au4BvrAEm5nGYJR7mgdBcSIZf8+wnEviS8P9Onx0QK23jtQghOBzZPzAN N4fGLOzN7zanBiL1BjFclORdY9L5qE1VW8P/pxvSQyzCFYPloq/da5cSzs9+5/L+5mvi 7lCHzZRbV+yvo+Rjb641ewWMBDlq0LeTL+MTSTfSkcr1n6sRohMfMEGChZSlbE4bm8+4 tDYA== 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=z9jl1dBSiKc+YK9B+kEwYcRzojLdtPPSWITB4K1BwUs=; b=fZTPt0MU77aB6JiCPXs/Uw4EqoynaC7Nsgwjj3twW9m9sArqrd6xEOprRx1eVgdTd+ PUrWX7R6f3m53HejQBYUMYqhnDxq5YlCaJSHE4sV4m4fkXBrnZwwl/YY+cFXnwRVq6/g w6kL+etLKGd0ZAzaRpTxdTuJP9QWpCUyA3ZQtyaBi3b7HLSKtshp2mOVL0VqhyXLCXyf tbGsBtnsMFKmEefMGZPbXQ5TWfKrPTeoo11FueJnpJhmulaHdbfewrqj9LEvCVbfDR1X 8Agl+5l19o/1JuJCyKR+7Ppv59HEDxV+1aCBnH7caMHUVaMw+LQc+yKJEJlkJrzHQZDX afoA== 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 v7si12009683edd.551.2020.08.16.07.11.56; Sun, 16 Aug 2020 07:12:20 -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 S1729008AbgHPOL2 (ORCPT + 99 others); Sun, 16 Aug 2020 10:11:28 -0400 Received: from out30-130.freemail.mail.aliyun.com ([115.124.30.130]:49271 "EHLO out30-130.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726304AbgHPOL1 (ORCPT ); Sun, 16 Aug 2020 10:11:27 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R141e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01355;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0U5ux5MB_1597587062; Received: from IT-FVFX43SYHV2H.lan(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0U5ux5MB_1597587062) by smtp.aliyun-inc.com(127.0.0.1); Sun, 16 Aug 2020 22:11:03 +0800 Subject: Re: [PATCH 2/2] mm/pageblock: remove false sharing in pageblock_flags To: Matthew Wilcox Cc: Andrew Morton , Hugh Dickins , Alexander Duyck , linux-kernel@vger.kernel.org, linux-mm@kvack.org References: <1597549677-7480-1-git-send-email-alex.shi@linux.alibaba.com> <1597549677-7480-2-git-send-email-alex.shi@linux.alibaba.com> <20200816041720.GG17456@casper.infradead.org> From: Alex Shi Message-ID: <957eee62-1f46-49b6-4d5a-9671dc07c562@linux.alibaba.com> Date: Sun, 16 Aug 2020 22:10:06 +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: <20200816041720.GG17456@casper.infradead.org> Content-Type: text/plain; charset=gbk Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ?? 2020/8/16 ????12:17, Matthew Wilcox ะด??: > On Sun, Aug 16, 2020 at 11:47:57AM +0800, Alex Shi wrote: >> 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. > > I don't believe this patch has that effect, mostly because it still does > cmpxchg() on words instead of bytes. Hi Matthew, Thank a lot for comments! Sorry, I must overlook sth, would you like point out why the cmpxchg is still on words after patch 1 applied? > > But which functions would benefit? It seems to me this cmpxchg() is > only called from the set_pageblock_migratetype() morass of functions, > none of which are called in hot paths as far as I can make out. > > So are you just reasoning by analogy with the previous patch where you > have measured a performance improvement, or did you send the wrong patch, > or did I overlook a hot path that calls one of the pageblock migration > functions? > Uh, I am reading compaction.c and found the following commit introduced test_and_set_skip under a lock. It looks like the pagelock_flags setting has false sharing in cmpxchg. but I have no valid data on this yet. Thanks Alex e380bebe4771548 mm, compaction: keep migration source private to a single compaction instance if (!locked) { locked = compact_trylock_irqsave(zone_lru_lock(zone), &flags, cc); - if (!locked) + + /* Allow future scanning if the lock is contended */ + if (!locked) { + clear_pageblock_skip(page); break; + } + + /* Try get exclusive access under lock */ + if (!skip_updated) { + skip_updated = true; + if (test_and_set_skip(cc, page, low_pfn)) + goto isolate_abort; + }