Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp2263879imm; Mon, 28 May 2018 05:02:48 -0700 (PDT) X-Google-Smtp-Source: AB8JxZr1XW00QC5f4+NH/k1CCtiPSvjhIOaIlfbSH0CcwsNsLdxNbp8J6N0RMM4cLwXkIABZqn4X X-Received: by 2002:a63:7b51:: with SMTP id k17-v6mr10371947pgn.55.1527508968344; Mon, 28 May 2018 05:02:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527508968; cv=none; d=google.com; s=arc-20160816; b=UUrAzdQmzI2AgXNSvzAZhGkSNmuAdGI1RGGUztMu0LVFVryecwx5upERfDT9rjqN3l oU0AhK1t6i5d/h1Pxm0QvC5Q4+iT5Ggu0gfKbYxAAUB/zS3iv/dJ6MXO397F7ZyYQPbj c5U6gTbPr+qAfw8FyOtaa6pNB8MpKtMMAFlwf0SL9fdies2O3TOxwqd5fxclKIRDLHEM MxHU1SdVHwxNP2/xnNyXZjR9W1qHFfS7fy/SyD2JV6pLuKjHih5xjvobZlQDl/ZqFqhD P5PKGzLA/WWpeGBDogyhUNOsUfU8ng7oVBZGm+s0LeApKPq/shZW9XjLo1VHnK73vkUB mq3g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=1Q4CkzIkbJ8rxefxUF8KXw+tZAQf2+l9DmTynpRiFHA=; b=v67NK9MgkOI6ZgC+pVyxwzwzs9QVQE68+a/42bpBPxD/iNPA3ScH0GF0JBf9zslJKp NWQGLHA0bOBqBmdwydLYh+wpPLHHLtkM3JDbvEzn+KOt3P6PbWzukGBSCPlaN06b+k95 HZYKzjJBSawVeAt7Qp7HQdufqaFqS/ITfxj0cIUrB7hmup/Z5TBHLeLR+zAdfgfyGDpZ J7uN9eLGQvdXfDgORrdoqPQ9s4CBgUqL3N6YMAz7AewKMoaRElFGCs6nBV+O3Z0tFw/P ziDpF3uUtJ0dHFxPQ6VtIsMlc83w4auCZ+XamK1Btf9e1Ueatj+V+Fbi0uGt5Ui+8eC1 hAoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cvH9hnsB; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o9-v6si23594550pgp.508.2018.05.28.05.02.33; Mon, 28 May 2018 05:02:48 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cvH9hnsB; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S938514AbeE1MBg (ORCPT + 99 others); Mon, 28 May 2018 08:01:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:53826 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1423343AbeE1LHG (ORCPT ); Mon, 28 May 2018 07:07:06 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 525F02087E; Mon, 28 May 2018 11:07:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1527505625; bh=vAsdQ9HriR00rhl67tt1iU7DNlLMUPlcmJ8Jv8rLvZ0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cvH9hnsB5ntDJUJzvKPWvogDUIGgJTRzKm9YtIn9SytNLi1qS1yxvHDJaw3gOTnZk ObyovSr+VNWuaHndG/0Jq+ItDZyFF+C5aw28eTNQHjaM5r2GClF+vUEdWd+bWHQtGn 8IUqTtfMr+RbIwZ3MNz4LHycPSj4UZMwT5I0PQMo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Yang Shi , Gang Deng , "Kirill A. Shutemov" , Andrew Morton , Linus Torvalds , Sasha Levin Subject: [PATCH 4.16 070/272] mm: thp: fix potential clearing to referenced flag in page_idle_clear_pte_refs_one() Date: Mon, 28 May 2018 12:01:43 +0200 Message-Id: <20180528100246.789221954@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180528100240.256525891@linuxfoundation.org> References: <20180528100240.256525891@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.16-stable review patch. If anyone has any objections, please let me know. ------------------ From: Yang Shi [ Upstream commit f0849ac0b8e072073ec5fcc7fadd05a77434364e ] For PTE-mapped THP, the compound THP has not been split to normal 4K pages yet, the whole THP is considered referenced if any one of sub page is referenced. When walking PTE-mapped THP by pvmw, all relevant PTEs will be checked to retrieve referenced bit. But, the current code just returns the result of the last PTE. If the last PTE has not referenced, the referenced flag will be cleared. Just set referenced when ptep{pmdp}_clear_young_notify() returns true. Link: http://lkml.kernel.org/r/1518212451-87134-1-git-send-email-yang.shi@linux.alibaba.com Signed-off-by: Yang Shi Reported-by: Gang Deng Suggested-by: Kirill A. Shutemov Reviewed-by: Andrew Morton Cc: "Kirill A. Shutemov" Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- mm/page_idle.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) --- a/mm/page_idle.c +++ b/mm/page_idle.c @@ -65,11 +65,15 @@ static bool page_idle_clear_pte_refs_one while (page_vma_mapped_walk(&pvmw)) { addr = pvmw.address; if (pvmw.pte) { - referenced = ptep_clear_young_notify(vma, addr, - pvmw.pte); + /* + * For PTE-mapped THP, one sub page is referenced, + * the whole THP is referenced. + */ + if (ptep_clear_young_notify(vma, addr, pvmw.pte)) + referenced = true; } else if (IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE)) { - referenced = pmdp_clear_young_notify(vma, addr, - pvmw.pmd); + if (pmdp_clear_young_notify(vma, addr, pvmw.pmd)) + referenced = true; } else { /* unexpected pmd-mapped page? */ WARN_ON_ONCE(1);