Browse Source

Guard against sysconf returning zero processors

tags/v0.3.21
Martin Kroeker GitHub 3 years ago
parent
commit
69148ae795
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 23 additions and 23 deletions
  1. +23
    -23
      driver/others/memory.c

+ 23
- 23
driver/others/memory.c View File

@@ -252,23 +252,23 @@ int get_num_procs(void) {
ret = omp_get_num_places(); ret = omp_get_num_places();
if (ret >0 ) nums = ret; if (ret >0 ) nums = ret;
#endif #endif
return nums;
return (nums > 0 ? nums : 2);
#endif #endif


#if !defined(OS_LINUX) #if !defined(OS_LINUX)
return nums;
return (nums > 0 ? nums : 2);
#endif #endif


#if !defined(__GLIBC_PREREQ) #if !defined(__GLIBC_PREREQ)
return nums;
return (nums > 0 ? nums :2);
#else #else
#if !__GLIBC_PREREQ(2, 3) #if !__GLIBC_PREREQ(2, 3)
return nums;
return (nums > 0 ? nums :2);
#endif #endif


#if !__GLIBC_PREREQ(2, 7) #if !__GLIBC_PREREQ(2, 7)
ret = sched_getaffinity(0,sizeof(cpuset), &cpuset); ret = sched_getaffinity(0,sizeof(cpuset), &cpuset);
if (ret!=0) return nums;
if (ret!=0) return (nums > 0 ? nums :2);
n=0; n=0;
#if !__GLIBC_PREREQ(2, 6) #if !__GLIBC_PREREQ(2, 6)
for (i=0;i<nums;i++) for (i=0;i<nums;i++)
@@ -277,31 +277,31 @@ int get_num_procs(void) {
#else #else
nums = CPU_COUNT(sizeof(cpuset),&cpuset); nums = CPU_COUNT(sizeof(cpuset),&cpuset);
#endif #endif
return nums;
return (nums > 0 ? nums :2);
#else #else
if (nums >= CPU_SETSIZE) { if (nums >= CPU_SETSIZE) {
cpusetp = CPU_ALLOC(nums); cpusetp = CPU_ALLOC(nums);
if (cpusetp == NULL) { if (cpusetp == NULL) {
return nums;
return (nums > 0 ? nums :2);
} }
size = CPU_ALLOC_SIZE(nums); size = CPU_ALLOC_SIZE(nums);
ret = sched_getaffinity(0,size,cpusetp); ret = sched_getaffinity(0,size,cpusetp);
if (ret!=0) { if (ret!=0) {
CPU_FREE(cpusetp); CPU_FREE(cpusetp);
return nums;
return (nums > 0 ? nums :2);
} }
ret = CPU_COUNT_S(size,cpusetp); ret = CPU_COUNT_S(size,cpusetp);
if (ret > 0 && ret < nums) nums = ret; if (ret > 0 && ret < nums) nums = ret;
CPU_FREE(cpusetp); CPU_FREE(cpusetp);
return nums;
return (nums > 0 ? nums :2);
} else { } else {
ret = sched_getaffinity(0,sizeof(cpuset),&cpuset); ret = sched_getaffinity(0,sizeof(cpuset),&cpuset);
if (ret!=0) { if (ret!=0) {
return nums;
return (nums > 0 ? nums :2);
} }
ret = CPU_COUNT(&cpuset); ret = CPU_COUNT(&cpuset);
if (ret > 0 && ret < nums) nums = ret; if (ret > 0 && ret < nums) nums = ret;
return nums;
return (nums > 0 ? nums :2);
} }
#endif #endif
#endif #endif
@@ -1823,56 +1823,56 @@ int get_num_procs(void) {
ret = omp_get_num_places(); ret = omp_get_num_places();
if (ret >0 ) nums = ret; if (ret >0 ) nums = ret;
#endif #endif
return nums;
return (nums > 0 ? nums :2);
#endif #endif


#if !defined(OS_LINUX) #if !defined(OS_LINUX)
return nums;
return (nums > 0 ? nums :2);
#endif #endif
#if !defined(__GLIBC_PREREQ) #if !defined(__GLIBC_PREREQ)
return nums;
return (nums > 0 ? nums :2);
#else #else
#if !__GLIBC_PREREQ(2, 3) #if !__GLIBC_PREREQ(2, 3)
return nums;
return (nums > 0 ? nums :2);
#endif #endif


#if !__GLIBC_PREREQ(2, 7) #if !__GLIBC_PREREQ(2, 7)
ret = sched_getaffinity(0,sizeof(cpuset), &cpuset); ret = sched_getaffinity(0,sizeof(cpuset), &cpuset);
if (ret!=0) return nums;
if (ret!=0) return (nums > 0 ? nums :2);
n=0; n=0;
#if !__GLIBC_PREREQ(2, 6) #if !__GLIBC_PREREQ(2, 6)
for (i=0;i<nums;i++)
for (i=0;i<(nums > 0 ? nums :2);i++)
if (CPU_ISSET(i,&cpuset)) n++; if (CPU_ISSET(i,&cpuset)) n++;
nums=n; nums=n;
#else #else
nums = CPU_COUNT(sizeof(cpuset),&cpuset); nums = CPU_COUNT(sizeof(cpuset),&cpuset);
#endif #endif
return nums;
return (nums > 0 ? nums :2);
#else #else
if (nums >= CPU_SETSIZE) { if (nums >= CPU_SETSIZE) {
cpusetp = CPU_ALLOC(nums); cpusetp = CPU_ALLOC(nums);
if (cpusetp == NULL) { if (cpusetp == NULL) {
return nums;
return (nums > 0 ? nums :2);
} }
size = CPU_ALLOC_SIZE(nums); size = CPU_ALLOC_SIZE(nums);
ret = sched_getaffinity(0,size,cpusetp); ret = sched_getaffinity(0,size,cpusetp);
if (ret!=0) { if (ret!=0) {
CPU_FREE(cpusetp); CPU_FREE(cpusetp);
return nums;
return (nums > 0 ? nums :2);
} }
ret = CPU_COUNT_S(size,cpusetp); ret = CPU_COUNT_S(size,cpusetp);
if (ret > 0 && ret < nums) nums = ret; if (ret > 0 && ret < nums) nums = ret;
CPU_FREE(cpusetp); CPU_FREE(cpusetp);
return nums;
return (nums > 0 ? nums :2);
} else { } else {
ret = sched_getaffinity(0,sizeof(cpuset),&cpuset); ret = sched_getaffinity(0,sizeof(cpuset),&cpuset);
if (ret!=0) { if (ret!=0) {
return nums;
return (nums > 0 ? nums :2);
} }
ret = CPU_COUNT(&cpuset); ret = CPU_COUNT(&cpuset);
if (ret > 0 && ret < nums) nums = ret; if (ret > 0 && ret < nums) nums = ret;
return nums;
return (nums > 0 ? nums :2);
} }
#endif #endif
#endif #endif


Loading…
Cancel
Save