Yes, that was an oversight. Which platforms was this on?<br><div class="gmail_quote"><div dir="ltr">On Fri, Mar 3, 2017 at 5:54 PM Jim Ingham <<a href="mailto:jingham@apple.com">jingham@apple.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This change seems to have lost the code that would make sure that on platforms with short thread names we pick up the end of the name passed in because that is generally the more specific part. Was that just an oversight?<br class="gmail_msg">
<br class="gmail_msg">
Jim<br class="gmail_msg">
<br class="gmail_msg">
> On Mar 3, 2017, at 5:31 PM, Zachary Turner via lldb-commits <<a href="mailto:lldb-commits@lists.llvm.org" class="gmail_msg" target="_blank">lldb-commits@lists.llvm.org</a>> wrote:<br class="gmail_msg">
><br class="gmail_msg">
> Author: zturner<br class="gmail_msg">
> Date: Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> New Revision: 296946<br class="gmail_msg">
><br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=296946&view=rev" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project?rev=296946&view=rev</a><br class="gmail_msg">
> Log:<br class="gmail_msg">
> Delete LLDB's code for getting / setting thread name.<br class="gmail_msg">
><br class="gmail_msg">
> This is now functionality in LLVM, and all callers have<br class="gmail_msg">
> already been updated to use the LLVM functions.<br class="gmail_msg">
><br class="gmail_msg">
> Removed:<br class="gmail_msg">
> lldb/trunk/include/lldb/Host/ThisThread.h<br class="gmail_msg">
> lldb/trunk/source/Host/common/ThisThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/freebsd/ThisThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/linux/ThisThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/macosx/ThisThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/netbsd/ThisThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/windows/ThisThread.cpp<br class="gmail_msg">
> Modified:<br class="gmail_msg">
> lldb/trunk/include/lldb/Host/Host.h<br class="gmail_msg">
> lldb/trunk/source/Host/CMakeLists.txt<br class="gmail_msg">
> lldb/trunk/source/Host/common/Host.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/common/HostNativeThreadBase.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/common/ThreadLauncher.cpp<br class="gmail_msg">
> lldb/trunk/source/Host/windows/Host.cpp<br class="gmail_msg">
> lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp<br class="gmail_msg">
> lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/include/lldb/Host/Host.h<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/Host.h?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/Host.h?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/include/lldb/Host/Host.h (original)<br class="gmail_msg">
> +++ lldb/trunk/include/lldb/Host/Host.h Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -100,14 +100,6 @@ public:<br class="gmail_msg">
> static void Kill(lldb::pid_t pid, int signo);<br class="gmail_msg">
><br class="gmail_msg">
> //------------------------------------------------------------------<br class="gmail_msg">
> - /// Get the thread ID for the calling thread in the current process.<br class="gmail_msg">
> - ///<br class="gmail_msg">
> - /// @return<br class="gmail_msg">
> - /// The thread ID for the calling thread in the current process.<br class="gmail_msg">
> - //------------------------------------------------------------------<br class="gmail_msg">
> - static lldb::tid_t GetCurrentThreadID();<br class="gmail_msg">
> -<br class="gmail_msg">
> - //------------------------------------------------------------------<br class="gmail_msg">
> /// Get the thread token (the one returned by ThreadCreate when the thread was<br class="gmail_msg">
> /// created) for the<br class="gmail_msg">
> /// calling thread in the current process.<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/include/lldb/Host/ThisThread.h<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/ThisThread.h?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/ThisThread.h?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/include/lldb/Host/ThisThread.h (original)<br class="gmail_msg">
> +++ lldb/trunk/include/lldb/Host/ThisThread.h (removed)<br class="gmail_msg">
> @@ -1,37 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.h --------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#ifndef lldb_Host_ThisThread_h_<br class="gmail_msg">
> -#define lldb_Host_ThisThread_h_<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/StringRef.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include <string><br class="gmail_msg">
> -<br class="gmail_msg">
> -namespace llvm {<br class="gmail_msg">
> -template <class T> class SmallVectorImpl;<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -namespace lldb_private {<br class="gmail_msg">
> -<br class="gmail_msg">
> -class ThisThread {<br class="gmail_msg">
> -private:<br class="gmail_msg">
> - ThisThread();<br class="gmail_msg">
> -<br class="gmail_msg">
> -public:<br class="gmail_msg">
> - // ThisThread common functions.<br class="gmail_msg">
> - static void SetName(llvm::StringRef name, int max_length);<br class="gmail_msg">
> -<br class="gmail_msg">
> - // ThisThread platform-specific functions.<br class="gmail_msg">
> - static void SetName(llvm::StringRef name);<br class="gmail_msg">
> - static void GetName(llvm::SmallVectorImpl<char> &name);<br class="gmail_msg">
> -};<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -#endif<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Host/CMakeLists.txt<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/CMakeLists.txt?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/CMakeLists.txt?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/CMakeLists.txt (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/CMakeLists.txt Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -35,7 +35,6 @@ add_host_subdirectory(common<br class="gmail_msg">
> common/Symbols.cpp<br class="gmail_msg">
> common/TCPSocket.cpp<br class="gmail_msg">
> common/Terminal.cpp<br class="gmail_msg">
> - common/ThisThread.cpp<br class="gmail_msg">
> common/ThreadLauncher.cpp<br class="gmail_msg">
> common/XML.cpp<br class="gmail_msg">
> common/UDPSocket.cpp<br class="gmail_msg">
> @@ -73,7 +72,6 @@ if (CMAKE_SYSTEM_NAME MATCHES "Windows")<br class="gmail_msg">
> windows/PipeWindows.cpp<br class="gmail_msg">
> windows/ProcessLauncherWindows.cpp<br class="gmail_msg">
> windows/ProcessRunLock.cpp<br class="gmail_msg">
> - windows/ThisThread.cpp<br class="gmail_msg">
> windows/Windows.cpp<br class="gmail_msg">
> )<br class="gmail_msg">
> else()<br class="gmail_msg">
> @@ -107,7 +105,6 @@ else()<br class="gmail_msg">
> macosx/HostInfoMacOSX.mm<br class="gmail_msg">
> macosx/HostThreadMacOSX.mm<br class="gmail_msg">
> macosx/Symbols.cpp<br class="gmail_msg">
> - macosx/ThisThread.cpp<br class="gmail_msg">
> macosx/cfcpp/CFCBundle.cpp<br class="gmail_msg">
> macosx/cfcpp/CFCData.cpp<br class="gmail_msg">
> macosx/cfcpp/CFCMutableArray.cpp<br class="gmail_msg">
> @@ -124,7 +121,6 @@ else()<br class="gmail_msg">
> linux/HostInfoLinux.cpp<br class="gmail_msg">
> linux/HostThreadLinux.cpp<br class="gmail_msg">
> linux/LibcGlue.cpp<br class="gmail_msg">
> - linux/ThisThread.cpp<br class="gmail_msg">
> )<br class="gmail_msg">
> list(APPEND LLDB_PLUGINS lldbPluginProcessLinux)<br class="gmail_msg">
> if (CMAKE_SYSTEM_NAME MATCHES "Android")<br class="gmail_msg">
> @@ -138,7 +134,6 @@ else()<br class="gmail_msg">
> freebsd/Host.cpp<br class="gmail_msg">
> freebsd/HostInfoFreeBSD.cpp<br class="gmail_msg">
> freebsd/HostThreadFreeBSD.cpp<br class="gmail_msg">
> - freebsd/ThisThread.cpp<br class="gmail_msg">
> )<br class="gmail_msg">
><br class="gmail_msg">
> elseif (CMAKE_SYSTEM_NAME MATCHES "NetBSD")<br class="gmail_msg">
> @@ -146,7 +141,6 @@ else()<br class="gmail_msg">
> netbsd/Host.cpp<br class="gmail_msg">
> netbsd/HostInfoNetBSD.cpp<br class="gmail_msg">
> netbsd/HostThreadNetBSD.cpp<br class="gmail_msg">
> - netbsd/ThisThread.cpp<br class="gmail_msg">
> )<br class="gmail_msg">
> endif()<br class="gmail_msg">
> endif()<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Host/common/Host.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/Host.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/Host.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/common/Host.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/common/Host.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -314,27 +314,6 @@ lldb::pid_t Host::GetCurrentProcessID()<br class="gmail_msg">
><br class="gmail_msg">
> #ifndef _WIN32<br class="gmail_msg">
><br class="gmail_msg">
> -lldb::tid_t Host::GetCurrentThreadID() {<br class="gmail_msg">
> -#if defined(__APPLE__)<br class="gmail_msg">
> - // Calling "mach_thread_self()" bumps the reference count on the thread<br class="gmail_msg">
> - // port, so we need to deallocate it. mach_task_self() doesn't bump the ref<br class="gmail_msg">
> - // count.<br class="gmail_msg">
> - thread_port_t thread_self = mach_thread_self();<br class="gmail_msg">
> - mach_port_deallocate(mach_task_self(), thread_self);<br class="gmail_msg">
> - return thread_self;<br class="gmail_msg">
> -#elif defined(__FreeBSD__)<br class="gmail_msg">
> - return lldb::tid_t(pthread_getthreadid_np());<br class="gmail_msg">
> -#elif defined(__NetBSD__)<br class="gmail_msg">
> - return lldb::tid_t(_lwp_self());<br class="gmail_msg">
> -#elif defined(__ANDROID__)<br class="gmail_msg">
> - return lldb::tid_t(gettid());<br class="gmail_msg">
> -#elif defined(__linux__)<br class="gmail_msg">
> - return lldb::tid_t(syscall(SYS_gettid));<br class="gmail_msg">
> -#else<br class="gmail_msg">
> - return lldb::tid_t(pthread_self());<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> lldb::thread_t Host::GetCurrentThread() {<br class="gmail_msg">
> return lldb::thread_t(pthread_self());<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Host/common/HostNativeThreadBase.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/HostNativeThreadBase.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/HostNativeThreadBase.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/common/HostNativeThreadBase.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/common/HostNativeThreadBase.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -9,10 +9,11 @@<br class="gmail_msg">
><br class="gmail_msg">
> #include "lldb/Host/HostNativeThreadBase.h"<br class="gmail_msg">
> #include "lldb/Host/HostInfo.h"<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> #include "lldb/Host/ThreadLauncher.h"<br class="gmail_msg">
> #include "lldb/Utility/Log.h"<br class="gmail_msg">
> +<br class="gmail_msg">
> #include "llvm/ADT/StringExtras.h"<br class="gmail_msg">
> +#include "llvm/Support/Threading.h"<br class="gmail_msg">
><br class="gmail_msg">
> using namespace lldb;<br class="gmail_msg">
> using namespace lldb_private;<br class="gmail_msg">
> @@ -52,7 +53,7 @@ lldb::thread_result_t<br class="gmail_msg">
> HostNativeThreadBase::ThreadCreateTrampoline(lldb::thread_arg_t arg) {<br class="gmail_msg">
> ThreadLauncher::HostThreadCreateInfo *info =<br class="gmail_msg">
> (ThreadLauncher::HostThreadCreateInfo *)arg;<br class="gmail_msg">
> - ThisThread::SetName(info->thread_name, HostInfo::GetMaxThreadNameLength());<br class="gmail_msg">
> + llvm::set_thread_name(info->thread_name);<br class="gmail_msg">
><br class="gmail_msg">
> thread_func_t thread_fptr = info->thread_fptr;<br class="gmail_msg">
> thread_arg_t thread_arg = info->thread_arg;<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/common/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/common/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/common/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,50 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -#include "lldb/Host/HostInfo.h"<br class="gmail_msg">
> -#include "lldb/Utility/Error.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/STLExtras.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include <algorithm><br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb;<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name, int max_length) {<br class="gmail_msg">
> - std::string truncated_name(name.data());<br class="gmail_msg">
> -<br class="gmail_msg">
> - // Thread names are coming in like '<lldb.comm.debugger.edit>' and<br class="gmail_msg">
> - // '<lldb.comm.debugger.editline>'. So just chopping the end of the string<br class="gmail_msg">
> - // off leads to a lot of similar named threads. Go through the thread name<br class="gmail_msg">
> - // and search for the last dot and use that.<br class="gmail_msg">
> -<br class="gmail_msg">
> - if (max_length > 0 &&<br class="gmail_msg">
> - truncated_name.length() > static_cast<size_t>(max_length)) {<br class="gmail_msg">
> - // First see if we can get lucky by removing any initial or final braces.<br class="gmail_msg">
> - std::string::size_type begin = truncated_name.find_first_not_of("(<");<br class="gmail_msg">
> - std::string::size_type end = truncated_name.find_last_not_of(")>.");<br class="gmail_msg">
> - if (end - begin > static_cast<size_t>(max_length)) {<br class="gmail_msg">
> - // We're still too long. Since this is a dotted component, use everything<br class="gmail_msg">
> - // after the last<br class="gmail_msg">
> - // dot, up to a maximum of |length| characters.<br class="gmail_msg">
> - std::string::size_type last_dot = truncated_name.rfind('.');<br class="gmail_msg">
> - if (last_dot != std::string::npos)<br class="gmail_msg">
> - begin = last_dot + 1;<br class="gmail_msg">
> -<br class="gmail_msg">
> - end = std::min(end, begin + max_length);<br class="gmail_msg">
> - }<br class="gmail_msg">
> -<br class="gmail_msg">
> - std::string::size_type count = end - begin + 1;<br class="gmail_msg">
> - truncated_name = truncated_name.substr(begin, count);<br class="gmail_msg">
> - }<br class="gmail_msg">
> -<br class="gmail_msg">
> - SetName(truncated_name);<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Host/common/ThreadLauncher.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/ThreadLauncher.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/ThreadLauncher.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/common/ThreadLauncher.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/common/ThreadLauncher.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -12,7 +12,6 @@<br class="gmail_msg">
> #include "lldb/Host/ThreadLauncher.h"<br class="gmail_msg">
> #include "lldb/Host/HostNativeThread.h"<br class="gmail_msg">
> #include "lldb/Host/HostThread.h"<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> #include "lldb/Utility/Log.h"<br class="gmail_msg">
><br class="gmail_msg">
> #if defined(_WIN32)<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/freebsd/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/freebsd/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/freebsd/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/freebsd/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/freebsd/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,35 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -#include "lldb/Host/HostNativeThread.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/SmallVector.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include <pthread.h><br class="gmail_msg">
> -#if defined(__FreeBSD__)<br class="gmail_msg">
> -#include <pthread_np.h><br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name) {<br class="gmail_msg">
> -#if defined(__FreeBSD__) // Kfreebsd does not have a simple alternative<br class="gmail_msg">
> - ::pthread_set_name_np(::pthread_self(), name.data());<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::GetName(llvm::SmallVectorImpl<char> &name) {<br class="gmail_msg">
> -#if defined(__FreeBSD__)<br class="gmail_msg">
> - HostNativeThread::GetName(::pthread_getthreadid_np(), name);<br class="gmail_msg">
> -#else<br class="gmail_msg">
> - // Kfreebsd<br class="gmail_msg">
> - HostNativeThread::GetName((unsigned)pthread_self(), name);<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/linux/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/linux/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/linux/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/linux/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/linux/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,25 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -#include "lldb/Host/HostNativeThread.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/SmallVector.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include <pthread.h><br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name) {<br class="gmail_msg">
> - HostNativeThread::SetName(::pthread_self(), name);<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::GetName(llvm::SmallVectorImpl<char> &name) {<br class="gmail_msg">
> - HostNativeThread::GetName(::pthread_self(), name);<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/macosx/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/macosx/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/macosx/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,25 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/SmallVector.h"<br class="gmail_msg">
> -#include <pthread.h><br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name) {<br class="gmail_msg">
> -#if defined(__APPLE__)<br class="gmail_msg">
> - ::pthread_setname_np(name.str().c_str());<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::GetName(llvm::SmallVectorImpl<char> &name) {<br class="gmail_msg">
> - // FIXME - implement this.<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/netbsd/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/netbsd/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/netbsd/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/netbsd/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/netbsd/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,26 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -#include "lldb/Host/HostNativeThread.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/SmallVector.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include <pthread.h><br class="gmail_msg">
> -#include <string.h><br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name) {<br class="gmail_msg">
> - HostNativeThread::SetName(::pthread_self(), name);<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::GetName(llvm::SmallVectorImpl<char> &name) {<br class="gmail_msg">
> - HostNativeThread::GetName(::pthread_self(), name);<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Host/windows/Host.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/windows/Host.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/windows/Host.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/windows/Host.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/windows/Host.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -101,10 +101,6 @@ lldb::DataBufferSP Host::GetAuxvData(lld<br class="gmail_msg">
> return 0;<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> -lldb::tid_t Host::GetCurrentThreadID() {<br class="gmail_msg">
> - return lldb::tid_t(::GetCurrentThreadId());<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> lldb::thread_t Host::GetCurrentThread() {<br class="gmail_msg">
> return lldb::thread_t(::GetCurrentThread());<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> Removed: lldb/trunk/source/Host/windows/ThisThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/windows/ThisThread.cpp?rev=296945&view=auto" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/windows/ThisThread.cpp?rev=296945&view=auto</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Host/windows/ThisThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Host/windows/ThisThread.cpp (removed)<br class="gmail_msg">
> @@ -1,63 +0,0 @@<br class="gmail_msg">
> -//===-- ThisThread.cpp ------------------------------------------*- C++ -*-===//<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// The LLVM Compiler Infrastructure<br class="gmail_msg">
> -//<br class="gmail_msg">
> -// This file is distributed under the University of Illinois Open Source<br class="gmail_msg">
> -// License. See LICENSE.TXT for details.<br class="gmail_msg">
> -//<br class="gmail_msg">
> -//===----------------------------------------------------------------------===//<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Utility/Error.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> -#include "lldb/Host/windows/windows.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -#include "llvm/ADT/STLExtras.h"<br class="gmail_msg">
> -#include "llvm/ADT/SmallVector.h"<br class="gmail_msg">
> -<br class="gmail_msg">
> -using namespace lldb;<br class="gmail_msg">
> -using namespace lldb_private;<br class="gmail_msg">
> -<br class="gmail_msg">
> -#if defined(_MSC_VER) && !defined(__clang__)<br class="gmail_msg">
> -<br class="gmail_msg">
> -namespace {<br class="gmail_msg">
> -static const DWORD MS_VC_EXCEPTION = 0x406D1388;<br class="gmail_msg">
> -<br class="gmail_msg">
> -#pragma pack(push, 8)<br class="gmail_msg">
> -struct THREADNAME_INFO {<br class="gmail_msg">
> - DWORD dwType; // Must be 0x1000.<br class="gmail_msg">
> - LPCSTR szName; // Pointer to thread name<br class="gmail_msg">
> - DWORD dwThreadId; // Thread ID (-1 == current thread)<br class="gmail_msg">
> - DWORD dwFlags; // Reserved. Do not use.<br class="gmail_msg">
> -};<br class="gmail_msg">
> -#pragma pack(pop)<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::SetName(llvm::StringRef name) {<br class="gmail_msg">
> -// Other compilers don't yet support SEH, so we can only set the thread if<br class="gmail_msg">
> -// compiling with MSVC.<br class="gmail_msg">
> -// TODO(zturner): Once clang-cl supports SEH, relax this conditional.<br class="gmail_msg">
> -#if defined(_MSC_VER) && !defined(__clang__)<br class="gmail_msg">
> - THREADNAME_INFO info;<br class="gmail_msg">
> - info.dwType = 0x1000;<br class="gmail_msg">
> - info.szName = name.data();<br class="gmail_msg">
> - info.dwThreadId = ::GetCurrentThreadId();<br class="gmail_msg">
> - info.dwFlags = 0;<br class="gmail_msg">
> -<br class="gmail_msg">
> - __try {<br class="gmail_msg">
> - ::RaiseException(MS_VC_EXCEPTION, 0, sizeof(info) / sizeof(ULONG_PTR),<br class="gmail_msg">
> - (ULONG_PTR *)&info);<br class="gmail_msg">
> - } __except (EXCEPTION_EXECUTE_HANDLER) {<br class="gmail_msg">
> - }<br class="gmail_msg">
> -#endif<br class="gmail_msg">
> -}<br class="gmail_msg">
> -<br class="gmail_msg">
> -void ThisThread::GetName(llvm::SmallVectorImpl<char> &name) {<br class="gmail_msg">
> - // Getting the thread name is not supported on Windows.<br class="gmail_msg">
> - // TODO(zturner): In SetName(), make a TLS entry that contains the thread's<br class="gmail_msg">
> - // name, and in this function<br class="gmail_msg">
> - // try to extract that TLS entry.<br class="gmail_msg">
> - name.clear();<br class="gmail_msg">
> -}<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Plugins/Process/Windows/Common/DebuggerThread.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -14,7 +14,6 @@<br class="gmail_msg">
> #include "lldb/Core/ModuleSpec.h"<br class="gmail_msg">
> #include "lldb/Host/FileSpec.h"<br class="gmail_msg">
> #include "lldb/Host/Predicate.h"<br class="gmail_msg">
> -#include "lldb/Host/ThisThread.h"<br class="gmail_msg">
> #include "lldb/Host/ThreadLauncher.h"<br class="gmail_msg">
> #include "lldb/Host/windows/HostProcessWindows.h"<br class="gmail_msg">
> #include "lldb/Host/windows/HostThreadWindows.h"<br class="gmail_msg">
> @@ -28,6 +27,7 @@<br class="gmail_msg">
><br class="gmail_msg">
> #include "llvm/ADT/STLExtras.h"<br class="gmail_msg">
> #include "llvm/Support/ConvertUTF.h"<br class="gmail_msg">
> +#include "llvm/Support/Threading.h"<br class="gmail_msg">
> #include "llvm/Support/raw_ostream.h"<br class="gmail_msg">
><br class="gmail_msg">
> using namespace lldb;<br class="gmail_msg">
> @@ -406,7 +406,7 @@ DebuggerThread::HandleCreateProcessEvent<br class="gmail_msg">
> llvm::raw_string_ostream name_stream(thread_name);<br class="gmail_msg">
> name_stream << "lldb.plugin.process-windows.slave[" << process_id << "]";<br class="gmail_msg">
> name_stream.flush();<br class="gmail_msg">
> - ThisThread::SetName(thread_name.c_str());<br class="gmail_msg">
> + llvm::set_thread_name(thread_name);<br class="gmail_msg">
><br class="gmail_msg">
> // info.hProcess and info.hThread are closed automatically by Windows when<br class="gmail_msg">
> // EXIT_PROCESS_DEBUG_EVENT is received.<br class="gmail_msg">
><br class="gmail_msg">
> Modified: lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp<br class="gmail_msg">
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp?rev=296946&r1=296945&r2=296946&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp?rev=296946&r1=296945&r2=296946&view=diff</a><br class="gmail_msg">
> ==============================================================================<br class="gmail_msg">
> --- lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp (original)<br class="gmail_msg">
> +++ lldb/trunk/source/Plugins/Process/gdb-remote/GDBRemoteCommunication.cpp Fri Mar 3 19:31:06 2017<br class="gmail_msg">
> @@ -72,7 +72,7 @@ void GDBRemoteCommunication::History::Ad<br class="gmail_msg">
> m_packets[idx].type = type;<br class="gmail_msg">
> m_packets[idx].bytes_transmitted = bytes_transmitted;<br class="gmail_msg">
> m_packets[idx].packet_idx = m_total_packet_count;<br class="gmail_msg">
> - m_packets[idx].tid = Host::GetCurrentThreadID();<br class="gmail_msg">
> + m_packets[idx].tid = llvm::get_threadid();<br class="gmail_msg">
> }<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
> @@ -87,7 +87,7 @@ void GDBRemoteCommunication::History::Ad<br class="gmail_msg">
> m_packets[idx].type = type;<br class="gmail_msg">
> m_packets[idx].bytes_transmitted = bytes_transmitted;<br class="gmail_msg">
> m_packets[idx].packet_idx = m_total_packet_count;<br class="gmail_msg">
> - m_packets[idx].tid = Host::GetCurrentThreadID();<br class="gmail_msg">
> + m_packets[idx].tid = llvm::get_threadid();<br class="gmail_msg">
> }<br class="gmail_msg">
> }<br class="gmail_msg">
><br class="gmail_msg">
><br class="gmail_msg">
><br class="gmail_msg">
> _______________________________________________<br class="gmail_msg">
> lldb-commits mailing list<br class="gmail_msg">
> <a href="mailto:lldb-commits@lists.llvm.org" class="gmail_msg" target="_blank">lldb-commits@lists.llvm.org</a><br class="gmail_msg">
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits</a><br class="gmail_msg">
<br class="gmail_msg">
</blockquote></div>