From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.6 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id B5A75C33C9B for ; Wed, 8 Jan 2020 10:24:51 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 4EF512077B for ; Wed, 8 Jan 2020 10:24:51 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="KOYYCAzG" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 4EF512077B Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 9BA238E0005; Wed, 8 Jan 2020 05:24:50 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 9693E8E0001; Wed, 8 Jan 2020 05:24:50 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 857F68E0005; Wed, 8 Jan 2020 05:24:50 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0126.hostedemail.com [216.40.44.126]) by kanga.kvack.org (Postfix) with ESMTP id 6DA718E0001 for ; Wed, 8 Jan 2020 05:24:50 -0500 (EST) Received: from smtpin05.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with SMTP id 2A412180AD806 for ; Wed, 8 Jan 2020 10:24:50 +0000 (UTC) X-FDA: 76354083540.05.birth78_d0eee1ea1e3d X-HE-Tag: birth78_d0eee1ea1e3d X-Filterd-Recvd-Size: 4030 Received: from mail-pg1-f195.google.com (mail-pg1-f195.google.com [209.85.215.195]) by imf12.hostedemail.com (Postfix) with ESMTP for ; Wed, 8 Jan 2020 10:24:49 +0000 (UTC) Received: by mail-pg1-f195.google.com with SMTP id k197so1348884pga.10 for ; Wed, 08 Jan 2020 02:24:49 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=Pwd6pPOfjcWBYssAiTNpLV/0fJ/zD+lixc1xNtJf0dM=; b=KOYYCAzGbdAmhqvoEW/wE4aLQ4Fde7v1gbG5YsnKLTapWTB8RfLiauP3P2og7nDG1p NqIQKtRHXRS8Y/YqBD8+XL0SptodOtyKaIUOswuCo4KUQ1IYsrphzFGIpFlDC9fOBrJ6 oJHuplRjqbn1XSdA4IAWKNETBuADlJmBnD6DhYmyl++NMfDDqHMLqfCBNmlkEJKaZPJO L4PB5jt/32q0Nh73m3a0P/0qDSkZ34x46Wy5owjYkLY5yb/0dJSMXa0Y+kcJzSXF1Y1D uVtSNKu9iH6xM05QCe47bLZ5TtN2LcBriwMCFoC4bZTd7d27zOp6Rny1V57vgkI1SmdE tIvw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=Pwd6pPOfjcWBYssAiTNpLV/0fJ/zD+lixc1xNtJf0dM=; b=eVzBWyyYK0Kyx+oMVTpqeBcw1YNa8tgLo90IUqIXTmpMuRs4232JlElYkMTJOglW0j Qgfgk0k/WFCnar3ipasgWFSQZmQO27d3OA9lYWcdxFTKEUlIWITSZ6kDcKUKgCQLjs6q xEsCPMSOAE9h4dkKW1hr+4n4OoJZdQ3TGhqX4Qys2vz5fWaP8C+cfhTbWvmBSlH2SCDz lS0ZUnEYDDBlhH9cie6XqUcEWVLqdSWar13w1YgjoyGb6Yd41ClAsDs1xoQqWA6NrUaW tUH5Lbmk3RUGQtChLnZ2kH59XZaGIB84fdYwxlX7FL8Tywf/EiUCjv3/eETTvHHmlCOI fnPw== X-Gm-Message-State: APjAAAVOl4JnwG+a9hPrZ7/IqLiZSqYRPigTKg/UV3QbRuBnc4EcpEED aMue9iw+gcSrn3fbYjKCDs0= X-Google-Smtp-Source: APXvYqwvzoAamwVJoubFH05zcgHB4geGaEetaFCpGtR6A2CuUJYuQerqEOKLD6qZWM0MhbitTf54NQ== X-Received: by 2002:aa7:9ec9:: with SMTP id r9mr4213707pfq.85.1578479088546; Wed, 08 Jan 2020 02:24:48 -0800 (PST) Received: from VM_16_2_centos.localdomain ([150.109.63.214]) by smtp.gmail.com with ESMTPSA id 13sm2986301pfi.78.2020.01.08.02.24.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 08 Jan 2020 02:24:48 -0800 (PST) From: Qiujun Huang To: akpm@linux-foundation.org Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, jhubbard@nvidia.com, aneesh.kumar@linux.ibm.com, Qiujun Huang Subject: [PATCH v2] mm:fix gup_pud_range Date: Wed, 8 Jan 2020 18:24:44 +0800 Message-Id: <1578479084-15508-1-git-send-email-hqjagain@gmail.com> X-Mailer: git-send-email 1.8.3.1 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: sorry for not processing for a long time. I met it again. patch v1 https://lkml.org/lkml/2019/9/20/656 do_machine_check() do_memory_failure() memory_failure() hw_poison_user_mappings() try_to_unmap() pteval = swp_entry_to_pte(make_hwpoison_entry(subpage)); ...and now we have a swap entry that indicates that the page entry refers to a bad (and poisoned) page of memory, but gup_fast() at this level of the page table was ignoring swap entries, and incorrectly assuming that "!pxd_none() == valid and present". And this was not just a poisoned page problem, but a generaly swap entry problem. So, any swap entry type (device memory migration, numa migration, or just regular swapping) could lead to the same problem. Fix this by checking for pxd_present(), instead of pxd_none(). Signed-off-by: Qiujun Huang --- mm/gup.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mm/gup.c b/mm/gup.c index 7646bf9..9c41670 100644 --- a/mm/gup.c +++ b/mm/gup.c @@ -2237,7 +2237,7 @@ static int gup_pud_range(p4d_t p4d, unsigned long addr, unsigned long end, pud_t pud = READ_ONCE(*pudp); next = pud_addr_end(addr, end); - if (pud_none(pud)) + if (unlikely(!pud_present(pud))) return 0; if (unlikely(pud_huge(pud))) { if (!gup_huge_pud(pud, pudp, addr, next, flags, -- 1.8.3.1