Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp8098141imu; Tue, 4 Dec 2018 02:59:14 -0800 (PST) X-Google-Smtp-Source: AFSGD/VQXJXdvqj6v6B8RxeTA0B9VIOnnmxmhvlKbYJjBeSQkMxRB/Z5Or8OeIIyeoLlitEkaRAh X-Received: by 2002:a62:c21c:: with SMTP id l28mr19370450pfg.74.1543921154197; Tue, 04 Dec 2018 02:59:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543921154; cv=none; d=google.com; s=arc-20160816; b=TUUPTgKHROr8/g3MBXKxfIbc5rfr4At0vErzoi6Mljf54bUf6RyRF8sdA7wzeKknEp x4KEVAZ0ns9jqXZ8hPhUQMxswuRUKstQepXPzY4iIzYIj0rlbhqGCsYXOlJvgw9MxygL gJKdbEiQRGb1n+91/7w6NEKfzMvhWhP0rfDYghgs6MDAk761siCiSyqxDVJwdVkfY96r lWsNtxmEhaPtFo2ECQWRW4vEBypqVC0G4r9PCAOMe9XGiVLG92uppNf/+Q1srm6zxwuM t8Vm0mfAhT2BO8cOngCmd1sB/L1SpD4k0JXsfPOtsVYBw5VbD7H8CSVySQOI/b3aTglC WK2g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WOvIRLZ7ighO4JaEPAySXlUqYC3jBf1FQMZTkdZa8yE=; b=iOJSqt0sogupWTo/2+NlnP+tvgEmIhVqyiuparaGpvtEnR0cfKLoxXK3HjBNvoU9Gn mK4sHcr0vDAZXCTZyReLlKl9lCk0cDPXH2iNBVSLKKzeezWn9XS9TPQTNMESQgqMy2pW ccWSuGD4NWoLq8z6QdSwB5pdPtwKutR6HmFbvNB/MxXt4r4lcaIfDJvqYLucOEX5N8OV NzhA/rkGWJQUCQRzwIitb7WgXXTZTs9fsGfWq+KO18aG9XwwKUSI2obOuxL8LW3NPgJR ggEpGlw8SYfUMMRz/dQDBEvsXYXB9iZ1/xuz5J61MySI7dIXPEiFsAihRrbVQoUPfbc4 ScWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OzAu2A6F; 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 c11si15191027pgj.255.2018.12.04.02.58.59; Tue, 04 Dec 2018 02:59:14 -0800 (PST) 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=OzAu2A6F; 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 S1726506AbeLDK4d (ORCPT + 99 others); Tue, 4 Dec 2018 05:56:33 -0500 Received: from mail.kernel.org ([198.145.29.99]:39860 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726466AbeLDK4b (ORCPT ); Tue, 4 Dec 2018 05:56:31 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (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 21E43214F1; Tue, 4 Dec 2018 10:56:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543920990; bh=WzdNy7Xjk2zutoN5UFiQTOI921JovDeDfkzu0rXuwmw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OzAu2A6FNUX0o0h0SR8D8Uc3qucbsFsys7YzTBY+Z6qsh0YfWOodd0f+0aq6efrGI WHcu5efvMhPNzMRTDFoDnAbq6ZDIxgYP1a4QOS9FgHMsia8WYoYAn7/J+pXkgfJSUz xTOxi2w99/7AwEMXOyPQqLjq3VadAoH/Pg5DK5uc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hugh Dickins , "Kirill A. Shutemov" , Jerome Glisse , Konstantin Khlebnikov , Matthew Wilcox , Andrew Morton , Linus Torvalds , Sasha Levin Subject: [PATCH 4.19 005/139] mm/khugepaged: fix crashes due to misaccounted holes Date: Tue, 4 Dec 2018 11:48:06 +0100 Message-Id: <20181204103650.176211712@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181204103649.950154335@linuxfoundation.org> References: <20181204103649.950154335@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ commit aaa52e340073b7f4593b3c4ddafcafa70cf838b5 upstream. Huge tmpfs testing on a shortish file mapped into a pmd-rounded extent hit shmem_evict_inode()'s WARN_ON(inode->i_blocks) followed by clear_inode()'s BUG_ON(inode->i_data.nrpages) when the file was later closed and unlinked. khugepaged's collapse_shmem() was forgetting to update mapping->nrpages on the rollback path, after it had added but then needs to undo some holes. There is indeed an irritating asymmetry between shmem_charge(), whose callers want it to increment nrpages after successfully accounting blocks, and shmem_uncharge(), when __delete_from_page_cache() already decremented nrpages itself: oh well, just add a comment on that to them both. And shmem_recalc_inode() is supposed to be called when the accounting is expected to be in balance (so it can deduce from imbalance that reclaim discarded some pages): so change shmem_charge() to update nrpages earlier (though it's rare for the difference to matter at all). Link: http://lkml.kernel.org/r/alpine.LSU.2.11.1811261523450.2275@eggly.anvils Fixes: 800d8c63b2e98 ("shmem: add huge pages support") Fixes: f3f0e1d2150b2 ("khugepaged: add support of collapse for tmpfs/shmem pages") Signed-off-by: Hugh Dickins Acked-by: Kirill A. Shutemov Cc: Jerome Glisse Cc: Konstantin Khlebnikov Cc: Matthew Wilcox Cc: [4.8+] Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- mm/khugepaged.c | 4 +++- mm/shmem.c | 6 +++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/mm/khugepaged.c b/mm/khugepaged.c index 0378f758b065..87dbb0fcfa1a 100644 --- a/mm/khugepaged.c +++ b/mm/khugepaged.c @@ -1537,8 +1537,10 @@ static void collapse_shmem(struct mm_struct *mm, khugepaged_pages_collapsed++; } else { /* Something went wrong: rollback changes to the radix-tree */ - shmem_uncharge(mapping->host, nr_none); xa_lock_irq(&mapping->i_pages); + mapping->nrpages -= nr_none; + shmem_uncharge(mapping->host, nr_none); + radix_tree_for_each_slot(slot, &mapping->i_pages, &iter, start) { if (iter.index >= end) break; diff --git a/mm/shmem.c b/mm/shmem.c index 38d228a30fdc..cd6b4bc221eb 100644 --- a/mm/shmem.c +++ b/mm/shmem.c @@ -297,12 +297,14 @@ bool shmem_charge(struct inode *inode, long pages) if (!shmem_inode_acct_block(inode, pages)) return false; + /* nrpages adjustment first, then shmem_recalc_inode() when balanced */ + inode->i_mapping->nrpages += pages; + spin_lock_irqsave(&info->lock, flags); info->alloced += pages; inode->i_blocks += pages * BLOCKS_PER_PAGE; shmem_recalc_inode(inode); spin_unlock_irqrestore(&info->lock, flags); - inode->i_mapping->nrpages += pages; return true; } @@ -312,6 +314,8 @@ void shmem_uncharge(struct inode *inode, long pages) struct shmem_inode_info *info = SHMEM_I(inode); unsigned long flags; + /* nrpages adjustment done by __delete_from_page_cache() or caller */ + spin_lock_irqsave(&info->lock, flags); info->alloced -= pages; inode->i_blocks -= pages * BLOCKS_PER_PAGE; -- 2.17.1