From 300cfbf252b5798c696a9ccd0abf4ed474260de6 Mon Sep 17 00:00:00 2001 From: Koakuma Date: Fri, 28 Aug 2020 21:48:10 +0700 Subject: [PATCH] Add TLS implementation for sparc64 --- lib/std/os/linux/tls.zig | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/lib/std/os/linux/tls.zig b/lib/std/os/linux/tls.zig index 69e7816f13..4f2ada90b9 100644 --- a/lib/std/os/linux/tls.zig +++ b/lib/std/os/linux/tls.zig @@ -54,7 +54,7 @@ const TLSVariant = enum { const tls_variant = switch (builtin.arch) { .arm, .armeb, .aarch64, .aarch64_be, .riscv32, .riscv64, .mips, .mipsel, .powerpc, .powerpc64, .powerpc64le => TLSVariant.VariantI, - .x86_64, .i386 => TLSVariant.VariantII, + .x86_64, .i386, .sparcv9 => TLSVariant.VariantII, else => @compileError("undefined tls_variant for this architecture"), }; @@ -168,6 +168,11 @@ pub fn setThreadPointer(addr: usize) void { .powerpc, .powerpc64, .powerpc64le => { asm volatile ( \\ mr 13, %[addr] + ); + }, + .sparcv9 => { + asm volatile ( + \\ mov %[addr], %%g7 : : [addr] "r" (addr) );