new dlstart stage-2 chaining for x86_64 and x32
authorRich Felker <dalias@aerifal.cx>
Thu, 17 Sep 2015 07:28:44 +0000 (07:28 +0000)
committerRich Felker <dalias@aerifal.cx>
Thu, 17 Sep 2015 07:28:44 +0000 (07:28 +0000)
arch/x32/reloc.h
arch/x86_64/reloc.h

index 574f44a777227fa9d0faf3e948a8e4838772651f..dc039adf5b455130af4a4d5af42a722943229bc0 100644 (file)
@@ -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" )
index 84c075c37e3dae6e7621d5a12b0f8ed1e7acc0cd..fac0c0ae3e779132766a158455e8cbb6c037c723 100644 (file)
@@ -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" )