Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3715395yba; Tue, 9 Apr 2019 03:18:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqywwG81FlsCLFpAB6YyfKDFBE7IXgAIDunJET45Az3mOOz5lcs2snrfeYWwA/dYM7RqNRt8 X-Received: by 2002:a62:6e05:: with SMTP id j5mr34646687pfc.5.1554805134365; Tue, 09 Apr 2019 03:18:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554805134; cv=none; d=google.com; s=arc-20160816; b=Qx8Sn8fNh7n8EifDyfknBqegf45rBmxnSDdY5/yVRWP0dN9ZNgEGmV1jnH6VXrAm0O xPu6IfaQeqOQw0/bC9E8HAikNP8M6oyV7F16XFlBdffUO1VofJPZC4YXnTIfvNWqNBni 8C2iB2t54Tgz5BtnK4t/qx3rqB+89qmv0DW+DM46rPkgOb6RpkYVyIWLwMLn059EFoTD V9WWcpsJVdVHBTK/jrgNxd2+/K45w1Hlk46F/xzJn0kBbTqZhHa992Jkl49ibCVnv3d/ 3HNSs6Ftr7rNL4Hhkez+hJblS/XLrVODla20/ynEDflm/Fx1opQ5HDFyYcSrf+/sk4Ar bBVg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=BbYjAm+yXyOq6O85Gve2jDCfjYogITxlH3pTVha67WQ=; b=kqrm9QC9Brshz/QegU2V0x0++nTocQlO66x7dEoSXJFx4jvu/Vl3DoInLi9sgTyn5v sBbZdnG7V/x7sqQEaS2spigoAMexW7ecHvkn7quGFaos0DgLkyX3ZgteNaYKkHTtK7uf hoCHfJWTMusQWr8XB7H6TpCDfbMQFFzsczjPkWrHeglvQRD4E9NgYHD49Q65ZkIfdfS9 ys086LP8WQCiPl6aYxMQAm3/M1w8q5HoqpmXdnr7Tntq40kULJXDbN69dZaE2y7rUK+H dxHhTDA6ZvXRtAjaeB07N0VmpqsVZG7LDYuLTwPoCfp8+PdNe5AF5UtDB9wsTy1xGnIK D0CA== 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 c71si24335250pfb.138.2019.04.09.03.18.38; Tue, 09 Apr 2019 03:18:54 -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 S1727179AbfDIKRd (ORCPT + 99 others); Tue, 9 Apr 2019 06:17:33 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:41794 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726765AbfDIKRd (ORCPT ); Tue, 9 Apr 2019 06:17:33 -0400 Received: from DGGEMS402-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 5F1B8B18EC5747D21AA4; Tue, 9 Apr 2019 18:17:31 +0800 (CST) Received: from localhost.localdomain.localdomain (10.175.113.25) by DGGEMS402-HUB.china.huawei.com (10.3.19.202) with Microsoft SMTP Server id 14.3.408.0; Tue, 9 Apr 2019 18:17:24 +0800 From: Chen Zhou To: , , , , , , , , CC: , , , , , , , Chen Zhou Subject: [PATCH v3 2/4] arm64: kdump: support reserving crashkernel above 4G Date: Tue, 9 Apr 2019 18:28:17 +0800 Message-ID: <20190409102819.121335-3-chenzhou10@huawei.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190409102819.121335-1-chenzhou10@huawei.com> References: <20190409102819.121335-1-chenzhou10@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.113.25] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When crashkernel is reserved above 4G in memory, kernel should reserve some amount of low memory for swiotlb and some DMA buffers. Kernel would try to allocate at least 256M below 4G automatically as x86_64 if crashkernel is above 4G. Meanwhile, support crashkernel=X,[high,low] in arm64. Signed-off-by: Chen Zhou --- arch/arm64/include/asm/kexec.h | 3 +++ arch/arm64/kernel/setup.c | 3 +++ arch/arm64/mm/init.c | 26 +++++++++++++++++++++----- 3 files changed, 27 insertions(+), 5 deletions(-) diff --git a/arch/arm64/include/asm/kexec.h b/arch/arm64/include/asm/kexec.h index 67e4cb7..32949bf 100644 --- a/arch/arm64/include/asm/kexec.h +++ b/arch/arm64/include/asm/kexec.h @@ -28,6 +28,9 @@ #define KEXEC_ARCH KEXEC_ARCH_AARCH64 +/* 2M alignment for crash kernel regions */ +#define CRASH_ALIGN SZ_2M + #ifndef __ASSEMBLY__ /** diff --git a/arch/arm64/kernel/setup.c b/arch/arm64/kernel/setup.c index 413d566..82cd9a0 100644 --- a/arch/arm64/kernel/setup.c +++ b/arch/arm64/kernel/setup.c @@ -243,6 +243,9 @@ static void __init request_standard_resources(void) request_resource(res, &kernel_data); #ifdef CONFIG_KEXEC_CORE /* Userspace will find "Crash kernel" region in /proc/iomem. */ + if (crashk_low_res.end && crashk_low_res.start >= res->start && + crashk_low_res.end <= res->end) + request_resource(res, &crashk_low_res); if (crashk_res.end && crashk_res.start >= res->start && crashk_res.end <= res->end) request_resource(res, &crashk_res); diff --git a/arch/arm64/mm/init.c b/arch/arm64/mm/init.c index 972bf43..3bebddf 100644 --- a/arch/arm64/mm/init.c +++ b/arch/arm64/mm/init.c @@ -64,6 +64,7 @@ EXPORT_SYMBOL(memstart_addr); phys_addr_t arm64_dma_phys_limit __ro_after_init; #ifdef CONFIG_KEXEC_CORE + /* * reserve_crashkernel() - reserves memory for crash kernel * @@ -74,20 +75,30 @@ phys_addr_t arm64_dma_phys_limit __ro_after_init; static void __init reserve_crashkernel(void) { unsigned long long crash_base, crash_size; + bool high = false; int ret; ret = parse_crashkernel(boot_command_line, memblock_phys_mem_size(), &crash_size, &crash_base); /* no crashkernel= or invalid value specified */ - if (ret || !crash_size) - return; + if (ret || !crash_size) { + /* crashkernel=X,high */ + ret = parse_crashkernel_high(boot_command_line, + memblock_phys_mem_size(), + &crash_size, &crash_base); + if (ret || !crash_size) + return; + high = true; + } crash_size = PAGE_ALIGN(crash_size); if (crash_base == 0) { /* Current arm64 boot protocol requires 2MB alignment */ - crash_base = memblock_find_in_range(0, ARCH_LOW_ADDRESS_LIMIT, - crash_size, SZ_2M); + crash_base = memblock_find_in_range(0, + high ? memblock_end_of_DRAM() + : ARCH_LOW_ADDRESS_LIMIT, + crash_size, CRASH_ALIGN); if (crash_base == 0) { pr_warn("cannot allocate crashkernel (size:0x%llx)\n", crash_size); @@ -105,13 +116,18 @@ static void __init reserve_crashkernel(void) return; } - if (!IS_ALIGNED(crash_base, SZ_2M)) { + if (!IS_ALIGNED(crash_base, CRASH_ALIGN)) { pr_warn("cannot reserve crashkernel: base address is not 2MB aligned\n"); return; } } memblock_reserve(crash_base, crash_size); + if (crash_base >= SZ_4G && reserve_crashkernel_low()) { + memblock_free(crash_base, crash_size); + return; + } + pr_info("crashkernel reserved: 0x%016llx - 0x%016llx (%lld MB)\n", crash_base, crash_base + crash_size, crash_size >> 20); -- 2.7.4