Received: by 2002:a05:6358:53a8:b0:117:f937:c515 with SMTP id z40csp4891940rwe; Mon, 17 Apr 2023 21:48:39 -0700 (PDT) X-Google-Smtp-Source: AKy350a7XDbh6k+855jZFRdAjbF2iSPMnQ5h/3tDCzAdox5SGzEhIgLuEPoJ6zso2emzYURp0cTI X-Received: by 2002:a17:90a:a618:b0:23b:4439:4179 with SMTP id c24-20020a17090aa61800b0023b44394179mr806308pjq.28.1681793318855; Mon, 17 Apr 2023 21:48:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681793318; cv=none; d=google.com; s=arc-20160816; b=SM1EjAd5XMqypE1QnN8FL3Sm+WXroxsoFRv83R5JPozXqY/bgRSViBrLfpt8RgPNew S5Tj+NKP/mJQXwf5A7BQTwsQUdI803SyKcJvSjeovQrLWsj5N50JqlIt6eFd3z4uoCg+ lZY67XUa1tfJsEea3f+O5K6jM+MQu1sYeiXfYo7H6xqG1ZMKbnwOgNah+HjIuHTQ7Ycw uoQZJ6d7KP3uPWJB1GtL8BRchpmaGxA3KeKRwuEXD/0KH/DLcKFQxtwqCteGJTOL9BvL 7r6ZDQZoWfA4HafTQSDEWvd+nHYIw0x1JrlEG+NLS4PO3VIPNNwFweephOT/VZqupTxn YEgw== 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=MmNCqthD+HS7Zi170wxRoVdfC1QjJufvMpFTlluYfgk=; b=yhrIiV/xdTKaqVDvF2YiOO4ts+XwBlZ3uCrg70RSiXleYnPPs2PrcXTT2YRHaBmCw6 iPRomlOAEiec19Jjmn9F0SpXIZ6Y+clAecK1oTnzyQUuKfqxpVqqpJBkATMul0EhLTFd GvRwhvmkT8anofdl3ZuS3EXG8hsXALxUlp0ciubmllQ+PkCd0njMOs4BZ+lgPMf+nrgr pHLpGRUtkcfyONNCZtlLgYXGVxFp0LHmPQiLoIDOawl0ns1EtDERtM7plSig163J0Fn/ U9sBBieSnbQoJilSCQ7K8Me+M/ZIRHmQR3nA5nF7SfCwej1NWmEGUoF/s/uE7tZuP+z7 Lbuw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=5HIAuV2j; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id a24-20020a17090ad81800b00233e2e1ff6csi12891965pjv.119.2023.04.17.21.48.27; Mon, 17 Apr 2023 21:48:38 -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=@google.com header.s=20221208 header.b=5HIAuV2j; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229714AbjDRElr (ORCPT + 99 others); Tue, 18 Apr 2023 00:41:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43070 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229517AbjDRElp (ORCPT ); Tue, 18 Apr 2023 00:41:45 -0400 Received: from mail-yb1-xb2c.google.com (mail-yb1-xb2c.google.com [IPv6:2607:f8b0:4864:20::b2c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A97661FC7 for ; Mon, 17 Apr 2023 21:41:44 -0700 (PDT) Received: by mail-yb1-xb2c.google.com with SMTP id t16so15236263ybi.13 for ; Mon, 17 Apr 2023 21:41:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1681792904; x=1684384904; h=mime-version:references:message-id:in-reply-to:subject:cc:to:from :date:from:to:cc:subject:date:message-id:reply-to; bh=MmNCqthD+HS7Zi170wxRoVdfC1QjJufvMpFTlluYfgk=; b=5HIAuV2jRVPb0IzmRrjaTOEMld/LD1MF6ynGtV4zhwLZcRconkU/MaIg83VumtbJyk 3vqG1IjqeZVwIY0K0fYqOUdfgnohulgubhh+Vd/HhVJKuC048gWuKMC2TM6G7Mr8QU1p y2AhDuMTlHUdw4tKtyhsDxLlaSSs2YUhbzu4kU8BqglUdL2wMIv5uqDgDW6zGokMf5XQ yKOvJ2UtxcwtMBPmNvslcODjKwEUm88cmtOO5IyAX66LLF1IP3vRQ6ALitYGFOrovhgp oUGPyt2zqjuAPLU2t1vmkJwXdpbJTBvuhxe0PnkdVTAqinwrOvkYMsux/hUVEcZBrNuC 092A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1681792904; x=1684384904; 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=MmNCqthD+HS7Zi170wxRoVdfC1QjJufvMpFTlluYfgk=; b=W53meww8ZwK4j9ThIgNwuQtp2i+FSSe5FaFV2Am9r7v3rWu9+n+VFhqT2g2akfPrgt 2QrOUV5wLQc8fGA9Wd/7YqLuulZnhIfTLCrkh4yxS74zZZab+gwfbibtN+4dQJxLaC+H 7Hy+fiiQY1vHTTboRwPtfZ70k3iXsGu7oyOTGh08XMHF1IjYr9+Uco3aImj2aNfNAhyu hjdLJOYLZ73Ts/swsaFetcqKPWGnuOKV6VgmlZGbMB8eze71mrUmKfFisDs3Rmx0VJZU aTT87mddUn0NQxhlCZDLoUq7nvq5BSnz5HgGWG1c+JZFmXhS/PQPhKhGfkc76GpL7Cen lAGA== X-Gm-Message-State: AAQBX9d90fACn3a9mBx1/ZHs7DErHh4WbWd9MFl3Sro6DibcsCUFeKob Ic2eA6zHm5lui6N3V6P+8sG9LQ== X-Received: by 2002:a05:6902:114d:b0:b8f:384b:4f83 with SMTP id p13-20020a056902114d00b00b8f384b4f83mr19369905ybu.33.1681792903775; Mon, 17 Apr 2023 21:41:43 -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 w10-20020a05690204ea00b00b7767ca747csm3435131ybs.25.2023.04.17.21.41.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 17 Apr 2023 21:41:43 -0700 (PDT) Date: Mon, 17 Apr 2023 21:41:41 -0700 (PDT) From: Hugh Dickins X-X-Sender: hugh@ripple.attlocal.net To: Luis Chamberlain cc: hughd@google.com, akpm@linux-foundation.org, willy@infradead.org, brauner@kernel.org, linux-mm@kvack.org, p.raghav@samsung.com, da.gomez@samsung.com, a.manzanares@samsung.com, dave@stgolabs.net, yosryahmed@google.com, keescook@chromium.org, patches@lists.linux.dev, linux-kernel@vger.kernel.org, David Hildenbrand Subject: Re: [PATCH v2 4/6] shmem: skip page split if we're not reclaiming In-Reply-To: <20230309230545.2930737-5-mcgrof@kernel.org> Message-ID: References: <20230309230545.2930737-1-mcgrof@kernel.org> <20230309230545.2930737-5-mcgrof@kernel.org> 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_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,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 On Thu, 9 Mar 2023, Luis Chamberlain wrote: > In theory when info->flags & VM_LOCKED we should not be getting > shem_writepage() called so we should be verifying this with a > WARN_ON_ONCE(). Since we should not be swapping then best to ensure > we also don't do the folio split earlier too. So just move the check > early to avoid folio splits in case its a dubious call. > > We also have a similar early bail when !total_swap_pages so just move > that earlier to avoid the possible folio split in the same situation. > > Acked-by: David Hildenbrand > Reviewed-by: Christian Brauner > Signed-off-by: Luis Chamberlain > --- > mm/shmem.c | 10 ++++++---- > 1 file changed, 6 insertions(+), 4 deletions(-) > > diff --git a/mm/shmem.c b/mm/shmem.c > index 68e9970baf1e..dfd995da77b4 100644 > --- a/mm/shmem.c > +++ b/mm/shmem.c > @@ -1350,6 +1350,12 @@ static int shmem_writepage(struct page *page, struct writeback_control *wbc) > if (WARN_ON_ONCE(!wbc->for_reclaim)) > goto redirty; > > + if (WARN_ON_ONCE(info->flags & VM_LOCKED)) > + goto redirty; Well, okay, I don't mind that. But shall we take bets on how soon syzbot (hope it's not watching) will try flipping SHM_LOCK on while swapping out pages from a SHM segment, and hit that warning? Perhaps I'm wrong, but I don't think any serialization prevents that. Hugh > + > + if (!total_swap_pages) > + goto redirty; > + > /* > * If /sys/kernel/mm/transparent_hugepage/shmem_enabled is "always" or > * "force", drivers/gpu/drm/i915/gem/i915_gem_shmem.c gets huge pages, > @@ -1365,10 +1371,6 @@ static int shmem_writepage(struct page *page, struct writeback_control *wbc) > } > > index = folio->index; > - if (info->flags & VM_LOCKED) > - goto redirty; > - if (!total_swap_pages) > - goto redirty; > > /* > * This is somewhat ridiculous, but without plumbing a SWAP_MAP_FALLOC > -- > 2.39.1