From f1d0c326db54712bf9d1e4cf73e53b61afbaa8af Mon Sep 17 00:00:00 2001 From: khizmax Date: Tue, 7 Feb 2017 21:26:04 +0300 Subject: [PATCH] Removed cds::OS::is_thread_alive() function. This function is based of pthread_kill(tid, 0) that is dangerous for Linux --- cds/os/posix/thread.h | 9 --------- cds/os/win/thread.h | 11 ----------- cds/urcu/details/base.h | 1 - src/dhp.cpp | 10 ++++++---- src/hp.cpp | 11 ++++++----- 5 files changed, 12 insertions(+), 30 deletions(-) diff --git a/cds/os/posix/thread.h b/cds/os/posix/thread.h index 64e6f26f..399c9375 100644 --- a/cds/os/posix/thread.h +++ b/cds/os/posix/thread.h @@ -46,15 +46,6 @@ namespace cds { namespace OS { { return pthread_self(); } - - /// Checks if thread \p id is alive - static inline bool is_thread_alive( ThreadId id ) - { - // if sig is zero, error checking is performed but no signal is actually sent. - // ESRCH - No thread could be found corresponding to that specified by the given thread ID - // Unresolved problem: Linux may crash on dead thread_id. Workaround unknown (except signal handler...) - return pthread_kill( id, 0 ) != ESRCH; - } } // namespace posix //@cond diff --git a/cds/os/win/thread.h b/cds/os/win/thread.h index 93f2440d..023f3306 100644 --- a/cds/os/win/thread.h +++ b/cds/os/win/thread.h @@ -48,16 +48,6 @@ namespace cds { namespace OS { { return ::GetCurrentThreadId(); } - - /// Tests whether the thread is alive - static inline bool is_thread_alive( ThreadId id ) - { - HANDLE h = ::OpenThread( SYNCHRONIZE, FALSE, id ); - if ( h == nullptr ) - return false; - ::CloseHandle( h ); - return true; - } } // namespace Win32 //@cond @@ -66,7 +56,6 @@ namespace cds { namespace OS { #ifndef CDS_CXX11_INLINE_NAMESPACE_SUPPORT using Win32::ThreadId; using Win32::get_current_thread_id; - using Win32::is_thread_alive; #endif //@endcond diff --git a/cds/urcu/details/base.h b/cds/urcu/details/base.h index 638eb876..ea910e31 100644 --- a/cds/urcu/details/base.h +++ b/cds/urcu/details/base.h @@ -424,7 +424,6 @@ namespace cds { assert( p->m_list.m_idOwner.load( atomics::memory_order_relaxed ) == nullThreadId || p->m_list.m_idOwner.load( atomics::memory_order_relaxed ) == mainThreadId - || !cds::OS::is_thread_alive( p->m_list.m_idOwner.load( atomics::memory_order_relaxed )) ); al.Delete( p ); diff --git a/src/dhp.cpp b/src/dhp.cpp index 462de952..0991de10 100644 --- a/src/dhp.cpp +++ b/src/dhp.cpp @@ -210,8 +210,7 @@ namespace cds { namespace gc { namespace dhp { for ( thread_record* hprec = pHead; hprec; hprec = pNext ) { assert( hprec->m_idOwner.load( atomics::memory_order_relaxed ) == nullThreadId - || hprec->m_idOwner.load( atomics::memory_order_relaxed ) == mainThreadId - || !cds::OS::is_thread_alive( hprec->m_idOwner.load( atomics::memory_order_relaxed ) ) + || hprec->m_idOwner.load( atomics::memory_order_relaxed ) == mainThreadId ) ); retired_array& retired = hprec->retired_; @@ -459,6 +458,9 @@ namespace cds { namespace gc { namespace dhp { const cds::OS::ThreadId curThreadId = cds::OS::get_current_thread_id(); for ( thread_record* hprec = thread_list_.load( atomics::memory_order_acquire ); hprec; hprec = hprec->m_pNextNode.load( atomics::memory_order_relaxed ) ) { + if ( hprec == static_cast( pThis )) + continue; + // If m_bFree == true then hprec->retired_ is empty - we don't need to see it if ( hprec->m_bFree.load( atomics::memory_order_acquire ) ) { assert( hprec->retired_.empty() ); @@ -469,7 +471,7 @@ namespace cds { namespace gc { namespace dhp { // Several threads may work concurrently so we use atomic technique { cds::OS::ThreadId curOwner = hprec->m_idOwner.load( atomics::memory_order_relaxed ); - if ( curOwner == nullThreadId || !cds::OS::is_thread_alive( curOwner ) ) { + if ( curOwner == nullThreadId ) { if ( !hprec->m_idOwner.compare_exchange_strong( curOwner, curThreadId, atomics::memory_order_acquire, atomics::memory_order_relaxed ) ) continue; } @@ -478,7 +480,7 @@ namespace cds { namespace gc { namespace dhp { } // We own the thread record successfully. Now, we can see whether it has retired pointers. - // If it has ones then we move to pThis that is private for current thread. + // If it has ones then we move them to pThis that is private for current thread. retired_array& src = hprec->retired_; retired_array& dest = pThis->retired_; diff --git a/src/hp.cpp b/src/hp.cpp index 6481a2cc..99a3d165 100644 --- a/src/hp.cpp +++ b/src/hp.cpp @@ -162,8 +162,7 @@ namespace cds { namespace gc { namespace hp { for ( thread_record* hprec = pHead; hprec; hprec = pNext ) { assert( hprec->m_idOwner.load( atomics::memory_order_relaxed ) == nullThreadId - || hprec->m_idOwner.load( atomics::memory_order_relaxed ) == mainThreadId - || !cds::OS::is_thread_alive( hprec->m_idOwner.load( atomics::memory_order_relaxed ) ) + || hprec->m_idOwner.load( atomics::memory_order_relaxed ) == mainThreadId ) ); retired_array& arr = hprec->retired_; @@ -256,7 +255,6 @@ namespace cds { namespace gc { namespace hp { CDS_EXPORT_API void smr::free_thread_data( smr::thread_record* pRec ) { assert( pRec != nullptr ); - //CDS_HAZARDPTR_STATISTIC( ++m_Stat.m_RetireHPRec ) pRec->hazards_.clear(); scan( pRec ); @@ -447,6 +445,9 @@ namespace cds { namespace gc { namespace hp { const cds::OS::ThreadId curThreadId = cds::OS::get_current_thread_id(); for ( thread_record* hprec = thread_list_.load( atomics::memory_order_acquire ); hprec; hprec = hprec->m_pNextNode.load( atomics::memory_order_relaxed )) { + if ( hprec == static_cast( pThis )) + continue; + // If m_bFree == true then hprec->retired_ is empty - we don't need to see it if ( hprec->m_bFree.load( atomics::memory_order_acquire )) continue; @@ -455,7 +456,7 @@ namespace cds { namespace gc { namespace hp { // Several threads may work concurrently so we use atomic technique only. { cds::OS::ThreadId curOwner = hprec->m_idOwner.load( atomics::memory_order_relaxed ); - if ( curOwner == nullThreadId || !cds::OS::is_thread_alive( curOwner ) ) { + if ( curOwner == nullThreadId ) { if ( !hprec->m_idOwner.compare_exchange_strong( curOwner, curThreadId, atomics::memory_order_acquire, atomics::memory_order_relaxed ) ) continue; } @@ -464,7 +465,7 @@ namespace cds { namespace gc { namespace hp { } // We own the thread record successfully. Now, we can see whether it has retired pointers. - // If it has ones then we move to pThis that is private for current thread. + // If it has ones then we move them to pThis that is private for current thread. retired_array& src = hprec->retired_; retired_array& dest = pThis->retired_; assert( !dest.full() ); -- 2.34.1