Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp1014855pxb; Tue, 17 Aug 2021 01:29:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzz7hi68YqRaVNooit/faHkSugr/y8r6uDobOK3wTn9TaqwXxjpev+s7qY4ej4qEQymOULI X-Received: by 2002:a05:6e02:1526:: with SMTP id i6mr1599557ilu.74.1629188992996; Tue, 17 Aug 2021 01:29:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629188992; cv=none; d=google.com; s=arc-20160816; b=Xl80H6H5CVHFD/V+QQSLLTooCyXk2MfC7TkTGKB6Y/0+zo3tvLdErRVMZ5ukXnLNLu mPoNQUXsMerLBa4jQDOXvadashqsgMPAZ6n38iBr4jO31C5dq7RJv2HYbtF3a8pzhBvP D81zkizHQ5dxIvbQtMC4Wvjwxq4wjx4KwqCoZejFU2wSeVdnaMipXrXDPBhSAm0Mb5PY pllP+Yn+imwv4qD4uFo3FQy+dzkeg2eojbCVZ9xltJ5ekIIvX3m43XCUriBf2AJiWLP8 bxu1zg1G5RYDE5UKom6YK/lGQ4qZ8VrDu6SZXfoag0zWlJnL4/pL8C8zPElBFP36iyCj bwnQ== 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=4uvnY/LMX/fosu9BxO1MG6ugTMEZPtMwQldGntwsVH4=; b=jOBVEblz+HM+j836Wy+Cpm10UCHVYpBcb/vIDA7HmsF0GafxkzVXTmKsH9ubkFseHr keAbo7zNvs/hi/5ZCmiKaT8TnTsDjvwEhOPhLNRYqRBxGb1GW+7mZ3Lb6odmgGlto3EU zWEdnAPLfos4N6s5n4mm0901Aiikxz89p4n3/MCC4HEICJlI+r/q88NStweNRUGXxq1S BG4SchtSySC9xAeu2FAMBjdYsFTKMKARfpTTGA6bP9/8LNzlpfQH1U1KU2CuCVtpipaC EgAFnsfE48kVJUE8VIPlnbbpSVlebdHectJuKiRgUjWHsSXLwZgqoGZkSk5lzmjiy7Lf f25A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=NjCpK1NR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h8si1819689jav.8.2021.08.17.01.29.41; Tue, 17 Aug 2021 01:29:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=NjCpK1NR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S235075AbhHQI3e (ORCPT + 99 others); Tue, 17 Aug 2021 04:29:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234676AbhHQI3d (ORCPT ); Tue, 17 Aug 2021 04:29:33 -0400 Received: from mail-qt1-x82b.google.com (mail-qt1-x82b.google.com [IPv6:2607:f8b0:4864:20::82b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 90EADC061764 for ; Tue, 17 Aug 2021 01:29:00 -0700 (PDT) Received: by mail-qt1-x82b.google.com with SMTP id e15so16503998qtx.1 for ; Tue, 17 Aug 2021 01:29:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:from:to:cc:subject:in-reply-to:message-id:references :mime-version; bh=4uvnY/LMX/fosu9BxO1MG6ugTMEZPtMwQldGntwsVH4=; b=NjCpK1NRhKmstHnpGiLXqM2SKOhBWtRSCCvP/5Amp0gqEwqp6QT1o+8ceJjU6jfYcL rDI6S2AFNamPsB4rByVDzyJlXKw4KZXU6D0rbktDv/9QfD0J2t8oUAaB2sOJGLBryTbW Eg9ME3auwtSoigl65liufDjtNbWJvOmgaeLq0eHHCyxJsULVCFf7GfGUgrPKsbxSwVQA cmdDUSbsnv+SoYjurKcsqszQmy4FQpbClnq9Zw42AWXe3ivRgU+PvAoZN1q5lME2rVm4 TE3/faPz6Y+vVIFyvh3bn7WAE5/J5u/v0idpkWltxqrs69YoF8K/Vp1jMsvycr72ZwZl rKrg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:in-reply-to:message-id :references:mime-version; bh=4uvnY/LMX/fosu9BxO1MG6ugTMEZPtMwQldGntwsVH4=; b=G8kGjULSYeS/UX5CG5Q5DII9tltulBxA9fpLBMLnsbLCdpo2enOfYZCG2hElnoQAq5 PtbCXUglw8eCZ7xNDqvpZWEhUnYkC3+NobW5Q+zLwSTBkDNdo8AlKK8dQkLavhkgU4PB n4fGslz0or7bYL3hvAv8PPtM5C+pVQ4lcgOvvLDcPmg/8jyGdAprEER+lkp0cKD2PA0a cuW1lCekokz9d65gT7ELSf0JB3lW7FkQLHzymUHLo2HwwyRICTNKHTbSH1M0GptAGLCg 6BlFfVL31xKQhm0sJmVNDCw+5xddHk/ng7+eyoJ44OkBICDcHJL+WqlPYKrvGXhoz97+ DBzw== X-Gm-Message-State: AOAM532Kv+QNH07W1zV229wiD0p0yjldc3UEjacxxg7Kc8/IYwgYSdC3 QnhffHfgtJJJblmcapFBvDO/5Q== X-Received: by 2002:a05:622a:13d4:: with SMTP id p20mr2056913qtk.380.1629188939512; Tue, 17 Aug 2021 01:28:59 -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 y26sm884220qkm.65.2021.08.17.01.28.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 17 Aug 2021 01:28:58 -0700 (PDT) Date: Tue, 17 Aug 2021 01:28:56 -0700 (PDT) From: Hugh Dickins X-X-Sender: hugh@ripple.anvils To: Andrew Morton cc: Hugh Dickins , Shakeel Butt , "Kirill A. Shutemov" , Yang Shi , Miaohe Lin , Mike Kravetz , Michal Hocko , Rik van Riel , Matthew Wilcox , Chris Wilson , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 9/9] shmem: shmem_writepage() split unlikely i915 THP In-Reply-To: Message-ID: References: MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org drivers/gpu/drm/i915/gem/i915_gem_shmem.c contains a shmem_writeback() which calls shmem_writepage() from a shrinker: that usually works well enough; but if /sys/kernel/mm/transparent_hugepage/shmem_enabled has been set to "always" (intended to be usable) or "force" (forces huge everywhere for easy testing), shmem_writepage() is surprised to be called with a huge page, and crashes on the VM_BUG_ON_PAGE(PageCompound) (I did not find out where the crash happens when CONFIG_DEBUG_VM is off). LRU page reclaim always splits the shmem huge page first: I'd prefer not to demand that of i915, so check and split compound in shmem_writepage(). Patch history: when first sent last year http://lkml.kernel.org/r/alpine.LSU.2.11.2008301401390.5954@eggly.anvils https://lore.kernel.org/linux-mm/20200919042009.bomzxmrg7%25akpm@linux-foundation.org/ Matthew Wilcox noticed that tail pages were wrongly left clean. This version brackets the split with Set and Clear PageDirty as he suggested: which works very well, even if it falls short of our aspirations. And recently I realized that the crash is not limited to the testing option "force", but affects "always" too: which is more important to fix. Fixes: 2d6692e642e7 ("drm/i915: Start writeback from the shrinker") Signed-off-by: Hugh Dickins Reviewed-by: Shakeel Butt Acked-by: Yang Shi --- mm/shmem.c | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/mm/shmem.c b/mm/shmem.c index b60a7abff27d..a1ba03f39eaa 100644 --- a/mm/shmem.c +++ b/mm/shmem.c @@ -1349,7 +1349,19 @@ static int shmem_writepage(struct page *page, struct writeback_control *wbc) swp_entry_t swap; pgoff_t index; - VM_BUG_ON_PAGE(PageCompound(page), page); + /* + * If /sys/kernel/mm/transparent_hugepage/shmem_enabled is "always" or + * "force", drivers/gpu/drm/i915/gem/i915_gem_shmem.c gets huge pages, + * and its shmem_writeback() needs them to be split when swapping. + */ + if (PageTransCompound(page)) { + /* Ensure the subpages are still dirty */ + SetPageDirty(page); + if (split_huge_page(page) < 0) + goto redirty; + ClearPageDirty(page); + } + BUG_ON(!PageLocked(page)); mapping = page->mapping; index = page->index; -- 2.26.2