tstellar / rpms / llvm

Forked from rpms/llvm 5 years ago
Clone
fa2d0d0
From 04c252cc93fe5905a625773cd174ed6ca7651463 Mon Sep 17 00:00:00 2001
fa2d0d0
From: Will Schmidt <will_schmidt@vnet.ibm.com>
fa2d0d0
Date: Mon, 24 Mar 2014 16:04:15 +0000
fa2d0d0
Subject: [PATCH] [PPC64LE] ELFv2 ABI updates for the .opd section
fa2d0d0
fa2d0d0
[PPC64LE] ELFv2 ABI updates for the .opd section
fa2d0d0
The PPC64 Little Endian (PPC64LE) target supports the ELFv2 ABI, and as
fa2d0d0
such, does not have a ".opd" section.  This is keyed off a _CALL_ELF=2
fa2d0d0
macro check.
fa2d0d0
fa2d0d0
The CALL_ELF check is not clearly documented at this time.  The basis
fa2d0d0
for usage in this patch is from the gcc thread here:
fa2d0d0
http://gcc.gnu.org/ml/gcc-patches/2013-11/msg01144.html
fa2d0d0
fa2d0d0
> Adding comment from Uli:
fa2d0d0
Looks good to me.  I think the old-style JIT doesn't really work
fa2d0d0
anyway for 64-bit, but at least with this patch LLVM will compile
fa2d0d0
and link again on a ppc64le host ...
fa2d0d0
fa2d0d0
fa2d0d0
fa2d0d0
fa2d0d0
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@204614 91177308-0d34-0410-b5e6-96231b3b80d8
fa2d0d0
---
fa2d0d0
 lib/Target/PowerPC/PPCJITInfo.cpp | 5 +++++
fa2d0d0
 1 file changed, 5 insertions(+)
fa2d0d0
fa2d0d0
diff --git a/lib/Target/PowerPC/PPCJITInfo.cpp b/lib/Target/PowerPC/PPCJITInfo.cpp
fa2d0d0
index 5e3a48d..227919c 100644
fa2d0d0
--- a/lib/Target/PowerPC/PPCJITInfo.cpp
fa2d0d0
+++ b/lib/Target/PowerPC/PPCJITInfo.cpp
fa2d0d0
@@ -214,6 +214,10 @@ asm(
fa2d0d0
     ".text\n"
fa2d0d0
     ".align 2\n"
fa2d0d0
     ".globl PPC64CompilationCallback\n"
fa2d0d0
+#if _CALL_ELF == 2
fa2d0d0
+    ".type PPC64CompilationCallback,@function\n"
fa2d0d0
+"PPC64CompilationCallback:\n"
fa2d0d0
+#else
fa2d0d0
     ".section \".opd\",\"aw\",@progbits\n"
fa2d0d0
     ".align 3\n"
fa2d0d0
 "PPC64CompilationCallback:\n"
fa2d0d0
@@ -223,6 +227,7 @@ asm(
fa2d0d0
     ".align 4\n"
fa2d0d0
     ".type PPC64CompilationCallback,@function\n"
fa2d0d0
 ".L.PPC64CompilationCallback:\n"
fa2d0d0
+#endif
fa2d0d0
 #  else
fa2d0d0
 asm(
fa2d0d0
     ".text\n"
fa2d0d0
-- 
fa2d0d0
1.9.3
fa2d0d0