Received: by 2002:a05:7412:37c9:b0:e2:908c:2ebd with SMTP id jz9csp438346rdb; Mon, 18 Sep 2023 22:55:40 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFYzkpsfLHOkaG1YU3qnQxWj6SdcyVPM+C85S6liXWB8RNB6FmlAvrMGasLSWJJJkaY6k6W X-Received: by 2002:a05:6358:5917:b0:142:ecad:c74 with SMTP id g23-20020a056358591700b00142ecad0c74mr12280892rwf.7.1695102939810; Mon, 18 Sep 2023 22:55:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695102939; cv=none; d=google.com; s=arc-20160816; b=oURK9TtV5uWNcOv65TWgd11mccJllXOEOMU1IH96ixX0NT4W/qgWyeGwrmUU0MeXyv llMyT6jdh/blLknBrkPNLshX+wbIuyNBP6qPl+u7S1Qh9wZ++ZH/ZOAHv7vLq35Gu1UR 1G9+kf4fHmonUjBbLdkoX2IxnW3JEmlXEFN5RFcBwPmIPJrp8MjOLm8lRlwnoA00vfGv L5PH6CL0y1bhqt3pg/8SVccX4+Z8xifkXuskdRlitKkMmPTVtNPWMs/rFYmVZkpBgTMs gSFljlUyE7Y9ftIGEVNC3aGGh/iZFPCHWI96SwJJx0ftSaCjaZkI9ax0dSGDa3p779Av Zntg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:message-id:in-reply-to :subject:cc:to:from:date:dkim-signature; bh=AvmZeLJa5EyjvpWd7at0QcGbhWatmHcWmtqRx8CiCf4=; fh=Fbj5SfzIiGXOBQ/i9iOafHg10IneRVC/d1OFjxTKVpY=; b=ZwqQ/yocNyv9uE6LJwAMbgJzxH4X5b0hpgf864/en8YUHrLey02pEoHDYp0Ovg5GZs 9S4o3jjr0KNSJYotOxnnBAWzkcS+htMzgQ8cLsRTkj4S0djQLFdwtOS93cgx2MeZfjVj 579m6Y+N7YBspnnqnerHz+6TfRtybFGrwcCmC//HYAbLIE4JapTtUUVVP+XqwrEFRtvW g7njJdHWTqWa3TKb87OdVLpGC+3L+JSw/2b0qw1O0nzK0VDGwErkyMMctHTZxYf0y1Hx JHa+zUSADHCsnS5MYq81aIlshBmQWFMIfe1WXVyWyb6+Z4NbyRXrcIdPAm3vu7EyBtav oTeg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=pGExb2pP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from howler.vger.email (howler.vger.email. [2620:137:e000::3:4]) by mx.google.com with ESMTPS id h184-20020a636cc1000000b00565dd108fd4si8773725pgc.115.2023.09.18.22.55.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Sep 2023 22:55:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) client-ip=2620:137:e000::3:4; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=pGExb2pP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 96EE38049D6C; Mon, 18 Sep 2023 16:31:50 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230099AbjIRXbR (ORCPT + 99 others); Mon, 18 Sep 2023 19:31:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48614 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229436AbjIRXbP (ORCPT ); Mon, 18 Sep 2023 19:31:15 -0400 Received: from mail-yw1-x1131.google.com (mail-yw1-x1131.google.com [IPv6:2607:f8b0:4864:20::1131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D0C6590 for ; Mon, 18 Sep 2023 16:31:05 -0700 (PDT) Received: by mail-yw1-x1131.google.com with SMTP id 00721157ae682-59c04237bf2so43047767b3.0 for ; Mon, 18 Sep 2023 16:31:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1695079865; x=1695684665; darn=vger.kernel.org; h=mime-version:references:message-id:in-reply-to:subject:cc:to:from :date:from:to:cc:subject:date:message-id:reply-to; bh=AvmZeLJa5EyjvpWd7at0QcGbhWatmHcWmtqRx8CiCf4=; b=pGExb2pPuLuG/EbV4lKr/lwnQIudowJDrj3y1Pd/+B2GSU0hVGnW3RJ7TW5JBhYgOG aD1VVHLT9gUR6YdQiXZQ5cPgCwn7NdkR0wy1BcdUa7HKSg67Xsq0ZeoStyF3UIRlWbVt h60Yii3bW3KfIzpEwajXnrLANTGz6GMw5fVUAaXwl4ioGBc10CygbsGR13gNPaNTM0bu NZKNNiIYiBinOPSG+bSzBqs4/8jrSfA/JNWf4zOtYNNcB/7qNwFVWUD1l6tdXWNi3eUh Gm4mF+szpQXaGaQftRWu31znIu890mA+SH+SHpXej30I52zj4mZqny3AgzU7mbVOWDgW jLkg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695079865; x=1695684665; h=mime-version:references:message-id:in-reply-to:subject:cc:to:from :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=AvmZeLJa5EyjvpWd7at0QcGbhWatmHcWmtqRx8CiCf4=; b=LSTBNHLumZb8gR4Zcn5kFGXemM5xf5LKE90YKjFPMkvHFuMtPyH5OttiRWeu/nwB87 T2AxcYFmjJgfl7vSwJynTe8Xs3D/vHm05XTTDVgzGaCsU/OeDTgAYgK220qHzj9MDGf1 mWZGabOpfaYczs825H1dv44JRlL1jDypsLaIiXCXs1L8cUrYB5LyO0fZX7SsX2S+SZqO X8uGX0wPuhnX9FwxOY23nqg/Mm8H/BT4jrZC6TS2snsoMUKstpOWqHHa0SXvkShd4rst ntFEKCJ2p55q/H2mF+zaKlnpK9cvthCRFSKIXp3SDcwEF9VTWIsQLA09nGEbgTfb/P3D MoUg== X-Gm-Message-State: AOJu0Yza8JIfs5Bxxp3PLkteSEPdkQBl+4V1YKg+nKFo9VtG7dd5TUdE mClskKvviP1Bet2M/Pw9YLwOTw== X-Received: by 2002:a0d:efc6:0:b0:595:be7:a38 with SMTP id y189-20020a0defc6000000b005950be70a38mr9618335ywe.49.1695079864905; Mon, 18 Sep 2023 16:31:04 -0700 (PDT) Received: from ripple.attlocal.net (172-10-233-147.lightspeed.sntcca.sbcglobal.net. [172.10.233.147]) by smtp.gmail.com with ESMTPSA id x8-20020a817c08000000b00589b653b7adsm2888815ywc.136.2023.09.18.16.31.02 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Sep 2023 16:31:03 -0700 (PDT) Date: Mon, 18 Sep 2023 16:30:54 -0700 (PDT) From: Hugh Dickins X-X-Sender: hugh@ripple.attlocal.net To: Suren Baghdasaryan cc: akpm@linux-foundation.org, willy@infradead.org, hughd@google.com, shy828301@gmail.com, mhocko@suse.com, vbabka@suse.cz, syzkaller-bugs@googlegroups.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org, syzbot+b591856e0f0139f83023@syzkaller.appspotmail.com Subject: Re: [PATCH 1/1] mm: lock VMAs skipped by a failed queue_pages_range() In-Reply-To: <20230918211608.3580629-1-surenb@google.com> Message-ID: <512d487a-758c-6d9c-787c-4169117d20cf@google.com> References: <20230918211608.3580629-1-surenb@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII X-Spam-Status: No, score=-17.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS, USER_IN_DEF_DKIM_WL,USER_IN_DEF_SPF_WL 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Mon, 18 Sep 2023 16:31:50 -0700 (PDT) On Mon, 18 Sep 2023, Suren Baghdasaryan wrote: > When queue_pages_range() encounters an unmovable page, it terminates > its page walk. This walk, among other things, locks the VMAs in the range. > This termination might result in some VMAs being left unlock after > queue_pages_range() completes. Since do_mbind() continues to operate on > these VMAs despite the failure from queue_pages_range(), it will encounter > an unlocked VMA. > This mbind() behavior has been modified several times before and might > need some changes to either finish the page walk even in the presence > of unmovable pages or to error out immediately after the failure to > queue_pages_range(). However that requires more discussions, so to > fix the immediate issue, explicitly lock the VMAs in the range if > queue_pages_range() failed. The added condition does not save much > but is added for documentation purposes to understand when this extra > locking is needed. > > Fixes: 49b0638502da ("mm: enable page walking API to lock vmas during the walk") > Reported-by: syzbot+b591856e0f0139f83023@syzkaller.appspotmail.com > Closes: https://lore.kernel.org/all/000000000000f392a60604a65085@google.com/ > Signed-off-by: Suren Baghdasaryan Acked-by: Hugh Dickins > --- > mm/mempolicy.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/mm/mempolicy.c b/mm/mempolicy.c > index 42b5567e3773..cbc584e9b6ca 100644 > --- a/mm/mempolicy.c > +++ b/mm/mempolicy.c > @@ -1342,6 +1342,9 @@ static long do_mbind(unsigned long start, unsigned long len, > vma_iter_init(&vmi, mm, start); > prev = vma_prev(&vmi); > for_each_vma_range(vmi, vma, end) { > + /* If queue_pages_range failed then not all VMAs might be locked */ > + if (ret) > + vma_start_write(vma); > err = mbind_range(&vmi, vma, &prev, start, end, new); > if (err) > break; > -- > 2.42.0.459.ge4e396fd5e-goog