|
|
@@ -778,11 +778,11 @@ static int initialized = 0; |
|
|
|
void gotoblas_affinity_init(void) { |
|
|
|
|
|
|
|
int cpu, num_avail; |
|
|
|
#ifndef USE_OPENMP |
|
|
|
#ifndef USE_OPENMP |
|
|
|
cpu_set_t cpu_mask; |
|
|
|
#endif |
|
|
|
int i; |
|
|
|
|
|
|
|
|
|
|
|
if (initialized) return; |
|
|
|
|
|
|
|
initialized = 1; |
|
|
@@ -826,54 +826,15 @@ void gotoblas_affinity_init(void) { |
|
|
|
common -> shmid = pshmid; |
|
|
|
|
|
|
|
if (common -> magic != SH_MAGIC) { |
|
|
|
cpu_set_t *cpusetp; |
|
|
|
int nums; |
|
|
|
int ret; |
|
|
|
|
|
|
|
#ifdef DEBUG |
|
|
|
fprintf(stderr, "Shared Memory Initialization.\n"); |
|
|
|
#endif |
|
|
|
|
|
|
|
//returns the number of processors which are currently online |
|
|
|
|
|
|
|
nums = sysconf(_SC_NPROCESSORS_CONF); |
|
|
|
|
|
|
|
#if !defined(__GLIBC_PREREQ) || !__GLIBC_PREREQ(2, 3) |
|
|
|
common->num_procs = nums; |
|
|
|
#elif __GLIBC_PREREQ(2, 7) |
|
|
|
cpusetp = CPU_ALLOC(nums); |
|
|
|
if (cpusetp == NULL) { |
|
|
|
common->num_procs = nums; |
|
|
|
} else { |
|
|
|
size_t size; |
|
|
|
size = CPU_ALLOC_SIZE(nums); |
|
|
|
ret = sched_getaffinity(0,size,cpusetp); |
|
|
|
if (ret!=0) |
|
|
|
common->num_procs = nums; |
|
|
|
else |
|
|
|
common->num_procs = CPU_COUNT_S(size,cpusetp); |
|
|
|
} |
|
|
|
CPU_FREE(cpusetp); |
|
|
|
#else |
|
|
|
ret = sched_getaffinity(0,sizeof(cpu_set_t), cpusetp); |
|
|
|
if (ret!=0) { |
|
|
|
common->num_procs = nums; |
|
|
|
} else { |
|
|
|
#if !__GLIBC_PREREQ(2, 6) |
|
|
|
int i; |
|
|
|
int n = 0; |
|
|
|
for (i=0;i<nums;i++) |
|
|
|
if (CPU_ISSET(i,cpusetp)) n++; |
|
|
|
common->num_procs = n; |
|
|
|
} |
|
|
|
#else |
|
|
|
common->num_procs = CPU_COUNT(sizeof(cpu_set_t),cpusetp); |
|
|
|
#endif |
|
|
|
|
|
|
|
#endif |
|
|
|
common -> num_procs = sysconf(_SC_NPROCESSORS_CONF);; |
|
|
|
|
|
|
|
if(common -> num_procs > MAX_CPUS) { |
|
|
|
fprintf(stderr, "\nOpenBLAS Warning : The number of CPU/Cores(%d) is beyond the limit(%d). Terminated.\n", common->num_procs, MAX_CPUS); |
|
|
|
fprintf(stderr, "\nOpenBLAS Warining : The number of CPU/Cores(%d) is beyond the limit(%d). Terminated.\n", common->num_procs, MAX_CPUS); |
|
|
|
exit(1); |
|
|
|
} |
|
|
|
|
|
|
@@ -886,7 +847,7 @@ void gotoblas_affinity_init(void) { |
|
|
|
if (common -> num_nodes > 1) numa_mapping(); |
|
|
|
|
|
|
|
common -> final_num_procs = 0; |
|
|
|
for(i = 0; i < common -> avail_count; i++) common -> final_num_procs += rcount(common -> avail[i]) + 1; //Make the max cpu number. |
|
|
|
for(i = 0; i < common -> avail_count; i++) common -> final_num_procs += rcount(common -> avail[i]) + 1; //Make the max cpu number. |
|
|
|
|
|
|
|
for (cpu = 0; cpu < common -> final_num_procs; cpu ++) common -> cpu_use[cpu] = 0; |
|
|
|
|
|
|
|