aboutsummaryrefslogtreecommitdiff
path: root/libgomp
diff options
context:
space:
mode:
Diffstat (limited to 'libgomp')
-rw-r--r--libgomp/ChangeLog10
-rw-r--r--libgomp/config/linux/affinity.c4
-rw-r--r--libgomp/config/linux/proc.c10
-rw-r--r--libgomp/config/linux/proc.h34
4 files changed, 51 insertions, 7 deletions
diff --git a/libgomp/ChangeLog b/libgomp/ChangeLog
index b26dcd5..df3cf60 100644
--- a/libgomp/ChangeLog
+++ b/libgomp/ChangeLog
@@ -1,3 +1,13 @@
+2011-08-03 Uros Bizjak <ubizjak@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.
+
2011-08-02 Jakub Jelinek <jakub@redhat.com>
PR fortran/42041
diff --git a/libgomp/config/linux/affinity.c b/libgomp/config/linux/affinity.c
index d8d57562..8896a6f 100644
--- a/libgomp/config/linux/affinity.c
+++ b/libgomp/config/linux/affinity.c
@@ -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));
diff --git a/libgomp/config/linux/proc.c b/libgomp/config/linux/proc.c
index 01f51df..8d9cfb5 100644
--- a/libgomp/config/linux/proc.c
+++ b/libgomp/config/linux/proc.c
@@ -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;
}
}
diff --git a/libgomp/config/linux/proc.h b/libgomp/config/linux/proc.h
new file mode 100644
index 0000000..f9e3110
--- /dev/null
+++ b/libgomp/config/linux/proc.h
@@ -0,0 +1,34 @@
+/* Copyright (C) 2011 Free Software Foundation, Inc.
+ Contributed by Uros Bizjak <ubizjak@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 */