sel4_initialize_tls/
set_thread_pointer.rs1use core::arch::asm;
8
9use cfg_if::cfg_if;
10
11pub type SetThreadPointerFn = unsafe extern "C" fn(thread_pointer: usize);
12
13pub const DEFAULT_SET_THREAD_POINTER_FN: SetThreadPointerFn = default_set_thread_pointer;
14
15unsafe extern "C" fn default_set_thread_pointer(thread_pointer: usize) {
16 let val = thread_pointer;
17
18 unsafe {
19 cfg_if! {
20 if #[cfg(target_arch = "aarch64")] {
21 asm!("msr tpidr_el0, {val}", val = in(reg) val);
22 } else if #[cfg(target_arch = "arm")] {
23 asm!("mcr p15, 0, {val}, c13, c0, 2", val = in(reg) val); } else if #[cfg(any(target_arch = "riscv32", target_arch = "riscv64"))] {
25 asm!("mv tp, {val}", val = in(reg) val);
26 } else if #[cfg(target_arch = "x86_64")] {
27 asm!("wrfsbase {val}", val = in(reg) val);
28 } else {
29 compile_error!("unsupported architecture");
30 }
31 }
32 }
33}