Re: [PATCH] MIPS: Loongson64: Add WARN_ON on kexec related kmalloc failed

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Nov 03, 2022 at 09:18:15AM +0800, Liao Chang wrote:
> Add WARN_ON on kexec related kmalloc failed, avoid to pass NULL pointer
> to following memcpy and loongson_kexec_prepare.
> 
> Fixes: 6ce48897ce47 ("MIPS: Loongson64: Add kexec/kdump support")
> Signed-off-by: Liao Chang <liaochang1@xxxxxxxxxx>
> ---
>  arch/mips/loongson64/reset.c | 10 ++++++++++
>  1 file changed, 10 insertions(+)
> 
> diff --git a/arch/mips/loongson64/reset.c b/arch/mips/loongson64/reset.c
> index 758d5d26aaaa..e420800043b0 100644
> --- a/arch/mips/loongson64/reset.c
> +++ b/arch/mips/loongson64/reset.c
> @@ -16,6 +16,7 @@
>  #include <asm/bootinfo.h>
>  #include <asm/idle.h>
>  #include <asm/reboot.h>
> +#include <asm/bug.h>
>  
>  #include <loongson.h>
>  #include <boot_param.h>
> @@ -159,8 +160,17 @@ static int __init mips_reboot_setup(void)
>  
>  #ifdef CONFIG_KEXEC
>  	kexec_argv = kmalloc(KEXEC_ARGV_SIZE, GFP_KERNEL);
> +	if (WARN_ON(!kexec_argv))
> +		return -ENOMEM;
> +
>  	kdump_argv = kmalloc(KEXEC_ARGV_SIZE, GFP_KERNEL);
> +	if (WARN_ON(!kdump_argv))
> +		return -ENOMEM;
> +
>  	kexec_envp = kmalloc(KEXEC_ENVP_SIZE, GFP_KERNEL);
> +	if (WARN_ON(!kexec_envp))
> +		return -ENOMEM;
> +
>  	fw_arg1 = KEXEC_ARGV_ADDR;
>  	memcpy(kexec_envp, (void *)fw_arg2, KEXEC_ENVP_SIZE);
>  
> -- 
> 2.17.1

applied to mips-fixes.

Thomas.

-- 
Crap can work. Given enough thrust pigs will fly, but it's not necessarily a
good idea.                                                [ RFC1925, 2.3 ]



[Index of Archives]     [LKML Archive]     [Linux ARM Kernel]     [Linux ARM]     [Git]     [Yosemite News]     [Linux SCSI]     [Linux Hams]

  Powered by Linux