From a2bd3ec4a2df72f2ae592afca5b9eb1eccd28d7a Mon Sep 17 00:00:00 2001 From: Ivan Maidanski Date: Fri, 6 Oct 2017 21:26:06 +0300 Subject: [PATCH] Move conditional GC_need_to_lock setting to gc_locks.h (code refactoring) * include/private/gc_locks.h [GC_PTHREADS && !THREAD_LOCAL_ALLOC && !USE_PTHREAD_LOCKS && !GC_ASSERTIONS] (UNCOND_LOCK): Remove GC_ASSERT(I_DONT_HOLD_LOCK()) because it is no-op (when assertion checking is off). * include/private/gc_locks.h [THREADS] (set_need_to_lock): New macro. * pthread_support.c [!GC_ALWAYS_MULTITHREADED] (GC_allow_register_threads, WRAP_FUNC(pthread_create)): Replace GC_need_to_lock=TRUE to set_need_to_lock(). * win32_threads.c [!GC_ALWAYS_MULTITHREADED] (GC_allow_register_threads, GC_CreateThread, GC_init_parallel): Likewise. * win32_threads.c [!MSWINCE && !CYGWIN32 && !GC_ALWAYS_MULTITHREADED] (GC_beginthreadex): Likewise. * win32_threads.c [GC_PTHREADS && !GC_ALWAYS_MULTITHREADED] (GC_pthread_create): Likewise. --- include/private/gc_locks.h | 6 ++++-- pthread_support.c | 10 ++-------- win32_threads.c | 29 ++++++++++------------------- 3 files changed, 16 insertions(+), 29 deletions(-) diff --git a/include/private/gc_locks.h b/include/private/gc_locks.h index 0062c796..e03fa67a 100644 --- a/include/private/gc_locks.h +++ b/include/private/gc_locks.h @@ -137,8 +137,7 @@ AO_CLEAR(&GC_allocate_lock); } # else # define UNCOND_LOCK() \ - { GC_ASSERT(I_DONT_HOLD_LOCK()); \ - if (AO_test_and_set_acquire(&GC_allocate_lock) == AO_TS_SET) \ + { if (AO_test_and_set_acquire(&GC_allocate_lock) == AO_TS_SET) \ GC_lock(); } # define UNCOND_UNLOCK() AO_CLEAR(&GC_allocate_lock) # endif /* !GC_ASSERTIONS */ @@ -197,12 +196,15 @@ # if defined(GC_ALWAYS_MULTITHREADED) \ && (defined(USE_PTHREAD_LOCKS) || defined(USE_SPIN_LOCK)) # define GC_need_to_lock TRUE +# define set_need_to_lock() (void)0 # else # if defined(GC_ALWAYS_MULTITHREADED) && !defined(CPPCHECK) # error Runtime initialization of GC lock is needed! # endif # undef GC_ALWAYS_MULTITHREADED GC_EXTERN GC_bool GC_need_to_lock; +# define set_need_to_lock() (void)(GC_need_to_lock = TRUE) + /* We are multi-threaded now. */ # endif # else /* !THREADS */ diff --git a/pthread_support.c b/pthread_support.c index c4d5a3f6..1b2eac1f 100644 --- a/pthread_support.c +++ b/pthread_support.c @@ -1643,10 +1643,7 @@ GC_API void GC_CALL GC_allow_register_threads(void) { /* Check GC is initialized and the current thread is registered. */ GC_ASSERT(GC_lookup_thread(pthread_self()) != 0); - -# ifndef GC_ALWAYS_MULTITHREADED - GC_need_to_lock = TRUE; /* We are multi-threaded now. */ -# endif + set_need_to_lock(); } GC_API int GC_CALL GC_register_my_thread(const struct GC_stack_base *sb) @@ -1838,10 +1835,7 @@ GC_API int WRAP_FUNC(pthread_create)(pthread_t *new_thread, GC_log_printf("About to start new thread from thread %p\n", (void *)pthread_self()); # endif -# ifndef GC_ALWAYS_MULTITHREADED - GC_need_to_lock = TRUE; -# endif - + set_need_to_lock(); result = REAL_FUNC(pthread_create)(new_thread, attr, GC_start_routine, si); /* Wait until child has been added to the thread table. */ diff --git a/win32_threads.c b/win32_threads.c index e234a19c..0fb4cf0b 100644 --- a/win32_threads.c +++ b/win32_threads.c @@ -726,13 +726,12 @@ GC_API void GC_CALL GC_allow_register_threads(void) { /* Check GC is initialized and the current thread is registered. */ GC_ASSERT(GC_lookup_thread_inner(GetCurrentThreadId()) != 0); -# ifndef GC_ALWAYS_MULTITHREADED -# if !defined(GC_NO_THREADS_DISCOVERY) && !defined(PARALLEL_MARK) +# if !defined(GC_ALWAYS_MULTITHREADED) && !defined(PARALLEL_MARK) \ + && !defined(GC_NO_THREADS_DISCOVERY) /* GC_init() does not call GC_init_parallel() in this case. */ - parallel_initialized = TRUE; -# endif - GC_need_to_lock = TRUE; /* We are multi-threaded now. */ + parallel_initialized = TRUE; # endif + set_need_to_lock(); } GC_API int GC_CALL GC_register_my_thread(const struct GC_stack_base *sb) @@ -2253,9 +2252,7 @@ GC_INNER void GC_get_next_stack(char *start, char *limit, args -> start = lpStartAddress; args -> param = lpParameter; -# ifndef GC_ALWAYS_MULTITHREADED - GC_need_to_lock = TRUE; -# endif + set_need_to_lock(); thread_h = CreateThread(lpThreadAttributes, dwStackSize, GC_win32_start, args, dwCreationFlags, lpThreadId); if (thread_h == 0) GC_free(args); @@ -2307,9 +2304,7 @@ GC_INNER void GC_get_next_stack(char *start, char *limit, args -> start = (LPTHREAD_START_ROUTINE)start_address; args -> param = arglist; -# ifndef GC_ALWAYS_MULTITHREADED - GC_need_to_lock = TRUE; -# endif + set_need_to_lock(); thread_h = _beginthreadex(security, stack_size, (unsigned (__stdcall *)(void *))GC_win32_start, args, initflag, thrdaddr); @@ -2605,9 +2600,7 @@ GC_INNER void GC_thr_init(void) (void *)GC_PTHREAD_PTRVAL(pthread_self()), (long)GetCurrentThreadId()); # endif -# ifndef GC_ALWAYS_MULTITHREADED - GC_need_to_lock = TRUE; -# endif + set_need_to_lock(); result = pthread_create(new_thread, attr, GC_pthread_start, si); if (result) { /* failure */ @@ -2837,15 +2830,13 @@ GC_INNER void GC_init_parallel(void) # if defined(CPPCHECK) && !defined(GC_NO_THREADS_DISCOVERY) GC_noop1((word)&GC_DllMain); # endif -# ifndef GC_ALWAYS_MULTITHREADED - if (GC_win32_dll_threads) { - GC_need_to_lock = TRUE; + if (GC_win32_dll_threads) { + set_need_to_lock(); /* Cannot intercept thread creation. Hence we don't know if */ /* other threads exist. However, client is not allowed to */ /* create other threads before collector initialization. */ /* Thus it's OK not to lock before this. */ - } -# endif + } /* Initialize thread local free lists if used. */ # if defined(THREAD_LOCAL_ALLOC) LOCK(); -- 2.40.0