[PATCH] powerpc/pseries: use slab context cpumask allocation in CPU hotplug init

Sachin Sant sachinp at linux.vnet.ibm.com
Sun Nov 7 19:59:06 AEDT 2021



> On 05-Nov-2021, at 6:59 PM, Nicholas Piggin <npiggin at gmail.com> wrote:
> 
> Slab is up at this point, using the bootmem allocator triggers a
> warning. Switch to using the regular cpumask allocator.
> 
> Signed-off-by: Nicholas Piggin <npiggin at gmail.com>
> ---

Fixes the warning for me. Thanks

Tested-by: Sachin Sant <sachinp at linux.vnet.ibm.com>

> 
> This only matters when CONFIG_CPUMASK_OFFNODE=y, which has not been
> possible before on powerpc.
> 
> Thanks,
> Nick
> 
> arch/powerpc/platforms/pseries/hotplug-cpu.c | 9 +++++----
> 1 file changed, 5 insertions(+), 4 deletions(-)
> 
> diff --git a/arch/powerpc/platforms/pseries/hotplug-cpu.c b/arch/powerpc/platforms/pseries/hotplug-cpu.c
> index d646c22e94ab..78a70ba60d24 100644
> --- a/arch/powerpc/platforms/pseries/hotplug-cpu.c
> +++ b/arch/powerpc/platforms/pseries/hotplug-cpu.c
> @@ -1016,12 +1016,13 @@ static int __init pseries_cpu_hotplug_init(void)
> 	/* Processors can be added/removed only on LPAR */
> 	if (firmware_has_feature(FW_FEATURE_LPAR)) {
> 		for_each_node(node) {
> -			alloc_bootmem_cpumask_var(&node_recorded_ids_map[node]);
> +			if (!alloc_cpumask_var_node(&node_recorded_ids_map[node],
> +						    GFP_KERNEL, node))
> +				return -ENOMEM;
> 
> 			/* Record ids of CPU added at boot time */
> -			cpumask_or(node_recorded_ids_map[node],
> -				   node_recorded_ids_map[node],
> -				   cpumask_of_node(node));
> +			cpumask_copy(node_recorded_ids_map[node],
> +				     cpumask_of_node(node));
> 		}
> 
> 		of_reconfig_notifier_register(&pseries_smp_nb);
> -- 
> 2.23.0
> 



More information about the Linuxppc-dev mailing list