On Tue, 22 Sep 2015 19:48:14 +0800 Baoquan He <b...@redhat.com> wrote:
> People reported that when allocating crashkernel memory using
> ",high" and ",low" syntax, there were cases where the reservation
> of the "high" portion succeeds, but the reservation of the "low"
> portion fails. Then kexec can load kdump kernel successfully, but
> the boot of kdump kernel fails as there's no low memory. This is
> because allocation of low memory for kdump kernel can fail on large
> systems for reasons. E.g it could be manually specified crashkernel
> low memory is too large to find in memblock region.
> 
> In this patch add return value for reserve_crashkernel_low. Then
> try to reserve crashkernel low memory after crashkernel high memory
> has been allocated. If crashkernel low memory reservation failed
> free crashkernel high memory and return. User can take measures
> when they found kdump kernel cann't be loaded successfully.
>
> ...
>
> --- a/arch/x86/kernel/setup.c
> +++ b/arch/x86/kernel/setup.c
> @@ -493,7 +493,7 @@ static void __init 
> memblock_x86_reserve_range_setup_data(void)
>  # define CRASH_KERNEL_ADDR_HIGH_MAX  MAXMEM
>  #endif
>  
> -static void __init reserve_crashkernel_low(void)
> +static int __init reserve_crashkernel_low(void)
>  {
>  #ifdef CONFIG_X86_64
>       const unsigned long long alignment = 16<<20;    /* 16M */
> @@ -522,17 +522,15 @@ static void __init reserve_crashkernel_low(void)
>       } else {
>               /* passed with crashkernel=0,low ? */
>               if (!low_size)
> -                     return;
> +                     return 0;

What's happening here?  It's returning "success" when
parse_crashkernel_low() fails?

>       }
>  
>       low_base = memblock_find_in_range(low_size, (1ULL<<32),
>                                       low_size, alignment);
>  
>       if (!low_base) {
> -             if (!auto_set)
> -                     pr_info("crashkernel low reservation failed - No 
> suitable area found.\n");
> -
> -             return;
> +             pr_info("crashkernel low reservation failed - No suitable area 
> found.\n");

That's not a terribly useful message.  If kdump is now unavailable and
the operator needs to take some remedial action then we should inform
them of this.

Also, such a message should have higher severity than KERN_INFO?

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

Reply via email to