diff options
author | Martin Sebor <msebor@redhat.com> | 2015-07-01 14:05:27 -0600 |
---|---|---|
committer | Martin Sebor <msebor@redhat.com> | 2015-07-01 14:05:27 -0600 |
commit | ed225df3ad9cbac3c22ec3f0fbbed1f9c61d1c54 (patch) | |
tree | 175abf6476b8924e619c559993324efdb855e392 /NEWS | |
parent | 9081b7bcb11e74cd2d4363663ccd1bb641392719 (diff) | |
download | glibc-ed225df3ad9cbac3c22ec3f0fbbed1f9c61d1c54.tar.gz glibc-ed225df3ad9cbac3c22ec3f0fbbed1f9c61d1c54.tar.xz glibc-ed225df3ad9cbac3c22ec3f0fbbed1f9c61d1c54.zip |
The C++ 2011 std::call_once function is specified to allow
the initialization routine to exit by throwing an exception. Such an execution, termed exceptional, requires call_once to propagate the exception to its caller. A program may contain any number of exceptional executions but only one returning execution (which, if it exists, must be the last execution with the same once flag). On POSIX systems such as Linux, std::call_once is implemented in terms of pthread_once. However, as discussed in libstdc++ bug 66146 - "call_once not C++11-compliant on ppc64le," GLIBC's pthread_once hangs when the initialization function exits by throwing an exception on at least arm and ppc64 (though apparently not on x86_64). This effectively prevents call_once from conforming to the C++ requirements since there doesn't appear to be a thread-safe way to work around this problem in libstdc++. This patch changes pthread_once to handle gracefully init functions that exit by throwing exceptions. It was successfully tested on ppc64, ppc64le, and x86_64. [BZ #18435] * nptl/Makefile: Add tst-once5.cc. * nptl/pthreadP.h (pthread_cleanup_push, pthread_cleanup_pop): Remove macro redefinitions. * nptl/tst-once5.cc: New test.
Diffstat (limited to 'NEWS')
-rw-r--r-- | NEWS | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/NEWS b/NEWS index 69d9f73932..91320dd429 100644 --- a/NEWS +++ b/NEWS @@ -21,11 +21,11 @@ Version 2.22 18111, 18116, 18125, 18128, 18138, 18185, 18196, 18197, 18206, 18210, 18211, 18217, 18219, 18220, 18221, 18234, 18244, 18245, 18247, 18287, 18319, 18324, 18333, 18346, 18371, 18397, 18409, 18410, 18412, 18418, - 18422, 18434, 18444, 18468, 18469, 18470, 18479, 18483, 18495, 18496, - 18497, 18498, 18502, 18507, 18512, 18513, 18519, 18520, 18522, 18527, - 18528, 18529, 18530, 18532, 18533, 18534, 18536, 18539, 18540, 18542, - 18544, 18545, 18546, 18547, 18549, 18553, 18558, 18569, 18583, 18585, - 18586, 18593, 18594, 18602, 18612, 18613. + 18422, 18434, 18435, 18444, 18468, 18469, 18470, 18479, 18483, 18495, + 18496, 18497, 18498, 18502, 18507, 18512, 18513, 18519, 18520, 18522, + 18527, 18528, 18529, 18530, 18532, 18533, 18534, 18536, 18539, 18540, + 18542, 18544, 18545, 18546, 18547, 18549, 18553, 18558, 18569, 18583, + 18585, 18586, 18593, 18594, 18602, 18612, 18613. * Cache information can be queried via sysconf() function on s390 e.g. with _SC_LEVEL1_ICACHE_SIZE as argument. |