Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2463258imm; Mon, 16 Jul 2018 08:25:28 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcrp/y3xQpvfi4BUT6M4JdbP860ByA233x+V+eN8GE75h7oB+rEXYbWSjZEWVpuv3YofZSp X-Received: by 2002:a62:dc8f:: with SMTP id c15-v6mr18495997pfl.155.1531754728515; Mon, 16 Jul 2018 08:25:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531754728; cv=none; d=google.com; s=arc-20160816; b=JZ85uY4ecnlWq44RO5dE5DAZuhs0EIZ3WLk4BIpRMmTzQfXvQisYvRvcMIOW3VuSnh 233J82WE0UIFr8Roxg/PJ3KjRJC+LjttrfjaQed1js7Cc3NtO7gbz0sEIMUD2aklo1ez ul5JKQg2nZctENZxItCYh+Q+PAc+ZTbB3MI0Vy1Xi4HlZdQGRgY/S3GJBdkouv+OhGZL axGuza57P8WXQncooB4r7sKgRcpCEA9lXdi1/eIA9ez2W6qlh7iHAj8teBZmYKm/OXHh aqXlKH5WWgZZGXz0aefbrB2qlegGevzGb7GLTP7f4O9ttBehLgWpcjOGrSqhfEAiedCH sOOQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=kO8bdq+F7dbkq8nolN7fUOj/lQJhTTNUr+1TC6aW5qg=; b=RmuLsGPTE6WoZ1Opcdqq/B0qOyNEIjv9c8lLLCC4qcFBUvCrHjjkym13oDL4kSPe8L KNsUXiL3MQTzb3tvvhr8jxp12/weWcfGux3OK0h0l3Tim6X5T826fXO0XzfSk1AHz7/z XEf1ZqCy+lhjlT09oWDjNi3amLCWqUcXlqPc83f5qkXl/tUXC5xZ7Oe2J0YpcoxX+mQY B/+86k2NQq0bDvaz6NEVCmgiw1B4ydfcaNKyXEz8tshyrtAnuR+yDsGFx9P4MpSAcnSD +n0cpbMKhQ7eLsE11pHz/+301puL2LmglMpBTKZ9e1C2swqWjk7FzmAiSH7L0NrKb3BX y8EQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y34-v6si30431928plb.17.2018.07.16.08.25.12; Mon, 16 Jul 2018 08:25:28 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730029AbeGPPwJ (ORCPT + 99 others); Mon, 16 Jul 2018 11:52:09 -0400 Received: from mx2.suse.de ([195.135.220.15]:38438 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727610AbeGPPwI (ORCPT ); Mon, 16 Jul 2018 11:52:08 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 2E9F1AEC0; Mon, 16 Jul 2018 15:24:12 +0000 (UTC) Date: Mon, 16 Jul 2018 17:24:10 +0200 From: Michal Hocko To: Baoquan He Cc: Chao Fan , Dou Liyang , akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, x86@kernel.org, yasu.isimatu@gmail.com, keescook@chromium.org, indou.takao@jp.fujitsu.com, caoj.fnst@cn.fujitsu.com, vbabka@suse.cz, mgorman@techsingularity.net Subject: Re: Bug report about KASLR and ZONE_MOVABLE Message-ID: <20180716152410.GU17280@dhcp22.suse.cz> References: <20180711094244.GA2019@localhost.localdomain> <20180711104158.GE2070@MiWiFi-R3L-srv> <20180711104944.GG1969@MiWiFi-R3L-srv> <20180711124008.GF2070@MiWiFi-R3L-srv> <72721138-ba6a-32c9-3489-f2060f40a4c9@cn.fujitsu.com> <20180712060115.GD6742@localhost.localdomain> <20180712123228.GK32648@dhcp22.suse.cz> <20180712235240.GH2070@MiWiFi-R3L-srv> <20180716113845.GM17280@dhcp22.suse.cz> <20180716130202.GB1724@MiWiFi-R3L-srv> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180716130202.GB1724@MiWiFi-R3L-srv> User-Agent: Mutt/1.10.0 (2018-05-17) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon 16-07-18 21:02:02, Baoquan He wrote: > On 07/16/18 at 01:38pm, Michal Hocko wrote: > > On Fri 13-07-18 07:52:40, Baoquan He wrote: > > > Hi Michal, > > > > > > On 07/12/18 at 02:32pm, Michal Hocko wrote: > > [...] > > > > I am not able to find the beginning of the email thread right now. Could > > > > you summarize what is the actual problem please? > > > > > > The bug is found on x86 now. > > > > > > When added "kernelcore=" or "movablecore=" into kernel command line, > > > kernel memory is spread evenly among nodes. However, this is right when > > > KASLR is not enabled, then kernel will be at 16M of place in x86 arch. > > > If KASLR enabled, it could be put any place from 16M to 64T randomly. > > > > > > Consider a scenario, we have 10 nodes, and each node has 20G memory, and > > > we specify "kernelcore=50%", means each node will take 10G for > > > kernelcore, 10G for movable area. But this doesn't take kernel position > > > into consideration. E.g if kernel is put at 15G of 2nd node, namely > > > node1. Then we think on node1 there's 10G for kernelcore, 10G for > > > movable, in fact there's only 5G available for movable, just after > > > kernel. > > > > OK, I guess I see that part. But who is going to use movablecore along > > with KASLR enabled? I mean do we really have to support those two > > obscure command line parameters for KASLR? > > Not very sure whether we have to support both of those to work with > KASLR. Maybe it's time to make clear of it now. Yes, I would really like to deprecate this. It is an ugly piece of code and it's far from easily maintainable as well. > For 'kernelcore=mirror', we have solved the conflict to make it work well > with KASLR. For 'movable_node' conflict with KASLR, Chao is posting > patches to fix it. As for 'kernelcore=' and 'movablecore=', > > 1) solve the conflict between them with KASLR in > find_zone_movable_pfns_for_nodes(); > 2) disable KASLR when 'kernelcore=' | 'movablecore=' is set; > 3) disable 'kernelcore=' | 'movablecore=' when KASLR is enabled; > 4) add note in doc to notice people to not add them at the same time; I would simply warn that those kernel parameters are not supported anymore. If somebody shows up with a valid usecase we can reconsider. > 2) and 3) may need be fixed in arch/x86 code. As long as come to an > agreement, any one is fine to me. > > > > In fact I would be much more concerned about memory hotplug and > > pre-defined movable nodes. Does the current KASLR code work in that > > case? > > As said above, kernelcore=mirror works well with KASLR now. Making > 'movable_node' work with KASLR is in progress. OK, thanks for the info. -- Michal Hocko SUSE Labs