bjorn3 opened issue #5008:
Feature
Support the
tls_value
instruction on riscv64Benefit
Necessary for cg_clif to implement thread local storage.
Implementation
https://github.com/riscv-non-isa/riscv-elf-psabi-doc/blob/master/riscv-elf.adoc#global-dynamic shows the instruction sequence with all relocation necessary for performing a tls access with the global dynamic tls model (the most general model).
__tls_get_addr
here is just a regular function following the riscv C abi. See https://github.com/bytecodealliance/wasmtime/blob/2986f6b0fffd576a2ba88a1fc6cb2db959a1f9e8/cranelift/codegen/src/isa/x64/inst/emit.rs#L3096-L3123 as an example implementation for x86_64 (different instruction sequence, but same principle)Alternatives
None
cc @yuyang-ok
elliottt labeled issue #5008:
Feature
Support the
tls_value
instruction on riscv64Benefit
Necessary for cg_clif to implement thread local storage.
Implementation
https://github.com/riscv-non-isa/riscv-elf-psabi-doc/blob/master/riscv-elf.adoc#global-dynamic shows the instruction sequence with all relocation necessary for performing a tls access with the global dynamic tls model (the most general model).
__tls_get_addr
here is just a regular function following the riscv C abi. See https://github.com/bytecodealliance/wasmtime/blob/2986f6b0fffd576a2ba88a1fc6cb2db959a1f9e8/cranelift/codegen/src/isa/x64/inst/emit.rs#L3096-L3123 as an example implementation for x86_64 (different instruction sequence, but same principle)Alternatives
None
cc @yuyang-ok
afonso360 commented on issue #5008:
This has been implemented as part of #7003
afonso360 closed issue #5008:
Feature
Support the
tls_value
instruction on riscv64Benefit
Necessary for cg_clif to implement thread local storage.
Implementation
https://github.com/riscv-non-isa/riscv-elf-psabi-doc/blob/master/riscv-elf.adoc#global-dynamic shows the instruction sequence with all relocation necessary for performing a tls access with the global dynamic tls model (the most general model).
__tls_get_addr
here is just a regular function following the riscv C abi. See https://github.com/bytecodealliance/wasmtime/blob/2986f6b0fffd576a2ba88a1fc6cb2db959a1f9e8/cranelift/codegen/src/isa/x64/inst/emit.rs#L3096-L3123 as an example implementation for x86_64 (different instruction sequence, but same principle)Alternatives
None
cc @yuyang-ok
Last updated: Jan 24 2025 at 00:11 UTC