[PATCH] perf tools: Work around lack of sched_getcpu in glibc < 2.6.

From: Vinson Lee
Date: Fri Feb 13 2015 - 21:07:07 EST


From: Vinson Lee <vlee@xxxxxxxxxxx>

This patch fixes this build error with glibc < 2.6.

CC util/cloexec.o
cc1: warnings being treated as errors
util/cloexec.c: In function âperf_flag_probeâ:
util/cloexec.c:24: error: implicit declaration of function
âsched_getcpuâ
util/cloexec.c:24: error: nested extern declaration of âsched_getcpuâ
make: *** [util/cloexec.o] Error 1

Cc: stable@xxxxxxxxxxxxxxx # 3.18+
Signed-off-by: Vinson Lee <vlee@xxxxxxxxxxx>
---
tools/perf/util/cloexec.c | 10 ++++++++++
1 file changed, 10 insertions(+)

diff --git a/tools/perf/util/cloexec.c b/tools/perf/util/cloexec.c
index 47b78b3..3738924 100644
--- a/tools/perf/util/cloexec.c
+++ b/tools/perf/util/cloexec.c
@@ -7,6 +7,12 @@

static unsigned long flag = PERF_FLAG_FD_CLOEXEC;

+#ifdef __GLIBC_PREREQ
+#if __GLIBC_PREREQ(2, 6)
+#define HAVE_SCHED_GETCPU
+#endif
+#endif
+
static int perf_flag_probe(void)
{
/* use 'safest' configuration as used in perf_evsel__fallback() */
@@ -21,9 +27,13 @@ static int perf_flag_probe(void)
pid_t pid = -1;
char sbuf[STRERR_BUFSIZE];

+#ifdef HAVE_SCHED_GETCPU
cpu = sched_getcpu();
if (cpu < 0)
cpu = 0;
+#else
+ cpu = 0;
+#endif

while (1) {
/* check cloexec flag */
--
1.8.2.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/