diff mbox series

riscv: Use kvmalloc_array on relocation_hashtable

Message ID 20250402053408.14052-1-wgpierce17@gmail.com (mailing list archive)
State Superseded
Headers show
Series riscv: Use kvmalloc_array on relocation_hashtable | expand

Checks

Context Check Description
bjorn/pre-ci_am success Success
bjorn/build-rv32-defconfig success build-rv32-defconfig
bjorn/build-rv64-clang-allmodconfig success build-rv64-clang-allmodconfig
bjorn/build-rv64-gcc-allmodconfig success build-rv64-gcc-allmodconfig
bjorn/build-rv64-nommu-k210-defconfig success build-rv64-nommu-k210-defconfig
bjorn/build-rv64-nommu-k210-virt success build-rv64-nommu-k210-virt
bjorn/checkpatch warning checkpatch
bjorn/dtb-warn-rv64 success dtb-warn-rv64
bjorn/header-inline success header-inline
bjorn/kdoc success kdoc
bjorn/module-param success module-param
bjorn/verify-fixes success verify-fixes
bjorn/verify-signedoff success verify-signedoff

Commit Message

William Pierce April 2, 2025, 5:34 a.m. UTC
From: Will Pierce <wgpierce17@gmail.com>

The number of relocations may be a huge value that is unallocatable
by kmalloc. Use kvmalloc instead so that it does not fail.

Signed-off-by: Will Pierce <wgpierce17@gmail.com>
---
 arch/riscv/kernel/module.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

Comments

Alexandre Ghiti April 2, 2025, 6:56 a.m. UTC | #1
Hi Will,

On 02/04/2025 07:34, wgpierce17@gmail.com wrote:
> From: Will Pierce <wgpierce17@gmail.com>
>
> The number of relocations may be a huge value that is unallocatable
> by kmalloc. Use kvmalloc instead so that it does not fail.
>
> Signed-off-by: Will Pierce <wgpierce17@gmail.com>
> ---
>   arch/riscv/kernel/module.c | 5 +++--
>   1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/arch/riscv/kernel/module.c b/arch/riscv/kernel/module.c
> index 47d0ebeec93c..bae3db50647c 100644
> --- a/arch/riscv/kernel/module.c
> +++ b/arch/riscv/kernel/module.c
> @@ -648,7 +648,7 @@ process_accumulated_relocations(struct module *me,
>   		kfree(bucket_iter);
>   	}
>   
> -	kfree(*relocation_hashtable);
> +	kvfree(*relocation_hashtable);
>   }
>   
>   static int add_relocation_to_accumulate(struct module *me, int type,
> @@ -752,7 +752,8 @@ initialize_relocation_hashtable(unsigned int num_relocations,
>   
>   	hashtable_size <<= should_double_size;
>   
> -	*relocation_hashtable = kmalloc_array(hashtable_size,
> +	/* Number of relocations may be large, so kvmalloc it */
> +	*relocation_hashtable = kvmalloc_array(hashtable_size,
>   					      sizeof(**relocation_hashtable),
>   					      GFP_KERNEL);
>   	if (!*relocation_hashtable)


Let's add a fixes tag:

Fixes: 8fd6c5142395 ("riscv: Add remaining module relocations")

Since Clément suggested this solution:

Suggested-by: Clément Léger <cleger@rivosinc.com>

And finally, this looks good to me so:

Reviewed-by: Alexandre Ghiti <alexghiti@rivosinc.com>

It's a bit late for rc1 so I'll take this one for a next rc.

Thanks for the patch!

Alex
William Pierce April 2, 2025, 8:12 a.m. UTC | #2
Hi Alexandre,

On 4/1/25 11:56 PM, Alexandre Ghiti wrote:
> Hi Will,
> 
> On 02/04/2025 07:34, wgpierce17@gmail.com wrote:
>> From: Will Pierce <wgpierce17@gmail.com>
>>
>> The number of relocations may be a huge value that is unallocatable
>> by kmalloc. Use kvmalloc instead so that it does not fail.
>>
>> Signed-off-by: Will Pierce <wgpierce17@gmail.com>
>> ---
>>   arch/riscv/kernel/module.c | 5 +++--
>>   1 file changed, 3 insertions(+), 2 deletions(-)
>>
>> diff --git a/arch/riscv/kernel/module.c b/arch/riscv/kernel/module.c
>> index 47d0ebeec93c..bae3db50647c 100644
>> --- a/arch/riscv/kernel/module.c
>> +++ b/arch/riscv/kernel/module.c
>> @@ -648,7 +648,7 @@ process_accumulated_relocations(struct module *me,
>>           kfree(bucket_iter);
>>       }
>>   -    kfree(*relocation_hashtable);
>> +    kvfree(*relocation_hashtable);
>>   }
>>     static int add_relocation_to_accumulate(struct module *me, int type,
>> @@ -752,7 +752,8 @@ initialize_relocation_hashtable(unsigned int num_relocations,
>>         hashtable_size <<= should_double_size;
>>   -    *relocation_hashtable = kmalloc_array(hashtable_size,
>> +    /* Number of relocations may be large, so kvmalloc it */
>> +    *relocation_hashtable = kvmalloc_array(hashtable_size,
>>                             sizeof(**relocation_hashtable),
>>                             GFP_KERNEL);
>>       if (!*relocation_hashtable)
> 
> 
> Let's add a fixes tag:
> 
> Fixes: 8fd6c5142395 ("riscv: Add remaining module relocations")
> 
> Since Clément suggested this solution:
> 
> Suggested-by: Clément Léger <cleger@rivosinc.com>
> 
> And finally, this looks good to me so:
> 
> Reviewed-by: Alexandre Ghiti <alexghiti@rivosinc.com>
> 
> It's a bit late for rc1 so I'll take this one for a next rc.
> 
> Thanks for the patch!
> 
> Alex
> 
> 

Thank you for checking. I will send a v2 with these additions and
a minor whitespace fix right now.

- Will
diff mbox series

Patch

diff --git a/arch/riscv/kernel/module.c b/arch/riscv/kernel/module.c
index 47d0ebeec93c..bae3db50647c 100644
--- a/arch/riscv/kernel/module.c
+++ b/arch/riscv/kernel/module.c
@@ -648,7 +648,7 @@  process_accumulated_relocations(struct module *me,
 		kfree(bucket_iter);
 	}
 
-	kfree(*relocation_hashtable);
+	kvfree(*relocation_hashtable);
 }
 
 static int add_relocation_to_accumulate(struct module *me, int type,
@@ -752,7 +752,8 @@  initialize_relocation_hashtable(unsigned int num_relocations,
 
 	hashtable_size <<= should_double_size;
 
-	*relocation_hashtable = kmalloc_array(hashtable_size,
+	/* Number of relocations may be large, so kvmalloc it */
+	*relocation_hashtable = kvmalloc_array(hashtable_size,
 					      sizeof(**relocation_hashtable),
 					      GFP_KERNEL);
 	if (!*relocation_hashtable)