BUILD: thread: use initcall instead of a constructor
The constructor present there could be replaced with an initcall.
This one is set at level STG_PREPARE because it also zeroes the
lock_stats, and it's a bit odd that it could possibly have been
scheduled to run after other constructors that might already
preset some of these locks by accident.
diff --git a/src/thread.c b/src/thread.c
index a04e914..9d601cc 100644
--- a/src/thread.c
+++ b/src/thread.c
@@ -951,7 +951,6 @@
pthread_join(dummy_thread, NULL);
}
-__attribute__((constructor))
static void __thread_init(void)
{
char *ptr = NULL;
@@ -975,6 +974,7 @@
memset(lock_stats, 0, sizeof(lock_stats));
#endif
}
+INITCALL0(STG_PREPARE, __thread_init);
#else