Re: [PATCH] crash_dump: export is_kdump_kernel to modules,consolidate elfcorehdr_addr, setup_elfcorehdr and saved_max_pfn

From: Andrew Morton
Date: Wed Jan 26 2011 - 19:04:44 EST


On Tue, 25 Jan 2011 17:10:52 +0100
Olaf Hering <olaf@xxxxxxxxx> wrote:

>
> The Xen PV drivers in a crashed HVM guest can not connect to the dom0
> backend drivers because both frontend and backend drivers are still in
> connected state. To run the connection reset function only in case of a
> crashdump, the is_kdump_kernel() function needs to be available for the
> PV driver modules.
>
> Consolidate elfcorehdr_addr, setup_elfcorehdr and saved_max_pfn into
> kernel/crash_dump.c Also export elfcorehdr_addr to make
> is_kdump_kernel() usable for modules.
>
> Leave 'elfcorehdr' as early_param(). This changes powerpc from
> __setup() to early_param(). It adds an address range check from x86
> also on ia64 and powerpc.
>
> Signed-off-by: Olaf Hering <olaf@xxxxxxxxx>
>
> ---
> arch/arm/kernel/crash_dump.c | 3 ---
> arch/arm/kernel/setup.c | 24 ------------------------
> arch/ia64/kernel/crash_dump.c | 3 ---
> arch/ia64/kernel/efi.c | 1 +
> arch/ia64/kernel/setup.c | 18 ------------------
> arch/powerpc/kernel/crash_dump.c | 17 -----------------
> arch/sh/kernel/crash_dump.c | 22 ----------------------
> arch/x86/kernel/crash_dump_32.c | 3 ---
> arch/x86/kernel/crash_dump_64.c | 3 ---
> arch/x86/kernel/e820.c | 1 +
> arch/x86/kernel/setup.c | 22 ----------------------
> include/linux/bootmem.h | 4 ----
> kernel/Makefile | 1 +
> kernel/crash_dump.c | 33 +++++++++++++++++++++++++++++++++
> mm/bootmem.c | 8 --------
> 15 files changed, 36 insertions(+), 127 deletions(-)

That was a decent cleanup.

>
> ...
>
> --- /dev/null
> +++ linux-2.6.38.rc/kernel/crash_dump.c
> @@ -0,0 +1,33 @@
> +#include <linux/crash_dump.h>
> +#include <linux/init.h>
> +#include <linux/module.h>
> +
> +/*
> + * If we have booted due to a crash, max_pfn will be a very low value. We need
> + * to know the amount of memory that the previous kernel used.
> + */
> +unsigned long saved_max_pfn;
> +
> +/*
> + * stores the physical address of elf header of crash image
> + *
> + * Note: elfcorehdr_addr is not just limited to vmcore. It is also used by
> + * is_kdump_kernel() to determine if we are booting after a panic. Hence put
> + * it under CONFIG_CRASH_DUMP and not CONFIG_PROC_VMCORE.
> + */
> +unsigned long long elfcorehdr_addr = ELFCORE_ADDR_MAX;
> +EXPORT_SYMBOL_GPL(elfcorehdr_addr);
> +
> +/*
> + * elfcorehdr= specifies the location of elf core header stored by the crashed
> + * kernel. This option will be passed by kexec loader to the capture kernel.
> + */
> +static int __init setup_elfcorehdr(char *arg)
> +{
> + char *end;
> + if (!arg)
> + return -EINVAL;
> + elfcorehdr_addr = memparse(arg, &end);
> + return end > arg ? 0 : -EINVAL;
> +}
> +early_param("elfcorehdr", setup_elfcorehdr);

Please check that this file is #including everything it needs. Just
looking at it I'd expect a build error with CONFIG_KEXEC=n,
CONFIG_CRASH_DUMP=y due to a missed ELFCORE_ADDR_MAX definition.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/