]> xenbits.xensource.com Git - xen.git/commitdiff
x86/ELF: don't store function pointer in elf_core_save_regs()
authorJan Beulich <jbeulich@suse.com>
Tue, 29 Sep 2020 08:51:54 +0000 (10:51 +0200)
committerJan Beulich <jbeulich@suse.com>
Tue, 29 Sep 2020 08:51:54 +0000 (10:51 +0200)
This keeps at least gcc 10 from generating a separate function instance
in common/kexec.o alongside the inlining of the function in its sole
caller. I also think putting the address of the actual code storing the
registers is a better indication to consumers than that of an otherwise
unreferenced function.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Andrew Cooper <andrew.cooper3@citrix.com>
xen/include/asm-x86/x86_64/elf.h

index 09b286422d284077a7c4c300f132d0861259cb27..43c9cf3a3f92d490a62b9c2c8634e1c3177fbad2 100644 (file)
@@ -54,7 +54,7 @@ static inline void elf_core_save_regs(ELF_Gregset *core_regs,
     asm volatile("movq %%rsi,%0" : "=m"(core_regs->rsi));
     asm volatile("movq %%rdi,%0" : "=m"(core_regs->rdi));
     /* orig_rax not filled in for now */
-    core_regs->rip = (unsigned long)elf_core_save_regs;
+    asm ( "call 0f; 0: popq %0" : "=m" (core_regs->rip) );
     core_regs->cs = read_sreg(cs);
     asm volatile("pushfq; popq %0" :"=m"(core_regs->rflags));
     asm volatile("movq %%rsp,%0" : "=m"(core_regs->rsp));