On Wed, Aug 3, 2011 at 11:11 AM, Jakub Jelinek <ja...@redhat.com> wrote: > On Wed, Aug 03, 2011 at 10:36:47AM +0200, Uros Bizjak wrote: >> We should not call CPU_COUNT when not defined in glibc. > > Oops, forgot that old glibcs don't have it.
> I don't like the prototype in libgomp.h, for one sched.h isn't included > in libgomp.h thus cpu_set_t is not defined type. Plus it isn't a generic > API, but a Linux private function. > So, IMHO either just don't provide any prototype in a header > and put > extern unsigned long gomp_cpuset_popcount (cpu_set_t *); > into config/linux/affinity.c, or introduce > config/linux/proc.h header containing > #include <sched.h> > #ifdef HAVE_PTHREAD_AFFINITY_NP > extern unsigned long gomp_cpuset_popcount (cpu_set_t *); > #endif > and > #include "config/linux/proc.h" > in config/linux/{proc.c,affinity.c}. > Ok with those changes, thanks. Attached is the patch that was committed to SVN. 2011-08-03 Uros Bizjak <ubiz...@gmail.com> * config/linux/proc.h: New. * config/linux/proc.c: Include "proc.h". Do not include <sched.h>. (gomp_cpuset_popcount): Rename from cpuset_popcount. No more static. (gomp_init_num_threads): Update call to cpuset_popcount. (get_num_procs): Ditto. * config/linux/affinity.c (gomp_init_affinity): Call gomp_cpuset_popcount. Tested on x86_64-pc-linux-gnu {,-m32}, committed to mainline SVN. Uros.
Index: config/linux/proc.c =================================================================== --- config/linux/proc.c (revision 177229) +++ config/linux/proc.c (working copy) @@ -30,7 +30,7 @@ #define _GNU_SOURCE 1 #endif #include "libgomp.h" -#include <sched.h> +#include "proc.h" #include <stdlib.h> #include <unistd.h> #ifdef HAVE_GETLOADAVG @@ -40,8 +40,8 @@ #endif #ifdef HAVE_PTHREAD_AFFINITY_NP -static unsigned long -cpuset_popcount (cpu_set_t *cpusetp) +unsigned long +gomp_cpuset_popcount (cpu_set_t *cpusetp) { #ifdef CPU_COUNT /* glibc 2.6 and above provide a macro for this. */ @@ -76,7 +76,7 @@ gomp_init_num_threads (void) if (pthread_getaffinity_np (pthread_self (), sizeof (cpuset), &cpuset) == 0) { /* Count only the CPUs this process can use. */ - gomp_global_icv.nthreads_var = cpuset_popcount (&cpuset); + gomp_global_icv.nthreads_var = gomp_cpuset_popcount (&cpuset); if (gomp_global_icv.nthreads_var == 0) gomp_global_icv.nthreads_var = 1; return; @@ -99,7 +99,7 @@ get_num_procs (void) if (pthread_getaffinity_np (pthread_self (), sizeof (cpuset), &cpuset) == 0) { - int ret = cpuset_popcount (&cpuset); + int ret = gomp_cpuset_popcount (&cpuset); return ret != 0 ? ret : 1; } } Index: config/linux/proc.h =================================================================== --- config/linux/proc.h (revision 0) +++ config/linux/proc.h (revision 0) @@ -0,0 +1,34 @@ +/* Copyright (C) 2011 Free Software Foundation, Inc. + Contributed by Uros Bizjak <ubiz...@gmail.com> + + This file is part of the GNU OpenMP Library (libgomp). + + Libgomp is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3, or (at your option) + any later version. + + Libgomp is distributed in the hope that it will be useful, but WITHOUT ANY + WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + FOR A PARTICULAR PURPOSE. See the GNU General Public License for + more details. + + Under Section 7 of GPL version 3, you are granted additional + permissions described in the GCC Runtime Library Exception, version + 3.1, as published by the Free Software Foundation. + + You should have received a copy of the GNU General Public License and + a copy of the GCC Runtime Library Exception along with this program; + see the files COPYING3 and COPYING.RUNTIME respectively. If not, see + <http://www.gnu.org/licenses/>. */ + +#ifndef GOMP_PROC_H +#define GOMP_PROC_H 1 + +#include <sched.h> + +#ifdef HAVE_PTHREAD_AFFINITY_NP +extern unsigned long gomp_cpuset_popcount (cpu_set_t *); +#endif + +#endif /* GOMP_PROC_H */ Index: config/linux/affinity.c =================================================================== --- config/linux/affinity.c (revision 177229) +++ config/linux/affinity.c (working copy) @@ -29,7 +29,7 @@ #define _GNU_SOURCE 1 #endif #include "libgomp.h" -#include <sched.h> +#include "proc.h" #include <stdlib.h> #include <unistd.h> @@ -56,7 +56,7 @@ gomp_init_affinity (void) CPU_ZERO (&cpusetnew); if (gomp_cpu_affinity_len == 0) { - unsigned long count = CPU_COUNT (&cpuset); + unsigned long count = gomp_cpuset_popcount (&cpuset); if (count >= 65536) count = 65536; gomp_cpu_affinity = malloc (count * sizeof (unsigned short));