Commit ed915ad4 authored by David Crawshaw's avatar David Crawshaw

runtime: use sched_yield instead of pthread_yield

Attempt to fix the linux-amd64-clang builder, which broke
with CL 29472.

Turns out pthread_yield is a non-portable Linux function, and
should have #define _GNU_SOURCE before #include <pthread.h>.
GCC doesn't complain about this, but Clang does:

	./raceprof.go:44:3: warning: implicit declaration of function 'pthread_yield' is invalid in C99 [-Wimplicit-function-declaration]

(Though the error, while explicable, certainly could be clearer.)

There is a portable POSIX equivalent, sched_yield, so this
CL uses it instead.

Change-Id: I58ca7a3f73a2b3697712fdb02e72a8027c391169
Reviewed-on: https://go-review.googlesource.com/29675
Run-TryBot: David Crawshaw <crawshaw@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent b444d438
......@@ -15,6 +15,7 @@ package main
#include <signal.h>
#include <stdint.h>
#include <pthread.h>
#include <sched.h>
struct cgoTracebackArg {
uintptr_t context;
......@@ -41,7 +42,7 @@ static void* raceprofThread(void* p) {
for (i = 0; i < 100; i++) {
pthread_kill(pthread_self(), SIGPROF);
pthread_yield();
sched_yield();
}
return 0;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment