Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1277962imu; Fri, 11 Jan 2019 19:27:08 -0800 (PST) X-Google-Smtp-Source: ALg8bN7+q38Sc9q7PjwYJmFLoUEVW5VIrWTfmmOOIlvaZActKKdtg215ngFQHoeydqEHCdBDT7l/ X-Received: by 2002:a62:2606:: with SMTP id m6mr16623163pfm.133.1547263628632; Fri, 11 Jan 2019 19:27:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547263628; cv=none; d=google.com; s=arc-20160816; b=eT2b6kKNY3mv38Tyuckj7tFZVO4tQ46K4UR1k1pu6mcNhjBNe8Jr3VlLgWaVz9rZF4 YBKQ9cecJbRjmU7uZYBdP8OSKM6E835n2xHinDTwivKTpGT4UgTOX8ERHYceSQfDLGdt roQ/dB6VT9EArcoRu8aE6GzcHetmWc7QEd1xe+FJYm2GkcsTO1UhGBpxYCqoTf9OpoKJ bO+wnDIbu0MsAMuOWNAooySRQV78Ooiot0g+hL3eZiiIq/YFZ9yranEhvWcHETVvhJ3w XI/ob3Sb1s8ZpMjBRwfJKXEz53FqPJQ5uR1DJ/QoOhwSzmC2uez1PaTZb3ATL4kUdamL NEkw== 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-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=ut59lX3R6EzTsi+aRCzFJec4HOpU0ANz24xreq1Fcyw=; b=C2UhkAR01xOOtlzmYdU6CfyOMkLCT/IoOfd2ODFZOOrgAEwJLgT11wD0z2Sph0xHxk KSp7wqO0zPi7L2fwLLMewy0QZbwsWnWGI1EpSOnd502kitu5qTRkUugxeUGQy3tsWTvo TJryxINcV4l+5d5riXern/sIwPy3nhOTJBVYZqtqHkNXOK06een6PZjqxI9l//iyBYVE NTf6COEC4DQOuwCU1OGR5Cl1c2dNBBhyerNORDgkkDweKmmuuNg/lgaGQGzxAHbNdxgf mm98pHiQdbgrTHDY175PF1r3ThnMhzwNjro/kIBlxfd06p9m6mtdsmFJ+dd5KNsQD6i5 bG3w== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q5si74377821pgg.204.2019.01.11.19.26.50; Fri, 11 Jan 2019 19:27:08 -0800 (PST) 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726450AbfALDZj (ORCPT + 99 others); Fri, 11 Jan 2019 22:25:39 -0500 Received: from mx1.redhat.com ([209.132.183.28]:45596 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726276AbfALDZj (ORCPT ); Fri, 11 Jan 2019 22:25:39 -0500 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 6E931C05AA51; Sat, 12 Jan 2019 03:25:38 +0000 (UTC) Received: from redhat.com (ovpn-120-63.rdu2.redhat.com [10.10.120.63]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 87CF818154; Sat, 12 Jan 2019 03:25:35 +0000 (UTC) Date: Fri, 11 Jan 2019 22:25:33 -0500 From: Jerome Glisse To: John Hubbard Cc: Jan Kara , Matthew Wilcox , Dave Chinner , Dan Williams , John Hubbard , Andrew Morton , Linux MM , tom@talpey.com, Al Viro , benve@cisco.com, Christoph Hellwig , Christopher Lameter , "Dalessandro, Dennis" , Doug Ledford , Jason Gunthorpe , Michal Hocko , mike.marciniszyn@intel.com, rcampbell@nvidia.com, Linux Kernel Mailing List , linux-fsdevel Subject: Re: [PATCH 1/2] mm: introduce put_user_page*(), placeholder versions Message-ID: <20190112032533.GD5059@redhat.com> References: <20190103015533.GA15619@redhat.com> <20190103092654.GA31370@quack2.suse.cz> <20190103144405.GC3395@redhat.com> <20190111165141.GB3190@redhat.com> <1b37061c-5598-1b02-2983-80003f1c71f2@nvidia.com> <20190112020228.GA5059@redhat.com> <294bdcfa-5bf9-9c09-9d43-875e8375e264@nvidia.com> <20190112024625.GB5059@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.32]); Sat, 12 Jan 2019 03:25:38 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jan 11, 2019 at 07:06:08PM -0800, John Hubbard wrote: > On 1/11/19 6:46 PM, Jerome Glisse wrote: > > On Fri, Jan 11, 2019 at 06:38:44PM -0800, John Hubbard wrote: > >> On 1/11/19 6:02 PM, Jerome Glisse wrote: > >>> On Fri, Jan 11, 2019 at 05:04:05PM -0800, John Hubbard wrote: > >>>> On 1/11/19 8:51 AM, Jerome Glisse wrote: > >>>>> On Thu, Jan 10, 2019 at 06:59:31PM -0800, John Hubbard wrote: > >>>>>> On 1/3/19 6:44 AM, Jerome Glisse wrote: > >>>>>>> On Thu, Jan 03, 2019 at 10:26:54AM +0100, Jan Kara wrote: > >>>>>>>> On Wed 02-01-19 20:55:33, Jerome Glisse wrote: > >>>>>>>>> On Wed, Dec 19, 2018 at 12:08:56PM +0100, Jan Kara wrote: > >>>>>>>>>> On Tue 18-12-18 21:07:24, Jerome Glisse wrote: > >>>>>>>>>>> On Tue, Dec 18, 2018 at 03:29:34PM -0800, John Hubbard wrote: > >>>>> [...] > >>>> > >>>> Hi Jerome, > >>>> > >>>> Looks good, in a conceptual sense. Let me do a brain dump of how I see it, > >>>> in case anyone spots a disastrous conceptual error (such as the lock_page > >>>> point), while I'm putting together the revised patchset. > >>>> > >>>> I've studied this carefully, and I agree that using mapcount in > >>>> this way is viable, *as long* as we use a lock (or a construct that looks just > >>>> like one: your "memory barrier, check, retry" is really just a lock) in > >>>> order to hold off gup() while page_mkclean() is in progress. In other words, > >>>> nothing that increments mapcount may proceed while page_mkclean() is running. > >>> > >>> No, increment to page->_mapcount are fine while page_mkclean() is running. > >>> The above solution do work no matter what happens thanks to the memory > >>> barrier. By clearing the pin flag first and reading the page->_mapcount > >>> after (and doing the reverse in GUP) we know that a racing GUP will either > >>> have its pin page clear but the incremented mapcount taken into account by > >>> page_mkclean() or page_mkclean() will miss the incremented mapcount but > >>> it will also no clear the pin flag set concurrently by any GUP. > >>> > >>> Here are all the possible time line: > >>> [T1]: > >>> GUP on CPU0 | page_mkclean() on CPU1 > >>> | > >>> [G2] atomic_inc(&page->mapcount) | > >>> [G3] smp_wmb(); | > >>> [G4] SetPagePin(page); | > >>> ... > >>> | [C1] pined = TestClearPagePin(page); > >> > >> It appears that you're using the "page pin is clear" to indicate that > >> page_mkclean() is running. The problem is, that approach leads to toggling > >> the PagePin flag, and so an observer (other than gup or page_mkclean) will > >> see intervals during which the PagePin flag is clear, when conceptually it > >> should be set. > >> > >> Jan and other FS people, is it definitely the case that we only have to take > >> action (defer, wait, revoke, etc) for gup-pinned pages, in page_mkclean()? > >> Because I recall from earlier experiments that there were several places, not > >> just page_mkclean(). > > > > Yes and it is fine to temporarily have the pin flag unstable. Anything > > that need stable page content will have to lock the page so will have > > to sync against any page_mkclean() and in the end the only thing were > > we want to check the pin flag is when doing write back ie after > > page_mkclean() while the page is still locked. If they are any other > > place that need to check the pin flag then they will need to lock the > > page. But i can not think of any other place right now. > > > > > > OK. Yes, since the clearing and resetting happens under page lock, that will > suffice to synchronize it. That's a good point. > > > [...] > > > >>>> The other idea that you and Dan (and maybe others) pointed out was a debug > >>>> option, which we'll certainly need in order to safely convert all the call > >>>> sites. (Mirror the mappings at a different kernel offset, so that put_page() > >>>> and put_user_page() can verify that the right call was made.) That will be > >>>> a separate patchset, as you recommended. > >>>> > >>>> I'll even go as far as recommending the page lock itself. I realize that this > >>>> adds overhead to gup(), but we *must* hold off page_mkclean(), and I believe > >>>> that this (below) has similar overhead to the notes above--but is *much* easier > >>>> to verify correct. (If the page lock is unacceptable due to being so widely used, > >>>> then I'd recommend using another page bit to do the same thing.) > >>> > >>> Please page lock is pointless and it will not work for GUP fast. The above > >>> scheme do work and is fine. I spend the day again thinking about all memory > >>> ordering and i do not see any issues. > >>> > >> > >> Why is it that page lock cannot be used for gup fast, btw? > > > > Well it can not happen within the preempt disable section. But after > > as a post pass before GUP_fast return and after reenabling preempt then > > it is fine like it would be for regular GUP. But locking page for GUP > > is also likely to slow down some workload (with direct-IO). > > > > Right, and so to crux of the matter: taking an uncontended page lock involves > pretty much the same set of operations that your approach does. (If gup ends up > contended with the page lock for other reasons than these paths, that seems > surprising.) I'd expect very similar performance. > > But the page lock approach leads to really dramatically simpler code (and code > reviews, let's not forget). Any objection to my going that direction, and keeping > this idea as a Plan B? I think the next step will be, once again, to gather some > performance metrics, so maybe that will help us decide. They are already work load that suffer from the page lock so adding more code that need it will only worsen those situations. I guess i will do a patchset with my solution as it is definitly lighter weight that having to take the page lock. Cheers, J?r?me