// having an undefined compiler function called.
#if defined(__GLIBC__) && !defined(__APPLE__) && !defined(__ANDROID__)
#if __GLIBC_PREREQ(2, 12)
-# define FOLLY_HAS_PTHREAD_SETNAME_NP
+// has pthread_setname_np(pthread_t, const char*) (2 params)
+#define FOLLY_HAS_PTHREAD_SETNAME_NP_THREAD_NAME 1
+#endif
+#endif
+#if defined(__APPLE__) && defined(__MAC_OS_X_VERSION_MIN_REQUIRED)
+#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1060
+// has pthread_setname_np(const char*) (1 param)
+#define FOLLY_HAS_PTHREAD_SETNAME_NP_NAME 1
#endif
#endif
return false;
}
-#ifdef FOLLY_HAS_PTHREAD_SETNAME_NP
+#ifdef FOLLY_HAS_PTHREAD_SETNAME_NP_THREAD_NAME
template <>
inline bool setThreadName(pthread_t id, StringPiece name) {
return 0 == pthread_setname_np(id, name.fbstr().substr(0, 15).c_str());
}
#endif
+#ifdef FOLLY_HAS_PTHREAD_SETNAME_NP_NAME
+template <>
+inline bool setThreadName(pthread_t id, StringPiece name) {
+ // Since OS X 10.6 it is possible for a thread to set its own name,
+ // but not that of some other thread.
+ if (pthread_equal(pthread_self(), id)) {
+ return 0 == pthread_setname_np(name.fbstr().c_str());
+ }
+ return false;
+}
+#endif
+
inline bool setThreadName(StringPiece name) {
return setThreadName(pthread_self(), name);
}
using namespace std;
using namespace folly;
+constexpr bool expectedSetOtherThreadNameResult =
+#ifdef FOLLY_HAS_PTHREAD_SETNAME_NP_THREAD_NAME
+ true
+#else
+ false // This system has no known way to set the name of another thread
+#endif
+ ;
+
+constexpr bool expectedSetSelfThreadNameResult =
+#if defined(FOLLY_HAS_PTHREAD_SETNAME_NP_THREAD_NAME) || \
+ defined(FOLLY_HAS_PTHREAD_SETNAME_NP_NAME)
+ true
+#else
+ false // This system has no known way to set its own thread name
+#endif
+ ;
+
TEST(ThreadName, setThreadName_self) {
thread th([] {
- EXPECT_TRUE(setThreadName("rockin-thread"));
+ EXPECT_EQ(expectedSetSelfThreadNameResult, setThreadName("rockin-thread"));
});
SCOPE_EXIT { th.join(); };
}
SCOPE_EXIT { th.join(); };
handle_set.wait();
SCOPE_EXIT { let_thread_end.post(); };
- EXPECT_TRUE(setThreadName(handle, "rockin-thread"));
+ EXPECT_EQ(
+ expectedSetOtherThreadNameResult, setThreadName(handle, "rockin-thread"));
}
TEST(ThreadName, setThreadName_other_native) {
});
SCOPE_EXIT { th.join(); };
SCOPE_EXIT { let_thread_end.post(); };
- EXPECT_TRUE(setThreadName(th.native_handle(), "rockin-thread"));
+ EXPECT_EQ(
+ expectedSetOtherThreadNameResult,
+ setThreadName(th.native_handle(), "rockin-thread"));
}