[PATCH] Fix addrspacecast with metadata globals
Matt Arsenault
Matthew.Arsenault at amd.com
Fri Dec 13 09:52:38 PST 2013
The actual pointer isn't important, and all of the array elements need to be the same i8*, so use addrspacecast in llvm.used etc. when appropriate.
http://llvm-reviews.chandlerc.com/D2402
Files:
lib/Transforms/IPO/GlobalOpt.cpp
test/Transforms/GlobalOpt/alias-used-address-space.ll
Index: lib/Transforms/IPO/GlobalOpt.cpp
===================================================================
--- lib/Transforms/IPO/GlobalOpt.cpp
+++ lib/Transforms/IPO/GlobalOpt.cpp
@@ -2860,12 +2860,14 @@
return;
}
- SmallVector<llvm::Constant *, 8> UsedArray;
- PointerType *Int8PtrTy = Type::getInt8PtrTy(V.getContext());
+ // Type of pointer to the array of pointers.
+ PointerType *Int8PtrTy = Type::getInt8PtrTy(V.getContext(), 0);
+ SmallVector<llvm::Constant *, 8> UsedArray;
for (SmallPtrSet<GlobalValue *, 8>::iterator I = Init.begin(), E = Init.end();
I != E; ++I) {
- Constant *Cast = llvm::ConstantExpr::getBitCast(*I, Int8PtrTy);
+ Constant *Cast
+ = ConstantExpr::getPointerBitCastOrAddrSpaceCast(*I, Int8PtrTy);
UsedArray.push_back(Cast);
}
// Sort to get deterministic order.
Index: test/Transforms/GlobalOpt/alias-used-address-space.ll
===================================================================
--- test/Transforms/GlobalOpt/alias-used-address-space.ll
+++ test/Transforms/GlobalOpt/alias-used-address-space.ll
@@ -1,18 +1,26 @@
-; RUN: opt < %s -globalopt -S | FileCheck %s
+; RUN: opt -S -globalopt < %s | FileCheck %s
target datalayout = "p:32:32:32-p1:16:16:16"
@c = addrspace(1) global i8 42
@i = internal addrspace(1) global i8 42
-; CHECK: @ia = internal global i8 42
+
+; CHECK: @ia = internal addrspace(1) global i8 42
@ia = alias internal i8 addrspace(1)* @i
+
+ at llvm.used = appending global [1 x i8*] [i8* addrspacecast (i8 addrspace(1)* @ca to i8*)], section "llvm.metadata"
+; CHECK-DAG: @llvm.used = appending global [1 x i8*] [i8* addrspacecast (i8 addrspace(1)* @ca to i8*)], section "llvm.metadata"
+
+ at llvm.compiler.used = appending global [2 x i8*] [i8* addrspacecast(i8 addrspace(1)* @ia to i8*), i8* addrspacecast (i8 addrspace(1)* @i to i8*)], section "llvm.metadata"
+; CHECK-DAG: @llvm.compiler.used = appending global [1 x i8*] [i8* addrspacecast (i8 addrspace(1)* @ia to i8*)], section "llvm.metadata"
+
+ at sameAsUsed = global [1 x i8*] [i8* addrspacecast(i8 addrspace(1)* @ca to i8*)]
+; CHECK-DAG: @sameAsUsed = global [1 x i8*] [i8* addrspacecast (i8 addrspace(1)* @c to i8*)]
+
@ca = alias internal i8 addrspace(1)* @c
-; CHECK: @ca = alias internal i8* @c
+; CHECK: @ca = alias internal i8 addrspace(1)* @c
define i8 addrspace(1)* @h() {
ret i8 addrspace(1)* @ca
}
-
-
- at llvm.used = appending global [1 x i8 addrspace(1)*] [i8 addrspace(1)* @ca], section "llvm.metadata"
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D2402.1.patch
Type: text/x-patch
Size: 2496 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20131213/d9d36c28/attachment.bin>
More information about the llvm-commits
mailing list