Browse Source

Merge pull request #2117 from martin-frbg/issue2114

Fix errors in cpu affinity setup with glibc 2.6
tags/v0.3.7
Martin Kroeker GitHub 6 years ago
parent
commit
5cabda79d0
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 10 additions and 3 deletions
  1. +10
    -3
      driver/others/init.c

+ 10
- 3
driver/others/init.c View File

@@ -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…
Cancel
Save