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

index 8aa0285..9b40e3d 100644 (file)
 
 #define CRTJMP(pc,sp) __asm__ __volatile__( \
        "move $sp,%1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )
+
+#define GETFUNCSYM(fp, sym, got) __asm__ ( \
+       ".hidden " #sym "\n" \
+       ".set push \n" \
+       ".set noreorder \n" \
+       "       bal 1f \n" \
+       "        nop \n" \
+       "       .gpword . \n" \
+       "       .gpword " #sym " \n" \
+       "1:     lw %0, ($ra) \n" \
+       "       subu %0, $ra, %0 \n" \
+       "       lw $ra, 4($ra) \n" \
+       "       addu %0, %0, $ra \n" \
+       ".set pop \n" \
+       : "=r"(*(fp)) : : "memory", "ra" )