mirror of
https://github.com/citra-emu/citra-canary.git
synced 2025-01-05 13:05:26 +00:00
Merge pull request #4245 from wwylele/thread-cleanup
Common/Thread cleanup
This commit is contained in:
commit
ded7e1f7c3
|
@ -11,25 +11,6 @@
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include "common/common_types.h"
|
#include "common/common_types.h"
|
||||||
|
|
||||||
// Support for C++11's thread_local keyword was surprisingly spotty in compilers until very
|
|
||||||
// recently. Fortunately, thread local variables have been well supported for compilers for a while,
|
|
||||||
// but with semantics supporting only POD types, so we can use a few defines to get some amount of
|
|
||||||
// backwards compat support.
|
|
||||||
// WARNING: This only works correctly with POD types.
|
|
||||||
#if defined(__clang__)
|
|
||||||
#if !__has_feature(cxx_thread_local)
|
|
||||||
#define thread_local __thread
|
|
||||||
#endif
|
|
||||||
#elif defined(__GNUC__)
|
|
||||||
#if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 8)
|
|
||||||
#define thread_local __thread
|
|
||||||
#endif
|
|
||||||
#elif defined(_MSC_VER)
|
|
||||||
#if _MSC_VER < 1900
|
|
||||||
#define thread_local __declspec(thread)
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace Common {
|
namespace Common {
|
||||||
|
|
||||||
int CurrentThreadId();
|
int CurrentThreadId();
|
||||||
|
@ -115,14 +96,6 @@ private:
|
||||||
|
|
||||||
void SleepCurrentThread(int ms);
|
void SleepCurrentThread(int ms);
|
||||||
void SwitchCurrentThread(); // On Linux, this is equal to sleep 1ms
|
void SwitchCurrentThread(); // On Linux, this is equal to sleep 1ms
|
||||||
|
|
||||||
// Use this function during a spin-wait to make the current thread
|
|
||||||
// relax while another thread is working. This may be more efficient
|
|
||||||
// than using events because event functions use kernel calls.
|
|
||||||
inline void YieldCPU() {
|
|
||||||
std::this_thread::yield();
|
|
||||||
}
|
|
||||||
|
|
||||||
void SetCurrentThreadName(const char* name);
|
void SetCurrentThreadName(const char* name);
|
||||||
|
|
||||||
} // namespace Common
|
} // namespace Common
|
||||||
|
|
Loading…
Reference in a new issue