summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2014-05-25 12:49:07 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2014-05-25 12:49:07 +0000
commit4a04c4b69c75775b5bfb04d3b3743dde171c4608 (patch)
tree6ba9b83ad8d2f5e05e5aedceaa4642c32b48e052
parentd234b0f08cf66d67ea90a016e472d65e0057ef5d (diff)
downloadbcm5719-llvm-4a04c4b69c75775b5bfb04d3b3743dde171c4608.tar.gz
bcm5719-llvm-4a04c4b69c75775b5bfb04d3b3743dde171c4608.zip
Emit data or code export directives based on the type.
Currently we look at the Aliasee to decide what type of export directive to use. It seems better to use the type of the alias directly. This is similar to how we handle the alias having the same address but other attributes (linkage, visibility) from the aliasee. With this patch it is now possible to do things like target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-pc-windows-msvc" @foo = global [6 x i8] c"\B8*\00\00\00\C3", section ".text", align 16 @f = dllexport alias i32 (), [6 x i8]* @foo !llvm.module.flags = !{!0} !0 = metadata !{i32 6, metadata !"Linker Options", metadata !1} !1 = metadata !{metadata !2, metadata !3} !2 = metadata !{metadata !"/DEFAULTLIB:libcmt.lib"} !3 = metadata !{metadata !"/DEFAULTLIB:oldnames.lib"} llvm-svn: 209600
-rw-r--r--llvm/lib/Target/X86/X86AsmPrinter.cpp10
-rw-r--r--llvm/test/CodeGen/X86/dllexport-x86_64.ll4
2 files changed, 7 insertions, 7 deletions
diff --git a/llvm/lib/Target/X86/X86AsmPrinter.cpp b/llvm/lib/Target/X86/X86AsmPrinter.cpp
index 68e136bd776..1dca5689ade 100644
--- a/llvm/lib/Target/X86/X86AsmPrinter.cpp
+++ b/llvm/lib/Target/X86/X86AsmPrinter.cpp
@@ -670,16 +670,12 @@ void X86AsmPrinter::EmitEndOfAsmFile(Module &M) {
DLLExportedGlobals.push_back(getSymbol(&Global));
for (const auto &Alias : M.aliases()) {
- const GlobalValue *GV = &Alias;
- if (!GV->hasDLLExportStorageClass())
+ if (!Alias.hasDLLExportStorageClass())
continue;
- while (const GlobalAlias *A = dyn_cast<GlobalAlias>(GV))
- GV = A->getAliasee();
-
- if (isa<Function>(GV))
+ if (Alias.getType()->getElementType()->isFunctionTy())
DLLExportedFns.push_back(getSymbol(&Alias));
- else if (isa<GlobalVariable>(GV))
+ else
DLLExportedGlobals.push_back(getSymbol(&Alias));
}
diff --git a/llvm/test/CodeGen/X86/dllexport-x86_64.ll b/llvm/test/CodeGen/X86/dllexport-x86_64.ll
index bd099b04223..1347664c71f 100644
--- a/llvm/test/CodeGen/X86/dllexport-x86_64.ll
+++ b/llvm/test/CodeGen/X86/dllexport-x86_64.ll
@@ -72,6 +72,8 @@ define weak_odr dllexport void @weak1() {
; CHECK: weak_alias = f1
@weak_alias = dllexport alias weak_odr void()* @f1
+@blob = global [6 x i8] c"\B8*\00\00\00\C3", section ".text", align 16
+@blob_alias = dllexport alias i32 (), [6 x i8]* @blob
; CHECK: .section .drectve
; WIN32: /EXPORT:Var1,DATA"
@@ -88,6 +90,7 @@ define weak_odr dllexport void @weak1() {
; WIN32: /EXPORT:alias2"
; WIN32: /EXPORT:alias3"
; WIN32: /EXPORT:weak_alias"
+; WIN32: /EXPORT:blob_alias"
; MINGW: -export:Var1,data"
; MINGW: -export:Var2,data"
; MINGW: -export:Var3,data"
@@ -102,3 +105,4 @@ define weak_odr dllexport void @weak1() {
; MINGW: -export:alias2"
; MINGW: -export:alias3"
; MINGW: -export:weak_alias"
+; MINGW: -export:blob_alias"
OpenPOWER on IntegriCloud