mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-23 10:07:41 +08:00 
			
		
		
		
	[NFC][libcxx] Add comments about making mutex/condition_variable trivial on Apple platforms
Leaving some comments behind so that we avoid re-having that discussion in the future. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@367048 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1097,17 +1097,27 @@ _LIBCPP_FUNC_VIS extern "C" void __sanitizer_annotate_contiguous_container( | |||||||
|        _LIBCPP_HAS_NO_THREADS is defined. |        _LIBCPP_HAS_NO_THREADS is defined. | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // The Apple, glibc, and Bionic implementation of pthreads implements | // The glibc and Bionic implementation of pthreads implements | ||||||
| // pthread_mutex_destroy as nop for regular mutexes. Additionally, Win32 | // pthread_mutex_destroy as nop for regular mutexes. Additionally, Win32 | ||||||
| // mutexes have no destroy mechanism. | // mutexes have no destroy mechanism. | ||||||
| // TODO(EricWF): Enable this optimization on Apple and Bionic platforms after | // | ||||||
| // speaking to their respective stakeholders. | // This optimization can't be performed on Apple platforms, where | ||||||
|  | // pthread_mutex_destroy can allow the kernel to release resources. | ||||||
|  | // See https://llvm.org/D64298 for details. | ||||||
|  | // | ||||||
|  | // TODO(EricWF): Enable this optimization on Bionic after speaking to their | ||||||
|  | //               respective stakeholders. | ||||||
| #if (defined(_LIBCPP_HAS_THREAD_API_PTHREAD) && defined(__GLIBC__)) \ | #if (defined(_LIBCPP_HAS_THREAD_API_PTHREAD) && defined(__GLIBC__)) \ | ||||||
|   || defined(_LIBCPP_HAS_THREAD_API_WIN32) |   || defined(_LIBCPP_HAS_THREAD_API_WIN32) | ||||||
| # define _LIBCPP_HAS_TRIVIAL_MUTEX_DESTRUCTION | # define _LIBCPP_HAS_TRIVIAL_MUTEX_DESTRUCTION | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // Destroying a condvar is a nop on Windows. | // Destroying a condvar is a nop on Windows. | ||||||
|  | // | ||||||
|  | // This optimization can't be performed on Apple platforms, where | ||||||
|  | // pthread_cond_destroy can allow the kernel to release resources. | ||||||
|  | // See https://llvm.org/D64298 for details. | ||||||
|  | // | ||||||
| // TODO(EricWF): This is potentially true for some pthread implementations | // TODO(EricWF): This is potentially true for some pthread implementations | ||||||
| // as well. | // as well. | ||||||
| #if defined(_LIBCPP_HAS_THREAD_API_WIN32) | #if defined(_LIBCPP_HAS_THREAD_API_WIN32) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Louis Dionne
					Louis Dionne