Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp6381351ybh; Wed, 7 Aug 2019 23:04:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqwvY8qwqZFcRlbSYlpNBk3LjcG8/FmwJtBFm40sJQjui562dETXR1zu9CM5ua7xDo2Dg1xO X-Received: by 2002:a17:90a:3ac2:: with SMTP id b60mr2316058pjc.74.1565244251125; Wed, 07 Aug 2019 23:04:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565244251; cv=none; d=google.com; s=arc-20160816; b=Vl5LUznL24be7yYAAAsGLEnq3KOT1t7cbCbjDPJaULUYnVyfl/qMdFtFjQxhyIQGqj vJLhL5Q6TzsxM1XdK4AIT36ZtrB5sYT1wAxgFrYaKvjNYAf/m+ZkFrcsxZKtUbur+LrL uTpvUlaQxYnheBn/6SfBjyLq/JhHR0t/np3FEyRligRn1QWbc8SrJTZ4dqDCA8NXlEfd XtHnAQRfy9r/JZGFqNtwKbPslpyRvbyRYoPShTyufv7047XTKUt2orc8+YcRVSU7LeLg G1OFVSh2NOmouE+/H8FXT/LzyDW6V1yGzlI1XetrocYFM35h/+jP8dfrTlio/BfUGHwp /b3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=mMMbJZ3j+NPo4KunwM+dB0OCXYM/A9TaVqSTcJGrnKI=; b=S/qcEqXrhQSDmEo2THFgL4Neg2DzITbsIQREv6Vrrn2mXPmLkG8rOsCAho1j/zoodX wUTnecJIrl3UUtX3kclNdy8ThZG5lrJEXE/9kqR+PD4W6E4VgIZDpezPwvIo+CbPZ+hy gjws6/W+3KmWdjKflaMhNUz13pvmTIRBR4eLvZSwN/8ZEqMoqFHXBokDgxsyLVYM439C 0mRlySongBar+KKj0KmZHjX648KRDVpgI91ixpjZYVgCf+qVuILx6RUmUCyx4R0jlw5S TmbEZ7/9VTg01lN/LE8TaaKgWqXwQbIGLq89VYa5pdWcN/VJoQ2ns+1uHYkePEo/qCaq 9FcQ== 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i23si51114642pfa.196.2019.08.07.23.03.55; Wed, 07 Aug 2019 23:04:11 -0700 (PDT) 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730990AbfHHGCN (ORCPT + 99 others); Thu, 8 Aug 2019 02:02:13 -0400 Received: from mx2.suse.de ([195.135.220.15]:58724 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726106AbfHHGCN (ORCPT ); Thu, 8 Aug 2019 02:02:13 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id B2659B68F; Thu, 8 Aug 2019 06:02:11 +0000 (UTC) Date: Thu, 8 Aug 2019 08:02:10 +0200 From: Michal Hocko To: Wei Yang Cc: Vlastimil Babka , akpm@linux-foundation.org, kirill.shutemov@linux.intel.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm/mmap.c: refine data locality of find_vma_prev Message-ID: <20190808060210.GE11812@dhcp22.suse.cz> References: <20190806081123.22334-1-richardw.yang@linux.intel.com> <3e57ba64-732b-d5be-1ad6-eecc731ef405@suse.cz> <20190807003109.GB24750@richard> <20190807075101.GN11812@dhcp22.suse.cz> <20190808032638.GA28138@richard> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190808032638.GA28138@richard> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 08-08-19 11:26:38, Wei Yang wrote: > On Wed, Aug 07, 2019 at 09:51:01AM +0200, Michal Hocko wrote: > >On Wed 07-08-19 08:31:09, Wei Yang wrote: > >> On Tue, Aug 06, 2019 at 11:29:52AM +0200, Vlastimil Babka wrote: > >> >On 8/6/19 10:11 AM, Wei Yang wrote: > >> >> When addr is out of the range of the whole rb_tree, pprev will points to > >> >> the biggest node. find_vma_prev gets is by going through the right most > >> > > >> >s/biggest/last/ ? or right-most? > >> > > >> >> node of the tree. > >> >> > >> >> Since only the last node is the one it is looking for, it is not > >> >> necessary to assign pprev to those middle stage nodes. By assigning > >> >> pprev to the last node directly, it tries to improve the function > >> >> locality a little. > >> > > >> >In the end, it will always write to the cacheline of pprev. The caller has most > >> >likely have it on stack, so it's already hot, and there's no other CPU stealing > >> >it. So I don't understand where the improved locality comes from. The compiler > >> >can also optimize the patched code so the assembly is identical to the previous > >> >code, or vice versa. Did you check for differences? > >> > >> Vlastimil > >> > >> Thanks for your comment. > >> > >> I believe you get a point. I may not use the word locality. This patch tries > >> to reduce some unnecessary assignment of pprev. > >> > >> Original code would assign the value on each node during iteration, this is > >> what I want to reduce. > > > >Is there any measurable difference (on micro benchmarks or regular > >workloads)? > > I wrote a test case to compare these two methods, but not find visible > difference in run time. What is the point in changing this code if it doesn't lead to any measurable improvement? -- Michal Hocko SUSE Labs