Searched refs:gsbase (Results 1 – 11 of 11) sorted by relevance
20 extern void x86_gsbase_write_task(struct task_struct *task, unsigned long gsbase);35 unsigned long gsbase; in rdgsbase() local37 asm volatile("rdgsbase %0" : "=r" (gsbase) :: "memory"); in rdgsbase()39 return gsbase; in rdgsbase()47 static __always_inline void wrgsbase(unsigned long gsbase) in wrgsbase() argument49 asm volatile("wrgsbase %0" :: "r" (gsbase) : "memory"); in wrgsbase()77 extern void x86_gsbase_write_cpu_inactive(unsigned long gsbase);
163 t->fsbase = t->gsbase = 0; in elf_common_init()
432 unsigned long gsbase; member
165 unsigned long gsbase; in __rdgsbase_inactive() local171 gsbase = rdgsbase(); in __rdgsbase_inactive()175 rdmsrl(MSR_KERNEL_GS_BASE, gsbase); in __rdgsbase_inactive()179 return gsbase; in __rdgsbase_inactive()190 static noinstr void __wrgsbase_inactive(unsigned long gsbase) in __wrgsbase_inactive() argument196 wrgsbase(gsbase); in __wrgsbase_inactive()200 wrmsrl(MSR_KERNEL_GS_BASE, gsbase); in __wrgsbase_inactive()246 prev_p->thread.gsbase = 0; in save_base_legacy()261 task->thread.gsbase = __rdgsbase_inactive(); in save_fsgs()379 __wrgsbase_inactive(next->gsbase); in x86_fsgsbase_load()[all …]
179 p->thread.gsbase = info.base_addr; in do_set_thread_area()
186 p->thread.gsbase = current->thread.gsbase; in copy_thread()
905 child->thread.gsbase = in putreg32()
91 unsigned long gsbase; in rdgsbase() local93 asm volatile("rdgsbase %0" : "=r" (gsbase) :: "memory"); in rdgsbase()95 return gsbase; in rdgsbase()107 static inline void wrgsbase(unsigned long gsbase) in wrgsbase() argument109 asm volatile("wrgsbase %0" :: "r" (gsbase) : "memory"); in wrgsbase()
100 must use idtentry with paranoid=1 to handle gsbase correctly. This103 - Interrupt entry will use the slower gsbase check.
59 arch_prctl(ARCH_GET_GS, &gsbase);64 arch_prctl(ARCH_SET_GS, gsbase);
1343 vmx->msr_host_kernel_gs_base = current->thread.gsbase; in vmx_prepare_switch_to_guest()