diff options
| -rw-r--r-- | kernel/sched/cpupri.c | 7 | ||||
| -rw-r--r-- | kernel/sched/cpupri.h | 2 | 
2 files changed, 8 insertions, 1 deletions
diff --git a/kernel/sched/cpupri.c b/kernel/sched/cpupri.c index 3031bac8aa3e..8834243abee2 100644 --- a/kernel/sched/cpupri.c +++ b/kernel/sched/cpupri.c @@ -30,6 +30,7 @@  #include <linux/gfp.h>  #include <linux/sched.h>  #include <linux/sched/rt.h> +#include <linux/slab.h>  #include "cpupri.h"  /* Convert between a 140 based task->prio, and our 102 based cpupri */ @@ -218,8 +219,13 @@ int cpupri_init(struct cpupri *cp)  			goto cleanup;  	} +	cp->cpu_to_pri = kcalloc(nr_cpu_ids, sizeof(int), GFP_KERNEL); +	if (!cp->cpu_to_pri) +		goto cleanup; +  	for_each_possible_cpu(i)  		cp->cpu_to_pri[i] = CPUPRI_INVALID; +  	return 0;  cleanup: @@ -236,6 +242,7 @@ void cpupri_cleanup(struct cpupri *cp)  {  	int i; +	kfree(cp->cpu_to_pri);  	for (i = 0; i < CPUPRI_NR_PRIORITIES; i++)  		free_cpumask_var(cp->pri_to_cpu[i].mask);  } diff --git a/kernel/sched/cpupri.h b/kernel/sched/cpupri.h index f6d756173491..6b033347fdfd 100644 --- a/kernel/sched/cpupri.h +++ b/kernel/sched/cpupri.h @@ -17,7 +17,7 @@ struct cpupri_vec {  struct cpupri {  	struct cpupri_vec pri_to_cpu[CPUPRI_NR_PRIORITIES]; -	int               cpu_to_pri[NR_CPUS]; +	int *cpu_to_pri;  };  #ifdef CONFIG_SMP  | 

