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=-6.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS 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 37521C43331 for ; Wed, 13 Nov 2019 06:08:43 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id D975E206BA for ; Wed, 13 Nov 2019 06:08:42 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org D975E206BA Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ah.jp.nec.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 701276B0005; Wed, 13 Nov 2019 01:08:42 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 6B1CE6B000C; Wed, 13 Nov 2019 01:08:42 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 5C8196B000D; Wed, 13 Nov 2019 01:08:42 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0027.hostedemail.com [216.40.44.27]) by kanga.kvack.org (Postfix) with ESMTP id 492AC6B0005 for ; Wed, 13 Nov 2019 01:08:42 -0500 (EST) Received: from smtpin05.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay05.hostedemail.com (Postfix) with SMTP id 0FCCE181AEF1D for ; Wed, 13 Nov 2019 06:08:42 +0000 (UTC) X-FDA: 76150225284.05.star04_2eb2115d87518 X-HE-Tag: star04_2eb2115d87518 X-Filterd-Recvd-Size: 5162 Received: from tyo162.gate.nec.co.jp (tyo162.gate.nec.co.jp [114.179.232.162]) by imf36.hostedemail.com (Postfix) with ESMTP for ; Wed, 13 Nov 2019 06:08:40 +0000 (UTC) Received: from mailgate01.nec.co.jp ([114.179.233.122]) by tyo162.gate.nec.co.jp (8.15.1/8.15.1) with ESMTPS id xAD68XOF026408 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Wed, 13 Nov 2019 15:08:33 +0900 Received: from mailsv01.nec.co.jp (mailgate-v.nec.co.jp [10.204.236.94]) by mailgate01.nec.co.jp (8.15.1/8.15.1) with ESMTP id xAD68Xib010372; Wed, 13 Nov 2019 15:08:33 +0900 Received: from mail03.kamome.nec.co.jp (mail03.kamome.nec.co.jp [10.25.43.7]) by mailsv01.nec.co.jp (8.15.1/8.15.1) with ESMTP id xAD64PCr013961; Wed, 13 Nov 2019 15:08:33 +0900 Received: from bpxc99gp.gisp.nec.co.jp ([10.38.151.149] [10.38.151.149]) by mail03.kamome.nec.co.jp with ESMTP id BT-MMP-711271; Wed, 13 Nov 2019 15:02:04 +0900 Received: from BPXM23GP.gisp.nec.co.jp ([10.38.151.215]) by BPXC21GP.gisp.nec.co.jp ([10.38.151.149]) with mapi id 14.03.0439.000; Wed, 13 Nov 2019 15:02:03 +0900 From: Naoya Horiguchi To: "Aneesh Kumar K.V" CC: Michal Hocko , Oscar Salvador , "mike.kravetz@oracle.com" , "linux-mm@kvack.org" , "linux-kernel@vger.kernel.org" Subject: Re: [RFC PATCH v2 01/16] mm,hwpoison: cleanup unused PageHuge() check Thread-Topic: [RFC PATCH v2 01/16] mm,hwpoison: cleanup unused PageHuge() check Thread-Index: AQHVhPYzQyNwsIsv3k6BqLdb1qTKQ6dfsyIAgARmlwCAIu1QAIABJ+YA Date: Wed, 13 Nov 2019 06:02:03 +0000 Message-ID: <20191113060202.GA3503@hori.linux.bs1.fc.nec.co.jp> References: <20191017142123.24245-1-osalvador@suse.de> <20191017142123.24245-2-osalvador@suse.de> <20191018114832.GK5017@dhcp22.suse.cz> <20191021070046.GA8782@hori.linux.bs1.fc.nec.co.jp> <87d0dxs2ql.fsf@linux.ibm.com> In-Reply-To: <87d0dxs2ql.fsf@linux.ibm.com> Accept-Language: en-US, ja-JP Content-Language: ja-JP X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.34.125.150] Content-Type: text/plain; charset="iso-2022-jp" Content-ID: <6EE8F565F6E5FB42A7EDC191D45757AC@gisp.nec.co.jp> Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-TM-AS-MML: disable 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: On Tue, Nov 12, 2019 at 05:52:58PM +0530, Aneesh Kumar K.V wrote: > Naoya Horiguchi writes: >=20 > > On Fri, Oct 18, 2019 at 01:48:32PM +0200, Michal Hocko wrote: > >> On Thu 17-10-19 16:21:08, Oscar Salvador wrote: > >> > From: Naoya Horiguchi > >> >=20 > >> > Drop the PageHuge check since memory_failure forks into memory_failu= re_hugetlb() > >> > for hugetlb pages. > >> >=20 > >> > Signed-off-by: Oscar Salvador > >> > Signed-off-by: Naoya Horiguchi > >>=20 > >> s-o-b chain is reversed. > >>=20 > >> The code is a bit confusing. Doesn't this check aim for THP? > > > > No, PageHuge() is false for thp, so this if branch is just dead code. >=20 > memory_failure() > { >=20 > if (PageTransHuge(hpage)) { > lock_page(p); > if (!PageAnon(p) || unlikely(split_huge_page(p))) { > unlock_page(p); > if (!PageAnon(p)) > pr_err("Memory failure: %#lx: non anonymous thp\n", > pfn); > else > pr_err("Memory failure: %#lx: thp split failed\n", > pfn); > if (TestClearPageHWPoison(p)) > num_poisoned_pages_dec(); > put_hwpoison_page(p); > return -EBUSY; > } > unlock_page(p); > VM_BUG_ON_PAGE(!page_count(p), p); > hpage =3D compound_head(p); > } >=20 > } >=20 > Do we need that hpage =3D compund_head(p) conversion there? We should jus= t > be able to say hpage =3D p, or even better after this change use p > directly instead of hpage in the code following? Thanks for the comment, the target page never be in compound_page (without races leading to MF_MSG_DIFFERENT_COMPOUND path), so hpage shouldn't be used afterward. We also have obsolete comment, so I feel like the following changes: diff --git a/mm/memory-failure.c b/mm/memory-failure.c index 392ac277b17d..c9df0f183d6c 100644 --- a/mm/memory-failure.c +++ b/mm/memory-failure.c @@ -1319,7 +1319,6 @@ int memory_failure(unsigned long pfn, int flags) } unlock_page(p); VM_BUG_ON_PAGE(!page_count(p), p); - hpage =3D compound_head(p); } =20 /* @@ -1391,11 +1390,8 @@ int memory_failure(unsigned long pfn, int flags) /* * Now take care of user space mappings. * Abort on fail: __delete_from_page_cache() assumes unmapped page. - * - * When the raw error page is thp tail page, hpage points to the raw - * page after thp split. */ - if (!hwpoison_user_mappings(p, pfn, flags, &hpage)) { + if (!hwpoison_user_mappings(p, pfn, flags, &p)) { action_result(pfn, MF_MSG_UNMAP_FAILED, MF_IGNORED); res =3D -EBUSY; goto out; Thanks, Naoya Horiguchi=