Commit dc0d838a authored by Oleg Drokin's avatar Oleg Drokin Committed by Rusty Russell

staging/lustre/ptlrpc: Do not use deprecated cpus_* functions

As per Rusty Russel, cpus_* functions are deprecated.
When mixing cpumask_copy with cpus_weight, they operate on different
sized masks if CPUMASK_OFFSTACK is enabled, causing an
immediate assertion failure.
Copying of cpumasks by assignment is also not allowed now.

Additionally, in ptlrpc/service.c avoid the cpumask copies,
since we only use it to check how many siblings are there for
core #0 and nothing else.
Reported-by: default avatarTyson Whitehead <twhitehead@gmail.com>
Signed-off-by: default avatarOleg Drokin <green@linuxhacker.ru>
Signed-off-by: default avatarRusty Russell <rusty@rustcorp.com.au>
parent 35168f51
...@@ -511,10 +511,10 @@ static int ptlrpcd_bind(int index, int max) ...@@ -511,10 +511,10 @@ static int ptlrpcd_bind(int index, int max)
#if defined(CONFIG_NUMA) #if defined(CONFIG_NUMA)
{ {
int i; int i;
mask = *cpumask_of_node(cpu_to_node(index)); cpumask_copy(&mask, cpumask_of_node(cpu_to_node(index)));
for (i = max; i < num_online_cpus(); i++) for (i = max; i < num_online_cpus(); i++)
cpu_clear(i, mask); cpumask_clear_cpu(i, &mask);
pc->pc_npartners = cpus_weight(mask) - 1; pc->pc_npartners = cpumask_weight(&mask) - 1;
set_bit(LIOD_BIND, &pc->pc_flags); set_bit(LIOD_BIND, &pc->pc_flags);
} }
#else #else
...@@ -554,7 +554,7 @@ static int ptlrpcd_bind(int index, int max) ...@@ -554,7 +554,7 @@ static int ptlrpcd_bind(int index, int max)
* that are already initialized * that are already initialized
*/ */
for (pidx = 0, i = 0; i < index; i++) { for (pidx = 0, i = 0; i < index; i++) {
if (cpu_isset(i, mask)) { if (cpumask_test_cpu(i, &mask)) {
ppc = &ptlrpcds->pd_threads[i]; ppc = &ptlrpcds->pd_threads[i];
pc->pc_partners[pidx++] = ppc; pc->pc_partners[pidx++] = ppc;
ppc->pc_partners[ppc-> ppc->pc_partners[ppc->
......
...@@ -543,7 +543,6 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc, ...@@ -543,7 +543,6 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc,
if (tc->tc_thr_factor != 0) { if (tc->tc_thr_factor != 0) {
int factor = tc->tc_thr_factor; int factor = tc->tc_thr_factor;
const int fade = 4; const int fade = 4;
cpumask_t mask;
/* /*
* User wants to increase number of threads with for * User wants to increase number of threads with for
...@@ -557,8 +556,8 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc, ...@@ -557,8 +556,8 @@ ptlrpc_server_nthreads_check(struct ptlrpc_service *svc,
* have too many threads no matter how many cores/HTs * have too many threads no matter how many cores/HTs
* there are. * there are.
*/ */
cpumask_copy(&mask, topology_thread_cpumask(0)); /* weight is # of HTs */
if (cpus_weight(mask) > 1) { /* weight is # of HTs */ if (cpumask_weight(topology_thread_cpumask(0)) > 1) {
/* depress thread factor for hyper-thread */ /* depress thread factor for hyper-thread */
factor = factor - (factor >> 1) + (factor >> 3); factor = factor - (factor >> 1) + (factor >> 3);
} }
...@@ -2752,7 +2751,6 @@ int ptlrpc_start_thread(struct ptlrpc_service_part *svcpt, int wait) ...@@ -2752,7 +2751,6 @@ int ptlrpc_start_thread(struct ptlrpc_service_part *svcpt, int wait)
int ptlrpc_hr_init(void) int ptlrpc_hr_init(void)
{ {
cpumask_t mask;
struct ptlrpc_hr_partition *hrp; struct ptlrpc_hr_partition *hrp;
struct ptlrpc_hr_thread *hrt; struct ptlrpc_hr_thread *hrt;
int rc; int rc;
...@@ -2770,8 +2768,7 @@ int ptlrpc_hr_init(void) ...@@ -2770,8 +2768,7 @@ int ptlrpc_hr_init(void)
init_waitqueue_head(&ptlrpc_hr.hr_waitq); init_waitqueue_head(&ptlrpc_hr.hr_waitq);
cpumask_copy(&mask, topology_thread_cpumask(0)); weight = cpumask_weight(topology_thread_cpumask(0));
weight = cpus_weight(mask);
cfs_percpt_for_each(hrp, i, ptlrpc_hr.hr_partitions) { cfs_percpt_for_each(hrp, i, ptlrpc_hr.hr_partitions) {
hrp->hrp_cpt = i; hrp->hrp_cpt = i;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment