Unverified Commit 9dcbdd1b authored by Luca Boccassi's avatar Luca Boccassi Committed by GitHub

Merge pull request #3601 from jacquesg/win32threadname

mingw thread name fix
parents 47fc979b b3123a2f
...@@ -32,6 +32,10 @@ ...@@ -32,6 +32,10 @@
#include "thread.hpp" #include "thread.hpp"
#include "err.hpp" #include "err.hpp"
#ifdef ZMQ_HAVE_WINDOWS
#include <winnt.h>
#endif
bool zmq::thread_t::get_started () const bool zmq::thread_t::get_started () const
{ {
return _started; return _started;
...@@ -113,10 +117,22 @@ struct thread_info_t ...@@ -113,10 +117,22 @@ struct thread_info_t
#pragma pack(pop) #pragma pack(pop)
} }
typedef struct _MY_EXCEPTION_REGISTRATION_RECORD
{
struct _MY_EXCEPTION_REGISTRATION_RECORD *Next;
void *Handler;
} MY_EXCEPTION_REGISTRATION_RECORD;
static EXCEPTION_DISPOSITION NTAPI continue_execution (EXCEPTION_RECORD *rec,
void *frame, CONTEXT *ctx, void *disp)
{
return ExceptionContinueExecution;
}
void zmq::thread_t:: void zmq::thread_t::
applyThreadName () // to be called in secondary thread context applyThreadName () // to be called in secondary thread context
{ {
if (!_name[0]) if (!_name[0] || !IsDebuggerPresent())
return; return;
thread_info_t thread_info; thread_info_t thread_info;
...@@ -125,17 +141,19 @@ void zmq::thread_t:: ...@@ -125,17 +141,19 @@ void zmq::thread_t::
thread_info._thread_id = -1; thread_info._thread_id = -1;
thread_info._flags = 0; thread_info._flags = 0;
#pragma warning(push) NT_TIB *tib = ((NT_TIB*)NtCurrentTeb());
#pragma warning(disable : 6320 6322)
__try { MY_EXCEPTION_REGISTRATION_RECORD rec;
DWORD MS_VC_EXCEPTION = 0x406D1388; rec.Next = (MY_EXCEPTION_REGISTRATION_RECORD *)tib->ExceptionList;
rec.Handler = continue_execution;
// push our handler, raise, and finally pop our handler
tib->ExceptionList = (_EXCEPTION_REGISTRATION_RECORD *)&rec;
DWORD MS_VC_EXCEPTION = 0x406D1388;
RaiseException (MS_VC_EXCEPTION, 0, RaiseException (MS_VC_EXCEPTION, 0,
sizeof (thread_info) / sizeof (ULONG_PTR), sizeof (thread_info) / sizeof (ULONG_PTR),
(ULONG_PTR *) &thread_info); (ULONG_PTR *) &thread_info);
} tib->ExceptionList = (_EXCEPTION_REGISTRATION_RECORD *)(((MY_EXCEPTION_REGISTRATION_RECORD *)tib->ExceptionList)->Next);
__except (EXCEPTION_CONTINUE_EXECUTION) {
}
#pragma warning(pop)
} }
#elif defined ZMQ_HAVE_VXWORKS #elif defined ZMQ_HAVE_VXWORKS
......
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