Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp658037pxv; Fri, 9 Jul 2021 06:20:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwCOOSYd4gIZtNKwGMqQKscsX9W8zYWc5vP3/1ti9yPICs2v6+92A6q+kuQUaFmWTQJhEZM X-Received: by 2002:a92:3f08:: with SMTP id m8mr25891401ila.104.1625836847080; Fri, 09 Jul 2021 06:20:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625836847; cv=none; d=google.com; s=arc-20160816; b=dtYfXhlqu2fiu4uEmKmprajfZAty6ey2p/fmGYUAjDgNTSk0nqS42o2pzPlyjkP03r DWv5Wt1OYmJo6qNSXMHa3AhRnHGIuv3bpqMUXDU2G/KhPV9Ly73p6CdW07P6Cc1ny8+l dJit/912BGz/bLF7eUcQj1vavbozOj0bxkWXDRwRZaRmsCuDEnQMCiOq1UQiR5c69gEt AVPUdiz0gEVuIhQ72VKmGWp7hvVnu268u6SwLt1C4RlrWQ4flJuEtW/c/pteqPAWrLv1 oLxPHV/WjbI/GwQYOnBNvgNQJmBTZ3q+nrK85haXlqh2YOrgjUI/ojrkKohKuaiMjJg0 Li/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=jy/vXDPAfLWP8NZISJqZ1rqK/k+j6QvnQzCcMSoaODM=; b=vmsKtoKfySxPUbM6C5rWcsc6AD/0LAUNnydpOcGnzoMpTFP4Em0L6Hr1eOsJwMYaK3 qyoTjFJpd1ysBuxYM+WGLzJ4SrinkKEAdFHxBkqgvsJ3ECO6/mp9jXy2qnSC8Pm3Kt7I 5vdKXh/ecHbv9NzMODuwNpKwqorVx/6ReUh/MurbSiXL705tfkKNcLxbNkO5cDd6Zca5 OMWxmvQDb3RmvVTVZlCorhV+YVDyuWzoyWIA5ARc+b1oX82msZbLFHtkhO05gW5II0Ek 0g9X1H/+ySmMMrWomgzDRfcwmLVwxnaf12HgL2pPQLEAsurx66OlzZ8n4COV43sWrJft Lz0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ZZ1ledHQ; 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=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x9si6351707ill.103.2021.07.09.06.20.35; Fri, 09 Jul 2021 06:20:47 -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=@linuxfoundation.org header.s=korg header.b=ZZ1ledHQ; 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=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232302AbhGINWZ (ORCPT + 99 others); Fri, 9 Jul 2021 09:22:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:52832 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232218AbhGINWO (ORCPT ); Fri, 9 Jul 2021 09:22:14 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 87FED611B0; Fri, 9 Jul 2021 13:19:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1625836768; bh=ITU6dZmJuib2i2lKCYWWL9gq9rBia4tuwEAJVfe7tWo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ZZ1ledHQJAnLa99Mv7SFMfy2LCVHSn3DZbyeU2si1+orJ34fsvJyS1VqGW8Lz2GuA gdaoLqUeAJ3D6R0YeU2R3S1ujFQhQXoBZpNrqIXIXTnRJ/gS27h5BYysqsnieZiuyS +1RqE3pNN3b23fHvFXucxp3Y0X696s0Kpqw+nRus= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hugh Dickins , "Kirill A. Shutemov" , Peter Xu , Alistair Popple , Matthew Wilcox , Ralph Campbell , Wang Yugui , Will Deacon , Yang Shi , Zi Yan , Andrew Morton , Linus Torvalds , Sasha Levin Subject: [PATCH 4.14 10/25] mm: page_vma_mapped_walk(): settle PageHuge on entry Date: Fri, 9 Jul 2021 15:18:41 +0200 Message-Id: <20210709131633.975266522@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210709131627.928131764@linuxfoundation.org> References: <20210709131627.928131764@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hugh Dickins [ Upstream commit 6d0fd5987657cb0c9756ce684e3a74c0f6351728 ] page_vma_mapped_walk() cleanup: get the hugetlbfs PageHuge case out of the way at the start, so no need to worry about it later. Link: https://lkml.kernel.org/r/e31a483c-6d73-a6bb-26c5-43c3b880a2@google.com Signed-off-by: Hugh Dickins Acked-by: Kirill A. Shutemov Reviewed-by: Peter Xu Cc: Alistair Popple Cc: "Kirill A. Shutemov" Cc: Matthew Wilcox Cc: Ralph Campbell Cc: Wang Yugui Cc: Will Deacon Cc: Yang Shi Cc: Zi Yan Cc: Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- mm/page_vma_mapped.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/mm/page_vma_mapped.c b/mm/page_vma_mapped.c index 3cff784019c1..bdb63aafc737 100644 --- a/mm/page_vma_mapped.c +++ b/mm/page_vma_mapped.c @@ -147,10 +147,11 @@ bool page_vma_mapped_walk(struct page_vma_mapped_walk *pvmw) if (pvmw->pmd && !pvmw->pte) return not_found(pvmw); - if (pvmw->pte) - goto next_pte; - if (unlikely(PageHuge(page))) { + /* The only possible mapping was handled on last iteration */ + if (pvmw->pte) + return not_found(pvmw); + /* when pud is not present, pte will be NULL */ pvmw->pte = huge_pte_offset(mm, pvmw->address, PAGE_SIZE << compound_order(page)); @@ -163,6 +164,9 @@ bool page_vma_mapped_walk(struct page_vma_mapped_walk *pvmw) return not_found(pvmw); return true; } + + if (pvmw->pte) + goto next_pte; restart: pgd = pgd_offset(mm, pvmw->address); if (!pgd_present(*pgd)) @@ -228,7 +232,7 @@ bool page_vma_mapped_walk(struct page_vma_mapped_walk *pvmw) return true; next_pte: /* Seek to next pte only makes sense for THP */ - if (!PageTransHuge(page) || PageHuge(page)) + if (!PageTransHuge(page)) return not_found(pvmw); end = vma_address_end(page, pvmw->vma); do { -- 2.30.2