Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2407760pxb; Sat, 30 Jan 2021 01:29:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJyfMXJ8uKTTg2IC+G2tlRVIlqa0oeBa6PqyTjdR4bx72sfBCO+/1zOGhjsrPbMNOnWvtjsc X-Received: by 2002:a17:906:ad86:: with SMTP id la6mr8211103ejb.47.1611998972279; Sat, 30 Jan 2021 01:29:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611998972; cv=none; d=google.com; s=arc-20160816; b=ojUSR9NvNGqAO+Zol9MefHXoRdXdSDfrTEOnfr9OltHwAzIfd7X9IvwprJ6FcanY2s XqrtgIB8Okn5oSQHmumMLgWxFEpNf27j0I7vqYXw1c05ZYJ0KCgXlHtIBqHgzprT9sbg p1iSHR5tvKCRN9JP/7XayhS4Ii6CGYqOvS+YMLlDoKynnrJrs4JVsILpfAwRV/OdbYJW Ysu9UwFkf2wp9K3GgJMjEO0x/6tGezuXDEU+hkJfFTbZXnt9RRSX/8rWWBWbJD1fE8hx PyMxabTOZ+W+I8GhDeNGKv4qrxLqo5/RANqwMdRtC4wLbb4qjtKDdrr/EUuzgyGWFhR2 crmA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=MrEOtSY9aYBw7wWp2b2yLRlOXQW4snSqg450e3Z0pyo=; b=FyHq8MqdSP71Tv2F+8332CyfCHSandjdqptYZyQ6watMJV+4yNYtHZnWYlo/N3E8Sd r5gyWJfydY5Gbrr/qBNfj8SdkV/4BcfpUAhcZNQGDxMfzNctdCKsDzOwzmmhukoIuIA8 mP6g9ZR0oDHyrbymKdhspYCwSyK1x1nXJ5CTrwzv2WuYKxf2zaCLsO+DICG14lxKKZ3D jf3qzi26AqE8DVXeWAY5e4poyT4UB7NFDDglvo1yKLWqOAi1VGkXb1bDHZeyybEAPBp8 374ip9sjkVolBnDNr4oslBBW9eXVgch8bHv/F5VbXn4L1t1CdmMPDWQgsAVXGAix5T/x QAfw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a8si6693430edv.386.2021.01.30.01.29.08; Sat, 30 Jan 2021 01:29:32 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231713AbhA3J0V (ORCPT + 99 others); Sat, 30 Jan 2021 04:26:21 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:11992 "EHLO szxga05-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231801AbhA3JXD (ORCPT ); Sat, 30 Jan 2021 04:23:03 -0500 Received: from DGGEMS402-HUB.china.huawei.com (unknown [172.30.72.60]) by szxga05-in.huawei.com (SkyGuard) with ESMTP id 4DSQFX3J9QzjGPt; Sat, 30 Jan 2021 15:05:04 +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.498.0; Sat, 30 Jan 2021 15:06:10 +0800 From: Chen Zhou To: , , , , , , , , , , , CC: , , , , , , , , , , , , Subject: [PATCH v14 09/11] x86, arm64: Add ARCH_WANT_RESERVE_CRASH_KERNEL config Date: Sat, 30 Jan 2021 15:10:23 +0800 Message-ID: <20210130071025.65258-10-chenzhou10@huawei.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210130071025.65258-1-chenzhou10@huawei.com> References: <20210130071025.65258-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 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We make the functions reserve_crashkernel[_low]() as generic for x86 and arm64. Since reserve_crashkernel[_low]() implementations are quite similar on other architectures as well, we can have more users of this later. So have CONFIG_ARCH_WANT_RESERVE_CRASH_KERNEL in arch/Kconfig and select this by X86 and ARM64. Suggested-by: Mike Rapoport Suggested-by: Baoquan He Signed-off-by: Chen Zhou --- arch/Kconfig | 3 +++ arch/arm64/Kconfig | 1 + arch/x86/Kconfig | 2 ++ kernel/crash_core.c | 7 ++----- 4 files changed, 8 insertions(+), 5 deletions(-) diff --git a/arch/Kconfig b/arch/Kconfig index 24862d15f3a3..0ca1ff5bb157 100644 --- a/arch/Kconfig +++ b/arch/Kconfig @@ -24,6 +24,9 @@ config KEXEC_ELF config HAVE_IMA_KEXEC bool +config ARCH_WANT_RESERVE_CRASH_KERNEL + bool + config SET_FS bool diff --git a/arch/arm64/Kconfig b/arch/arm64/Kconfig index f39568b28ec1..09365c7ff469 100644 --- a/arch/arm64/Kconfig +++ b/arch/arm64/Kconfig @@ -82,6 +82,7 @@ config ARM64 select ARCH_WANT_FRAME_POINTERS select ARCH_WANT_HUGE_PMD_SHARE if ARM64_4K_PAGES || (ARM64_16K_PAGES && !ARM64_VA_BITS_36) select ARCH_WANT_LD_ORPHAN_WARN + select ARCH_WANT_RESERVE_CRASH_KERNEL if KEXEC_CORE select ARCH_HAS_UBSAN_SANITIZE_ALL select ARM_AMBA select ARM_ARCH_TIMER diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 21f851179ff0..e6926fcb4a40 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -12,6 +12,7 @@ config X86_32 depends on !64BIT # Options that are inherently 32-bit kernel only: select ARCH_WANT_IPC_PARSE_VERSION + select ARCH_WANT_RESERVE_CRASH_KERNEL if KEXEC_CORE select CLKSRC_I8253 select CLONE_BACKWARDS select GENERIC_VDSO_32 @@ -28,6 +29,7 @@ config X86_64 select ARCH_HAS_GIGANTIC_PAGE select ARCH_SUPPORTS_INT128 if CC_HAS_INT128 select ARCH_USE_CMPXCHG_LOCKREF + select ARCH_WANT_RESERVE_CRASH_KERNEL if KEXEC_CORE select HAVE_ARCH_SOFT_DIRTY select MODULES_USE_ELF_RELA select NEED_DMA_MAP_STATE diff --git a/kernel/crash_core.c b/kernel/crash_core.c index 8479be270c0b..2c5783985db5 100644 --- a/kernel/crash_core.c +++ b/kernel/crash_core.c @@ -320,9 +320,7 @@ int __init parse_crashkernel_low(char *cmdline, * --------- Crashkernel reservation ------------------------------ */ -#ifdef CONFIG_KEXEC_CORE - -#if defined(CONFIG_X86) || defined(CONFIG_ARM64) +#ifdef CONFIG_ARCH_WANT_RESERVE_CRASH_KERNEL static int __init reserve_crashkernel_low(void) { #ifdef CONFIG_64BIT @@ -450,8 +448,7 @@ void __init reserve_crashkernel(void) crashk_res.start = crash_base; crashk_res.end = crash_base + crash_size - 1; } -#endif -#endif /* CONFIG_KEXEC_CORE */ +#endif /* CONFIG_ARCH_WANT_RESERVE_CRASH_KERNEL */ Elf_Word *append_elf_note(Elf_Word *buf, char *name, unsigned int type, void *data, size_t data_len) -- 2.20.1