commit 228a0937a2bb761b3a63d98ddda5402a1f594fe8 (tree)
parent 7dab3ae135bbe388b412f06bcd8910b86565635e
Author: Andrew Kelley <andrew@ziglang.org>
Date: Thu, 17 Dec 2020 21:09:54 -0700
memory fences to make sure TLS init happens
Diffstat:
1 file changed, 2 insertions(+), 0 deletions(-)
diff --git a/lib/std/start.zig b/lib/std/start.zig
@@ -206,6 +206,7 @@ fn posixCallMainAndExit() noreturn {
// Do this as early as possible, the aux vector is needed
if (builtin.position_independent_executable) {
@import("os/linux/start_pie.zig").apply_relocations();
+ @fence(.SeqCst);
}
// Initialize the TLS area. We do a runtime check here to make sure
@@ -214,6 +215,7 @@ fn posixCallMainAndExit() noreturn {
const is_dynamic = @import("dynamic_library.zig").get_DYNAMIC() != null;
if (!is_dynamic) {
std.os.linux.tls.initStaticTLS();
+ @fence(.SeqCst);
}
{