mcexec: limit nr. of threads for non-OpenMP partitioned execution

This commit is contained in:
Balazs Gerofi
2017-09-21 15:30:37 +09:00
parent 973d8ddd2c
commit 203bfc2492

View File

@ -2158,7 +2158,20 @@ int main(int argc, char **argv)
n_threads = atoi(getenv("OMP_NUM_THREADS")) + 4;
}
else {
n_threads = ncpu;
/*
* When running with partitioned execution, do not allow
* more threads then the corresponding number of CPUs.
*/
if (nr_processes > 0) {
n_threads = (ncpu / nr_processes) + 4;
if (n_threads == 0) {
n_threads = 2;
}
}
else {
n_threads = ncpu;
}
}
/*