summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog15
-rw-r--r--stdlib/tst-quick_exit.cc17
-rw-r--r--stdlib/tst-thread-quick_exit.cc36
3 files changed, 53 insertions, 15 deletions
diff --git a/ChangeLog b/ChangeLog
index fd472f9577..e5a6209053 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,18 @@
+2016-06-09 Florian Weimer <fweimer@redhat.com>
+
+ Prevent GCC 6 <cstdlib> from including /usr/include/stdlib.h.
+ * stdlib/tst-quick_exit.cc: Include <stdlib.h> instead of
+ <cstdlib>.
+ (optimization_barrier): New.
+ (do_test): Use it. Call quick_exit in the global namespace.
+ * stdlib/tst-thread-quick_exit.cc: Include <stdlib.h>, <pthread.h>
+ instead of <cstdlib>, <thread>.
+ (optimization_barrier): New.
+ (non_main_thread): Adjust declaration. Call optimization_barrier.
+ Call quick_exit in the global namespace.
+ (do_test): Call optimization_barrier. Use pthread_create,
+ pthread_join instead of std::thread.
+
2016-06-09 Andreas Schwab <schwab@suse.de>
[BZ #19755]
diff --git a/stdlib/tst-quick_exit.cc b/stdlib/tst-quick_exit.cc
index c4a15a901c..6fb99c452a 100644
--- a/stdlib/tst-quick_exit.cc
+++ b/stdlib/tst-quick_exit.cc
@@ -15,24 +15,31 @@
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */
-#include <cstdlib>
+
+#include <stdlib.h>
struct A
{
- ~A() { abort(); }
+ ~A () { abort (); }
};
thread_local A a;
+void
+__attribute__ ((noinline, noclone))
+optimization_barrier (A &)
+{
+}
+
static int
-do_test()
+do_test ()
{
- (void)a;
+ optimization_barrier (a);
/* The C++11 standard in 18.5.12 says:
"Objects shall not be destroyed as a result of calling
quick_exit."
If quick_exit calls the destructors the test aborts. */
- std::quick_exit(0);
+ quick_exit (0);
return 0;
}
diff --git a/stdlib/tst-thread-quick_exit.cc b/stdlib/tst-thread-quick_exit.cc
index 307d2a2430..057cc044ef 100644
--- a/stdlib/tst-thread-quick_exit.cc
+++ b/stdlib/tst-thread-quick_exit.cc
@@ -15,35 +15,51 @@
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */
-#include <cstdlib>
-#include <thread>
+
+#include <errno.h>
+#include <pthread.h>
+#include <stdio.h>
+#include <stdlib.h>
struct A
{
- ~A() { abort(); }
+ ~A () { abort (); }
};
thread_local A a1;
thread_local A a2;
+void
+__attribute__ ((noinline, noclone))
+optimization_barrier (A &)
+{
+}
+
/* Call std::quick_exit from a non-main thread. */
-void non_main_thread (void)
+void *
+non_main_thread (void *)
{
- (void)a1;
+ optimization_barrier (a1);
/* The C++11 standard in 18.5.12 says:
"Objects shall not be destroyed as a result of calling
quick_exit."
If quick_exit calls the destructors the test aborts. */
- std::quick_exit (0);
+ quick_exit (0);
}
static int
do_test()
{
- (void)a2;
- std::thread th (non_main_thread);
- th.join ();
- return 0;
+ optimization_barrier (a2);
+ pthread_t thr;
+ int ret = pthread_create (&thr, NULL, non_main_thread, NULL);
+ if (ret != 0)
+ {
+ errno = ret;
+ printf ("error: pthread_create: %m\n");
+ }
+ pthread_join (thr, NULL);
+ return 1;
}
#define TEST_FUNCTION do_test ()