mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 10:32:56 +01:00 
			
		
		
		
	Thread POSIX: tid is numeric OS thread ID on Linux and OSX instead of pthread_t.
This commit is contained in:
		| @@ -45,7 +45,18 @@ namespace Poco { | ||||
| class Foundation_API ThreadImpl | ||||
| { | ||||
| public: | ||||
|  | ||||
| #if POCO_OS == POCO_OS_LINUX | ||||
| 	// OS kernel thread ID | ||||
| 	typedef pid_t TIDImpl; | ||||
| #elif POCO_OS == POCO_OS_MAC_OS_X | ||||
| 	// OS kernel thread ID | ||||
| 	typedef mach_port_t TIDImpl; | ||||
| #else | ||||
| 	// Default: pthread id | ||||
| 	typedef pthread_t TIDImpl; | ||||
| #endif | ||||
|  | ||||
| 	typedef void (*Callable)(void*); | ||||
|  | ||||
| 	enum Priority | ||||
| @@ -136,6 +147,7 @@ private: | ||||
|  | ||||
| 		SharedPtr<Runnable> pRunnableTarget; | ||||
| 		pthread_t     thread; | ||||
| 		TIDImpl       tid; | ||||
| 		int           prio; | ||||
| 		int           osPrio; | ||||
| 		int           policy; | ||||
| @@ -191,7 +203,7 @@ inline int ThreadImpl::getStackSizeImpl() const | ||||
|  | ||||
| inline ThreadImpl::TIDImpl ThreadImpl::tidImpl() const | ||||
| { | ||||
| 	return _pData->thread; | ||||
| 	return _pData->tid; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -35,7 +35,9 @@ | ||||
| #   include <mach/task.h> | ||||
| #   include <mach/thread_policy.h> | ||||
| #endif | ||||
|  | ||||
| #if POCO_OS == POCO_OS_LINUX | ||||
| #include <sys/syscall.h> | ||||
| #endif | ||||
|  | ||||
| // | ||||
| // Block SIGPIPE in main thread. | ||||
| @@ -296,6 +298,15 @@ void ThreadImpl::startImpl(SharedPtr<Runnable> pTarget) | ||||
| 		pthread_attr_destroy(&attributes); | ||||
| 		throw SystemException("cannot start thread"); | ||||
| 	} | ||||
| #if POCO_OS == POCO_OS_LINUX | ||||
| 	// On Linux the TID is acquired from the running thread using syscall | ||||
| 	_pData->tid = 0; | ||||
| #elif POCO_OS == POCO_OS_MAC_OS_X | ||||
| 	_pData->tid = static_cast<TIDImpl>( pthread_mach_thread_np(_pData->thread) ); | ||||
| #else | ||||
| 	_pData->tid = _pData->thread; | ||||
| #endif | ||||
|  | ||||
| 	_pData->started = true; | ||||
| 	pthread_attr_destroy(&attributes); | ||||
|  | ||||
| @@ -353,7 +364,13 @@ ThreadImpl* ThreadImpl::currentImpl() | ||||
|  | ||||
| ThreadImpl::TIDImpl ThreadImpl::currentTidImpl() | ||||
| { | ||||
| #if POCO_OS == POCO_OS_LINUX | ||||
| 	return static_cast<TIDImpl>( syscall (SYS_gettid) ); | ||||
| #elif POCO_OS == POCO_OS_MAC_OS_X | ||||
| 	return static_cast<TIDImpl>( pthread_mach_thread_np(pthread_self()) ); | ||||
| #else | ||||
| 	return pthread_self(); | ||||
| #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -430,7 +447,12 @@ void* ThreadImpl::runnableEntry(void* pThread) | ||||
| #if defined(POCO_POSIX_DEBUGGER_THREAD_NAMES) | ||||
| 	setThreadName(pThreadImpl->_pData->thread, reinterpret_cast<Thread*>(pThread)->getName().c_str()); | ||||
| #endif | ||||
| #if POCO_OS == POCO_OS_LINUX | ||||
| 	pThreadImpl->_pData->tid = static_cast<TIDImpl>( syscall (SYS_gettid) ); | ||||
| #endif | ||||
|  | ||||
| 	AutoPtr<ThreadData> pData = pThreadImpl->_pData; | ||||
|  | ||||
| 	try | ||||
| 	{ | ||||
| 		pData->pRunnableTarget->run(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Matej Kenda
					Matej Kenda