Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp657174pxv; Thu, 15 Jul 2021 12:39:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzzDUCY9FWiBaw305PDXMU1P1LKjNu4baCb4BRBmZ969qQTy5lhk68azkYOB+tu7MS9Z5tA X-Received: by 2002:aa7:d809:: with SMTP id v9mr9433470edq.146.1626377997731; Thu, 15 Jul 2021 12:39:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626377997; cv=none; d=google.com; s=arc-20160816; b=hJFtIguldg2TkNnmKrwsHBfXNKuifxBaE9tD5m2jSlxTEibD9eqSOPsGnSZzpODnsF MAYTM4jqFqf+nU0ja5JV2me/pHxRgMmpGQp+UHElq+1saafmEyQEyuBvUjWS6qP9NCDs Fx6fSA4z3ncRHzaUAXo+Hsv6S40Apfh3Xq3lP/W7pqN+u9aOKmYkcxwIF52oDlvTHvlG UceeJSK26pDP1r90E/74LGnvUj/r7Vsxqndas5z7ptLyg+yz0ZUhWhupvf6rP5Og8S8n 5IDjPfFJYTQc1xg8s28ZmK6R7xiC41UIhoMlIPdzW/M39GG4518J7YAl/YoebuwG5nwO XdOg== 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=XfmhhruqA71VG9GwzNuS6kHd4b4ITaVCmLm1LUfL/ac=; b=d0zXGex/7iMjb/yfEGfd+7OVGpPEq9yZRxGW1p5cR3DQWBzhuJt/noyCXnPlTdPA6c 05E4xagBBA3HYJ802RHPLulUF0hqBhDItTihC3kFAfXfKIp29LZKixL3XLY/QSnynky0 pYzphN5crNFnVunY/PVq5ug17TP1yrz8Pgou29HrC0KYzpDG2V1RX5RlNkPKGfnvH5p0 yebaVz2hrmJqfWVgpPAEzwGFHUhPjR1tHauOZIKaAbV4n0q1qu6zWiaxbjfw7jj3jBaU blxBPZiPfWQCEyDtwaTZGgwFuMaqfm18CdT5JTRK3h9uOTFxoiFH5xFV/fy6071SV84N rtWw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=qcCBJmuF; 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 m4si9078496eja.301.2021.07.15.12.39.34; Thu, 15 Jul 2021 12:39:57 -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=qcCBJmuF; 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 S245436AbhGOTjU (ORCPT + 99 others); Thu, 15 Jul 2021 15:39:20 -0400 Received: from mail.kernel.org ([198.145.29.99]:51470 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244322AbhGOTOn (ORCPT ); Thu, 15 Jul 2021 15:14:43 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id A8477613EB; Thu, 15 Jul 2021 19:10:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626376220; bh=SMo/T7Ka7E8f0cAteUTp8D85XzExdOnkdsf86LhuHO4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qcCBJmuFcE3Bo7v82KLwKstQbCAh/6jdfQTeq5A5xJq5Anh9WuE/1ncRB/btyFb4+ 5S70SFklzw6Pif0bNY/owTyDj9itjkuG65c6SRV7FAtTyezXqJ2Ur8vcEXQatXR/gc b9RWQfA8uyRM2SZYlNtZBRyuoub9+2Vqo1dp6eTY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Aneesh Kumar K.V" , Hugh Dickins , "Kirill A. Shutemov" , Christophe Leroy , Joel Fernandes , Kalesh Singh , "Kirill A. Shutemov" , Michael Ellerman , Nicholas Piggin , Stephen Rothwell , Andrew Morton , Linus Torvalds Subject: [PATCH 5.13 179/266] mm/mremap: hold the rmap lock in write mode when moving page table entries. Date: Thu, 15 Jul 2021 20:38:54 +0200 Message-Id: <20210715182643.348412958@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210715182613.933608881@linuxfoundation.org> References: <20210715182613.933608881@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: Aneesh Kumar K.V commit 97113eb39fa7972722ff490b947d8af023e1f6a2 upstream. To avoid a race between rmap walk and mremap, mremap does take_rmap_locks(). The lock was taken to ensure that rmap walk don't miss a page table entry due to PTE moves via move_pagetables(). The kernel does further optimization of this lock such that if we are going to find the newly added vma after the old vma, the rmap lock is not taken. This is because rmap walk would find the vmas in the same order and if we don't find the page table attached to older vma we would find it with the new vma which we would iterate later. As explained in commit eb66ae030829 ("mremap: properly flush TLB before releasing the page") mremap is special in that it doesn't take ownership of the page. The optimized version for PUD/PMD aligned mremap also doesn't hold the ptl lock. This can result in stale TLB entries as show below. This patch updates the rmap locking requirement in mremap to handle the race condition explained below with optimized mremap:: Optmized PMD move CPU 1 CPU 2 CPU 3 mremap(old_addr, new_addr) page_shrinker/try_to_unmap_one mmap_write_lock_killable() addr = old_addr lock(pte_ptl) lock(pmd_ptl) pmd = *old_pmd pmd_clear(old_pmd) flush_tlb_range(old_addr) *new_pmd = pmd *new_addr = 10; and fills TLB with new addr and old pfn unlock(pmd_ptl) ptep_clear_flush() old pfn is free. Stale TLB entry Optimized PUD move also suffers from a similar race. Both the above race condition can be fixed if we force mremap path to take rmap lock. Link: https://lkml.kernel.org/r/20210616045239.370802-7-aneesh.kumar@linux.ibm.com Fixes: 2c91bd4a4e2e ("mm: speed up mremap by 20x on large regions") Fixes: c49dd3401802 ("mm: speedup mremap on 1GB or larger regions") Link: https://lore.kernel.org/linux-mm/CAHk-=wgXVR04eBNtxQfevontWnP6FDm+oj5vauQXP3S-huwbPw@mail.gmail.com Signed-off-by: Aneesh Kumar K.V Acked-by: Hugh Dickins Acked-by: Kirill A. Shutemov Cc: Christophe Leroy Cc: Joel Fernandes Cc: Kalesh Singh Cc: Kirill A. Shutemov Cc: Michael Ellerman Cc: Nicholas Piggin Cc: Stephen Rothwell Cc: Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- mm/mremap.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/mm/mremap.c +++ b/mm/mremap.c @@ -439,7 +439,7 @@ unsigned long move_page_tables(struct vm if (!new_pud) break; if (move_pgt_entry(NORMAL_PUD, vma, old_addr, new_addr, - old_pud, new_pud, need_rmap_locks)) + old_pud, new_pud, true)) continue; } @@ -466,7 +466,7 @@ unsigned long move_page_tables(struct vm * moving at the PMD level if possible. */ if (move_pgt_entry(NORMAL_PMD, vma, old_addr, new_addr, - old_pmd, new_pmd, need_rmap_locks)) + old_pmd, new_pmd, true)) continue; }