libstdc++: Fix __thread_relax for non-gthreads non-x86 targets
My recent change to the preprocessor conditions in __thread_relax() was supposed to also change the __gthread_yield() call to __thread_yield(), which has the right preprocessor checks. Instead I just removed the check for _GLIBCXX_USE_SCHED_YIELD which means the __gthread_yield() call will be ill-formed for non-gthreads targets, and targets without sched_yield(). This fixes it properly. libstdc++-v3/ChangeLog: * include/bits/atomic_wait.h (__thread_relax()): Call __thread_yield() not __gthread_yield().
This commit is contained in:
parent
f600f271b1
commit
9d449189ee
@ -217,7 +217,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
__thread_yield() noexcept
|
||||
{
|
||||
#if defined _GLIBCXX_HAS_GTHREADS && defined _GLIBCXX_USE_SCHED_YIELD
|
||||
__gthread_yield();
|
||||
__gthread_yield();
|
||||
#endif
|
||||
}
|
||||
|
||||
@ -227,7 +227,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
#if defined __i386__ || defined __x86_64__
|
||||
__builtin_ia32_pause();
|
||||
#else
|
||||
__gthread_yield();
|
||||
__thread_yield();
|
||||
#endif
|
||||
}
|
||||
} // namespace __detail
|
||||
|
Loading…
Reference in New Issue
Block a user