Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1772763imm; Thu, 27 Sep 2018 02:12:23 -0700 (PDT) X-Google-Smtp-Source: ACcGV63wFFbkZbgT2UIPT/wBzU/hZeJJhMt20r/NFNUxoosCAS5X4Q4kwNKEnTZWFanY2aDdUiQb X-Received: by 2002:a62:6e45:: with SMTP id j66-v6mr6161959pfc.259.1538039542854; Thu, 27 Sep 2018 02:12:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538039542; cv=none; d=google.com; s=arc-20160816; b=B+BEzGMwUJA24RqxOdFedNfu/P0Rtjo1/7Bp1ZQIMQi3XSkSUi7bFfDtsDcycwyQ1K gMNUwZ2AtaUcrjGOrajALmcBzUEgs57qbVVN8asnitbE8g9hIHnmAN/lgTJelc8I+S// WRVVVG15L6li4Al4KxWAY03kzeyL1RBV8HqiOcjEGjdcXQIsuD6EJG8OoEMzIw0fEW2Q nUxhMn9zAouy4dJtz9a0O/aPUlrHPi2pwdHyLwUjOCTF7OLOZfRqb2InRrV16LcT0HaG syxRh/+ilowU9RrGtBwub8XNA5sUIoYjrYOaKjSX0VEKQ/f6gN8/aPt6V7cx1PZmR0bj Ag4A== 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; bh=TB2w0I1cb5Puxdc4LzzeQYUgfHjOq/pwYV1d401Plg0=; b=Upvr/Er1nNQ1Bs+1maQpGXCCrRj2+HTzkrBWTQUx/WP+wo3GONBVkTa2D7n/G+OP6D i0kRQ0wXU/MN1Vfp9jk5WfTJ0cLvWC+In65ayiAYz1ZupuUt/cWhMk7JkPWeIKAbK5fr xZbPtL0xF6AP3wVvWpPsmx/O6mhkr5Sd7AG13gw8Uq86faWpRP/QhzUyJha+thMiSrn0 OF5i7Yc7Qi8iNqf0Da0fJJscxx6PDz8wf9ktLWp7NF/J93Vqq8YKkEmAidjSkhjj88xn 4kUaBuMWMMwe998ht2oTiFnI8w2dIxnmHH7Hek8N9upwFq7Pu1TC4acNig91Xe579MUh lNzg== ARC-Authentication-Results: i=1; mx.google.com; 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 i64-v6si1558649pfc.16.2018.09.27.02.12.07; Thu, 27 Sep 2018 02:12:22 -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; 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 S1728498AbeI0P2X (ORCPT + 99 others); Thu, 27 Sep 2018 11:28:23 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:55212 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727447AbeI0P2W (ORCPT ); Thu, 27 Sep 2018 11:28:22 -0400 Received: from localhost (ip-213-127-77-73.ip.prioritytelecom.net [213.127.77.73]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 8CFCD111D; Thu, 27 Sep 2018 09:11:05 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pavel Tatashin , Jiri Slaby , Michal Hocko , Andrew Morton Subject: [PATCH 4.18 51/88] mm: disable deferred struct page for 32-bit arches Date: Thu, 27 Sep 2018 11:03:32 +0200 Message-Id: <20180927090307.031484475@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20180927090300.631426620@linuxfoundation.org> References: <20180927090300.631426620@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Pasha Tatashin commit 889c695d419f19e5db52592dafbaf26143c36d1f upstream. Deferred struct page init is needed only on systems with large amount of physical memory to improve boot performance. 32-bit systems do not benefit from this feature. Jiri reported a problem where deferred struct pages do not work well with x86-32: [ 0.035162] Dentry cache hash table entries: 131072 (order: 7, 524288 bytes) [ 0.035725] Inode-cache hash table entries: 65536 (order: 6, 262144 bytes) [ 0.036269] Initializing CPU#0 [ 0.036513] Initializing HighMem for node 0 (00036ffe:0007ffe0) [ 0.038459] page:f6780000 is uninitialized and poisoned [ 0.038460] raw: ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff [ 0.039509] page dumped because: VM_BUG_ON_PAGE(1 && PageCompound(page)) [ 0.040038] ------------[ cut here ]------------ [ 0.040399] kernel BUG at include/linux/page-flags.h:293! [ 0.040823] invalid opcode: 0000 [#1] SMP PTI [ 0.041166] CPU: 0 PID: 0 Comm: swapper Not tainted 4.19.0-rc1_pt_jiri #9 [ 0.041694] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.11.0-20171110_100015-anatol 04/01/2014 [ 0.042496] EIP: free_highmem_page+0x64/0x80 [ 0.042839] Code: 13 46 d8 c1 e8 18 5d 83 e0 03 8d 04 c0 c1 e0 06 ff 80 ec 5f 44 d8 c3 8d b4 26 00 00 00 00 ba 08 65 28 d8 89 d8 e8 fc 71 02 00 <0f> 0b 8d 76 00 8d bc 27 00 00 00 00 ba d0 b1 26 d8 89 d8 e8 e4 71 [ 0.044338] EAX: 0000003c EBX: f6780000 ECX: 00000000 EDX: d856cbe8 [ 0.044868] ESI: 0007ffe0 EDI: d838df20 EBP: d838df00 ESP: d838defc [ 0.045372] DS: 007b ES: 007b FS: 00d8 GS: 00e0 SS: 0068 EFLAGS: 00210086 [ 0.045913] CR0: 80050033 CR2: 00000000 CR3: 18556000 CR4: 00040690 [ 0.046413] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000 [ 0.046913] DR6: fffe0ff0 DR7: 00000400 [ 0.047220] Call Trace: [ 0.047419] add_highpages_with_active_regions+0xbd/0x10d [ 0.047854] set_highmem_pages_init+0x5b/0x71 [ 0.048202] mem_init+0x2b/0x1e8 [ 0.048460] start_kernel+0x1d2/0x425 [ 0.048757] i386_start_kernel+0x93/0x97 [ 0.049073] startup_32_smp+0x164/0x168 [ 0.049379] Modules linked in: [ 0.049626] ---[ end trace 337949378db0abbb ]--- We free highmem pages before their struct pages are initialized: mem_init() set_highmem_pages_init() add_highpages_with_active_regions() free_highmem_page() .. Access uninitialized struct page here.. Because there is no reason to have this feature on 32-bit systems, just disable it. Link: http://lkml.kernel.org/r/20180831150506.31246-1-pavel.tatashin@microsoft.com Fixes: 2e3ca40f03bb ("mm: relax deferred struct page requirements") Signed-off-by: Pavel Tatashin Reported-by: Jiri Slaby Acked-by: Michal Hocko Cc: Signed-off-by: Andrew Morton Signed-off-by: Greg Kroah-Hartman --- mm/Kconfig | 1 + 1 file changed, 1 insertion(+) --- a/mm/Kconfig +++ b/mm/Kconfig @@ -637,6 +637,7 @@ config DEFERRED_STRUCT_PAGE_INIT depends on NO_BOOTMEM depends on SPARSEMEM depends on !NEED_PER_CPU_KM + depends on 64BIT help Ordinarily all struct pages are initialised during early boot in a single thread. On very large machines this can take a considerable