Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp4879344rwb; Tue, 6 Sep 2022 14:24:02 -0700 (PDT) X-Google-Smtp-Source: AA6agR5fofMa0TV4yST3jfaRrl+uik5eYr1YYJU4tG6xl9YbqgMs4K6FMv9uHE+19fhyybC8gzwx X-Received: by 2002:aa7:c74c:0:b0:44e:a7b9:d5c9 with SMTP id c12-20020aa7c74c000000b0044ea7b9d5c9mr459637eds.19.1662499442200; Tue, 06 Sep 2022 14:24:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662499442; cv=none; d=google.com; s=arc-20160816; b=V9cNvFD9QoCiobJN/X1kBR3gE7ENM3CJOe33a9GVFHrFZB2B4VhY3SZcfnhkijlXle DSWRa1qc78c/zpPvCiQR4IGtT4RcdposoChYWC135lHt5YXcwQsCVncMe2xjZ2Y92y+E AnmiD/R5Nft/V5DB4meo5vvZz1V0qV3RH1WvHVbD4dy9gOZyVpZhRecOMbVstH1yTo8g MTL0UuqK0RngHhxHmEWV0YzHyU6JSSWQWkrFIxQaQbD3cYQXdFejaEtNwQwD2vj4qrgH JjXtxPNeo8rCVzMAcpecYHOGgre4zyZIfdTsBRB/gtGgtlLa+KmkdOMU/KQsSwYagCqJ gzgw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=6rfQm3A/tm7Sj95hHoCuXpvQKcgb4WAgDh0q01aC4qg=; b=QEgYXprEWh4hSwYY5pqnlEHHknEb7N3GiuD977wBc4KIb+cQ33tqsom5sKvS+o43tN 2F+aOFilz3BoWD7db5oAqhP1wEGQIGpPmWpyA4dDo/sxjNNnMS5Rs1emRFp+gRr/PKnG BuQEN6GT5LuYo0LIetmHb24lIVtSOK7asnxS/qkxCfHidp72JdIPXjLPqyphDfgE2oLp L+LjfQMxoF3qgf7Kp52g4/b7175YYVnuDzgm6rkPIOv7fqZynr1WeTJ17h1bq2RWEi0m o22Tt3ddPy4KI+SA8PY+2cRKOL+JVyPxEfYti1tJlASkKIB8eG3OdO4h4k8YoJLqgJjz Rhqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=U1rT34Xt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id eb13-20020a0564020d0d00b004480d6fefe4si1951924edb.239.2022.09.06.14.23.36; Tue, 06 Sep 2022 14:24:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=U1rT34Xt; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229863AbiIFUXL (ORCPT + 99 others); Tue, 6 Sep 2022 16:23:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41722 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231213AbiIFUWv (ORCPT ); Tue, 6 Sep 2022 16:22:51 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2C8978A1FD for ; Tue, 6 Sep 2022 13:22:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1662495755; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=6rfQm3A/tm7Sj95hHoCuXpvQKcgb4WAgDh0q01aC4qg=; b=U1rT34XtVUrh0NF8Jjv898YADzbCIC+Hb08Uh1C+CvdQsRecl1AkBLR91CdJjMGrX4LC4+ pL4bpYs2gA8IyKA/5RXAku+sSkbZEj6JvOw1+cEcRS/uLYBgnYyjJERma5aQW/q0v++5od pG2Qb9h7No06oBULPM55mB50NjPoTvc= Received: from mail-qv1-f69.google.com (mail-qv1-f69.google.com [209.85.219.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_128_GCM_SHA256) id us-mta-172-hDz4yw1dPimUvrIP4nodVg-1; Tue, 06 Sep 2022 16:22:34 -0400 X-MC-Unique: hDz4yw1dPimUvrIP4nodVg-1 Received: by mail-qv1-f69.google.com with SMTP id li18-20020a0562145e1200b004a7963a772cso4181231qvb.23 for ; Tue, 06 Sep 2022 13:22:34 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date; bh=6rfQm3A/tm7Sj95hHoCuXpvQKcgb4WAgDh0q01aC4qg=; b=DjA1w7uDo5t3oTSmYcWnRsDYO3kYWMpvMc1dC9GE1k2vGDml4ifSl9NtJtuwjelAfi udWlK/avBwXQ+5D2/Awx57mh9VB7IofhYOqJVlylEI0UKDBT9WElF63MVryW4b26+cCx GKzbkQ05YdziVjv1VK9reKzrAj2EhpP+LQtXWyDc1Je6tOwvFcpGL0WQQhfzkOjXnPWN +0kvf/4rdM8+y32wqUHrUvHZ3MzKUGQrGl1Di03j/6zcfumf2qdqqEfIZvZlEw7xf7xf rf3b9/wEWwgtf6s9KGb5lsAruaOseQsRgqEwrXb8VBe5ScOeFSR7w+RG4Wx1KepFkxpx qMIQ== X-Gm-Message-State: ACgBeo2xP8AquARLsjjxfpmdXW3GounDXp/O032uu4EAxkjE857v+U3y COhlfnpQPvRfjlkBN9EgEVTqmMvd0I5PWbkreKP6vBKWKDn1V79ENFqnrqqvzhS3WymB7bu8l7n CM/iXIypagowq4ywMsDkNNXiq X-Received: by 2002:ad4:5ccc:0:b0:49a:87e:b21c with SMTP id iu12-20020ad45ccc000000b0049a087eb21cmr58585qvb.28.1662495753498; Tue, 06 Sep 2022 13:22:33 -0700 (PDT) X-Received: by 2002:ad4:5ccc:0:b0:49a:87e:b21c with SMTP id iu12-20020ad45ccc000000b0049a087eb21cmr58555qvb.28.1662495753193; Tue, 06 Sep 2022 13:22:33 -0700 (PDT) Received: from xz-m1.local (bras-base-aurron9127w-grc-35-70-27-3-10.dsl.bell.ca. [70.27.3.10]) by smtp.gmail.com with ESMTPSA id u14-20020a05622a14ce00b00341a807ed21sm2137489qtx.72.2022.09.06.13.22.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 06 Sep 2022 13:22:32 -0700 (PDT) Date: Tue, 6 Sep 2022 16:22:30 -0400 From: Peter Xu To: Suren Baghdasaryan Cc: Andrew Morton , Michel Lespinasse , Jerome Glisse , Michal Hocko , Vlastimil Babka , Johannes Weiner , Mel Gorman , Davidlohr Bueso , Matthew Wilcox , "Liam R. Howlett" , Peter Zijlstra , Laurent Dufour , Laurent Dufour , "Paul E . McKenney" , Andy Lutomirski , Song Liu , David Hildenbrand , dhowells@redhat.com, Hugh Dickins , Sebastian Andrzej Siewior , Kent Overstreet , David Rientjes , Axel Rasmussen , Joel Fernandes , Minchan Kim , kernel-team , linux-mm , linux-arm-kernel@lists.infradead.org, linuxppc-dev@lists.ozlabs.org, x86@kernel.org, LKML Subject: Re: [RFC PATCH RESEND 19/28] mm: disallow do_swap_page to handle page faults under VMA lock Message-ID: References: <20220901173516.702122-1-surenb@google.com> <20220901173516.702122-20-surenb@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Sep 06, 2022 at 01:08:10PM -0700, Suren Baghdasaryan wrote: > On Tue, Sep 6, 2022 at 12:39 PM Peter Xu wrote: > > > > On Thu, Sep 01, 2022 at 10:35:07AM -0700, Suren Baghdasaryan wrote: > > > Due to the possibility of do_swap_page dropping mmap_lock, abort fault > > > handling under VMA lock and retry holding mmap_lock. This can be handled > > > more gracefully in the future. > > > > > > Signed-off-by: Suren Baghdasaryan > > > --- > > > mm/memory.c | 5 +++++ > > > 1 file changed, 5 insertions(+) > > > > > > diff --git a/mm/memory.c b/mm/memory.c > > > index 9ac9944e8c62..29d2f49f922a 100644 > > > --- a/mm/memory.c > > > +++ b/mm/memory.c > > > @@ -3738,6 +3738,11 @@ vm_fault_t do_swap_page(struct vm_fault *vmf) > > > vm_fault_t ret = 0; > > > void *shadow = NULL; > > > > > > + if (vmf->flags & FAULT_FLAG_VMA_LOCK) { > > > + ret = VM_FAULT_RETRY; > > > + goto out; > > > + } > > > + > > > > May want to fail early similarly for handle_userfault() too for similar > > reason. Thanks, > > I wasn't aware of a similar issue there. Will have a closer look. Thanks! Sure. Just in case this would be anything helpful - handle_userfault() will both assert at the entry (mmap_assert_locked) and will in most cases release read lock along the way when waiting for page fault resolutions. And userfaultfd should work on anonymous memory for either missing mode or write protect mode. Thanks, -- Peter Xu