From patchwork Mon Jul 9 23:42:26 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: AKASHI Takahiro X-Patchwork-Id: 141494 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp3205046ljj; Mon, 9 Jul 2018 16:42:06 -0700 (PDT) X-Google-Smtp-Source: AAOMgpeBioWE1Ib8u3LV2BDzavwaKDyxeOAjH8scwBWm0ywPchdD5ok+E8vujhzkvzG4TQAk2QzZ X-Received: by 2002:a63:7a43:: with SMTP id j3-v6mr20347565pgn.363.1531179726435; Mon, 09 Jul 2018 16:42:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531179726; cv=none; d=google.com; s=arc-20160816; b=XVtiwV4ZYxDlUiY8qCcQIOLiFVxbIqcQsWfHAwQH/KnSl0hIjMSTcsv99xwl5TllMy YwgXTrOA58cHLHFOIk8xgsTBSlO/bgWVgIzjupAUHcBG97OQRx8J9hlnrwkydhFQ6OGP 5uEpWCd6Ma9JEbh6/Rd1q5vSF6kJZQPGHomMP6SG7WB08kgL+TQtu7kDowQoX515AJlL 4HOFiDwPoesjuhrxa+WKS8V4+OdErpQ7q0AP5E7Xj1H1z5Nies/Sypjj5b5sR3Z6n6cM n/7tHDt8q1mgokRLF93yllU7XDSonXSd7lHpgxxwft7W133k85JfJJrD5kRaO7SKopcf Vctw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=F9qL97WIJTDKar0RATFRGa32DomSlp6yFEb0hpSLUU4=; b=xWk4nI6SgaPhn5nAbrSn5bYcBmTozs0mxvA0E3VaHdhxMDq5DEQLgONoOQqJG4xQSY 3kFWU+FVLAyHn3cfbTN0+xWW9XsKzEaHhLn4yviKlBAWqA/J0JQBcNvRthkTtgkTtCYe by7l/tNyaPwMU9PXrNhtu6aop6A7x+olFsT3DxZjwgQojpOouBT7eXl+3P0pSlbf4+EW akYDqTDtr1xyGtXF/NnpIZ6AFkywGQxOBqhO1WdS0SCqycTDdaMgepq9T0O6w0Se1tgM ebGMrkDUo8zE3h5ZhoZBqmZ3tDTvBad8xX2wax0Cxt7lbFOvtbzJ0pRePuY0xqPlnXnP UYjw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=J1Dty9bw; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i7-v6si14951295plt.433.2018.07.09.16.42.06; Mon, 09 Jul 2018 16:42:06 -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=@linaro.org header.s=google header.b=J1Dty9bw; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933308AbeGIXmB (ORCPT + 12 others); Mon, 9 Jul 2018 19:42:01 -0400 Received: from mail-pf0-f195.google.com ([209.85.192.195]:36883 "EHLO mail-pf0-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932828AbeGIXl6 (ORCPT ); Mon, 9 Jul 2018 19:41:58 -0400 Received: by mail-pf0-f195.google.com with SMTP id x10-v6so4877008pfm.4 for ; Mon, 09 Jul 2018 16:41:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=F9qL97WIJTDKar0RATFRGa32DomSlp6yFEb0hpSLUU4=; b=J1Dty9bw2HvCVfptzhJ9j8KLnWlRTwnijOhMp450puPL/2G67C/ERCCXxZPpkxxm+1 LMoIhzNZ27yFwI2P13mSpt5Yq3i5POgS6g/MpBdbeTZFrrYbmxdUb3vP7Aoni52lcTX6 c6Qu7HJFEjPkR8prUqtzb8ve000CgswW3QiH4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=F9qL97WIJTDKar0RATFRGa32DomSlp6yFEb0hpSLUU4=; b=fy3xtajy6Nz3aKrBXz/WozULxHrTeuxHEj4Olfd+1J2gaSO4lVdZLAGAg0dZFDlGik UwqYabiR2gRrvfYuZj5pNhOGn37JB8zgJfWeZ/3mUuYdNewMdsVguZJN7yC3KEDxYC+/ IhESRFu1KczGY5aNCJqAvQT2gl2aKvnZ8gKVWICkLq2spnpPncwXGTObAUtDxlDweoik hCLhFmnhNa+9KQCmBq4nABz/4wDvoDu+IQ4Uk2Y8mVSq/tNRo8owRZzqJWDh1/G7GTq+ QB3LVQqRlso5RBjmtdi0JMwPRwIM/xvktnKznxvTeGdKYdWw3zfVCA3pR2R8F9Anf0ji jo7w== X-Gm-Message-State: APt69E3P2LKwzmNp3LDnhStUb4/SYQAzNQCL3WygSgY77uBGIFdm4unW N2wowZuXw8zTABouAxM4Rkb1BA== X-Received: by 2002:a65:520c:: with SMTP id o12-v6mr20734470pgp.15.1531179717516; Mon, 09 Jul 2018 16:41:57 -0700 (PDT) Received: from linaro.org ([121.95.100.191]) by smtp.googlemail.com with ESMTPSA id p73-v6sm40364523pfa.142.2018.07.09.16.41.56 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 09 Jul 2018 16:41:56 -0700 (PDT) From: AKASHI Takahiro To: catalin.marinas@arm.com, will.deacon@arm.com, ard.biesheuvel@linaro.org Cc: tbaicar@codeaurora.org, bhsharma@redhat.com, dyoung@redhat.com, james.morse@arm.com, mark.rutland@arm.com, al.stone@linaro.org, graeme.gregory@linaro.org, hanjun.guo@linaro.org, lorenzo.pieralisi@arm.com, sudeep.holla@arm.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, kexec@lists.infradead.org Subject: [PATCH v3.1 1/4] arm64: export memblock_reserve()d regions via /proc/iomem Date: Tue, 10 Jul 2018 08:42:26 +0900 Message-Id: <20180709234229.20181-2-takahiro.akashi@linaro.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180709234229.20181-1-takahiro.akashi@linaro.org> References: <20180709234229.20181-1-takahiro.akashi@linaro.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: James Morse There has been some confusion around what is necessary to prevent kexec overwriting important memory regions. memblock: reserve, or nomap? Only memblock nomap regions are reported via /proc/iomem, kexec's user-space doesn't know about memblock_reserve()d regions. Until commit f56ab9a5b73ca ("efi/arm: Don't mark ACPI reclaim memory as MEMBLOCK_NOMAP") the ACPI tables were nomap, now they are reserved and thus possible for kexec to overwrite with the new kernel or initrd. But this was always broken, as the UEFI memory map is also reserved and not marked as nomap. Exporting both nomap and reserved memblock types is a nuisance as they live in different memblock structures which we can't walk at the same time. Take a second walk over memblock.reserved and add new 'reserved' subnodes for the memblock_reserved() regions that aren't already described by the existing code. (e.g. Kernel Code) We use reserve_region_with_split() to find the gaps in existing named regions. This handles the gap between 'kernel code' and 'kernel data' which is memblock_reserve()d, but already partially described by request_standard_resources(). e.g.: | 80000000-dfffffff : System RAM | 80080000-80ffffff : Kernel code | 81000000-8158ffff : reserved | 81590000-8237efff : Kernel data | a0000000-dfffffff : Crash kernel | e00f0000-f949ffff : System RAM reserve_region_with_split needs kzalloc() which isn't available when request_standard_resources() is called, use an initcall. Reported-by: Bhupesh Sharma Reported-by: Tyler Baicar Suggested-by: Akashi Takahiro Signed-off-by: James Morse Fixes: d28f6df1305a ("arm64/kexec: Add core kexec support") Reviewed-by: Ard Biesheuvel CC: Mark Rutland --- arch/arm64/kernel/setup.c | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) -- 2.17.0 diff --git a/arch/arm64/kernel/setup.c b/arch/arm64/kernel/setup.c index 30ad2f085d1f..5b4fac434c84 100644 --- a/arch/arm64/kernel/setup.c +++ b/arch/arm64/kernel/setup.c @@ -241,6 +241,44 @@ static void __init request_standard_resources(void) } } +static int __init reserve_memblock_reserved_regions(void) +{ + phys_addr_t start, end, roundup_end = 0; + struct resource *mem, *res; + u64 i; + + for_each_reserved_mem_region(i, &start, &end) { + if (end <= roundup_end) + continue; /* done already */ + + start = __pfn_to_phys(PFN_DOWN(start)); + end = __pfn_to_phys(PFN_UP(end)) - 1; + roundup_end = end; + + res = kzalloc(sizeof(*res), GFP_ATOMIC); + if (WARN_ON(!res)) + return -ENOMEM; + res->start = start; + res->end = end; + res->name = "reserved"; + res->flags = IORESOURCE_MEM; + + mem = request_resource_conflict(&iomem_resource, res); + /* + * We expected memblock_reserve() regions to conflict with + * memory created by request_standard_resources(). + */ + if (WARN_ON_ONCE(!mem)) + continue; + kfree(res); + + reserve_region_with_split(mem, start, end, "reserved"); + } + + return 0; +} +arch_initcall(reserve_memblock_reserved_regions); + u64 __cpu_logical_map[NR_CPUS] = { [0 ... NR_CPUS-1] = INVALID_HWID }; void __init setup_arch(char **cmdline_p)