Merge pull request #2117 from martin-frbg/issue2114
Fix errors in cpu affinity setup with glibc 2.6
This commit is contained in:
commit
5cabda79d0
|
@ -857,7 +857,14 @@ void gotoblas_affinity_init(void) {
|
||||||
common -> shmid = pshmid;
|
common -> shmid = pshmid;
|
||||||
|
|
||||||
if (common -> magic != SH_MAGIC) {
|
if (common -> magic != SH_MAGIC) {
|
||||||
|
|
||||||
|
#if defined(__GLIBC_PREREQ)
|
||||||
|
#if __GLIBC_PREREQ(2, 7)
|
||||||
cpu_set_t *cpusetp;
|
cpu_set_t *cpusetp;
|
||||||
|
#else
|
||||||
|
cpu_set_t cpuset;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
int nums;
|
int nums;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -890,7 +897,7 @@ void gotoblas_affinity_init(void) {
|
||||||
}
|
}
|
||||||
CPU_FREE(cpusetp);
|
CPU_FREE(cpusetp);
|
||||||
#else
|
#else
|
||||||
ret = sched_getaffinity(0,sizeof(cpu_set_t), cpusetp);
|
ret = sched_getaffinity(0,sizeof(cpu_set_t), &cpuset);
|
||||||
if (ret!=0) {
|
if (ret!=0) {
|
||||||
common->num_procs = nums;
|
common->num_procs = nums;
|
||||||
} else {
|
} else {
|
||||||
|
@ -898,11 +905,11 @@ void gotoblas_affinity_init(void) {
|
||||||
int i;
|
int i;
|
||||||
int n = 0;
|
int n = 0;
|
||||||
for (i=0;i<nums;i++)
|
for (i=0;i<nums;i++)
|
||||||
if (CPU_ISSET(i,cpusetp)) n++;
|
if (CPU_ISSET(i,&cpuset)) n++;
|
||||||
common->num_procs = n;
|
common->num_procs = n;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
common->num_procs = CPU_COUNT(sizeof(cpu_set_t),cpusetp);
|
common->num_procs = CPU_COUNT(&cpuset);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue