From: Rich Felker Date: Thu, 17 Sep 2015 07:28:44 +0000 (+0000) Subject: new dlstart stage-2 chaining for x86_64 and x32 X-Git-Tag: v1.1.12~49 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=12b0b7d8eab5ec428b779d83bd3c6edad2f31993;p=oweals%2Fmusl.git new dlstart stage-2 chaining for x86_64 and x32 --- diff --git a/arch/x32/reloc.h b/arch/x32/reloc.h index 574f44a7..dc039adf 100644 --- a/arch/x32/reloc.h +++ b/arch/x32/reloc.h @@ -24,3 +24,8 @@ #define CRTJMP(pc,sp) __asm__ __volatile__( \ "mov %1,%%esp ; jmp *%0" : : "r"((uint64_t)(uintptr_t)pc), "r"(sp) : "memory" ) + +#define GETFUNCSYM(fp, sym, got) __asm__ ( \ + ".hidden " #sym "\n" \ + " lea " #sym "(%%rip),%0\n" \ + : "=r"(*fp) : : "memory" ) diff --git a/arch/x86_64/reloc.h b/arch/x86_64/reloc.h index 84c075c3..fac0c0ae 100644 --- a/arch/x86_64/reloc.h +++ b/arch/x86_64/reloc.h @@ -13,3 +13,8 @@ #define CRTJMP(pc,sp) __asm__ __volatile__( \ "mov %1,%%rsp ; jmp *%0" : : "r"(pc), "r"(sp) : "memory" ) + +#define GETFUNCSYM(fp, sym, got) __asm__ ( \ + ".hidden " #sym "\n" \ + " lea " #sym "(%%rip),%0\n" \ + : "=r"(*fp) : : "memory" )