Index: fusl/arch/powerpc/reloc.h |
diff --git a/fusl/arch/powerpc/reloc.h b/fusl/arch/powerpc/reloc.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b8b6589f988e42519e7e05c3195ad054f0817dc7 |
--- /dev/null |
+++ b/fusl/arch/powerpc/reloc.h |
@@ -0,0 +1,24 @@ |
+#define LDSO_ARCH "powerpc" |
+ |
+#define TPOFF_K (-0x7000) |
+ |
+#define REL_SYMBOLIC R_PPC_ADDR32 |
+#define REL_GOT R_PPC_GLOB_DAT |
+#define REL_PLT R_PPC_JMP_SLOT |
+#define REL_RELATIVE R_PPC_RELATIVE |
+#define REL_COPY R_PPC_COPY |
+#define REL_DTPMOD R_PPC_DTPMOD32 |
+#define REL_DTPOFF R_PPC_DTPREL32 |
+#define REL_TPOFF R_PPC_TPREL32 |
+ |
+#define CRTJMP(pc,sp) __asm__ __volatile__( \ |
+ "mr 1,%1 ; mtlr %0 ; blr" : : "r"(pc), "r"(sp) : "memory" ) |
+ |
+#define GETFUNCSYM(fp, sym, got) __asm__ ( \ |
+ ".hidden " #sym " \n" \ |
+ " bl 1f \n" \ |
+ " .long " #sym "-. \n" \ |
+ "1: mflr %1 \n" \ |
+ " lwz %0, 0(%1) \n" \ |
+ " add %0, %0, %1 \n" \ |
+ : "=r"(*(fp)), "=r"((int){0}) : : "memory", "lr" ) |