[PATCH] D106098: [infer-address-spaces] Handle complex non-pointer constexpr arguments.
Artem Belevich via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 15 13:53:38 PDT 2021
tra updated this revision to Diff 359123.
tra edited the summary of this revision.
tra added a comment.
Added checks to the test.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D106098/new/
https://reviews.llvm.org/D106098
Files:
llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
llvm/test/Transforms/InferAddressSpaces/NVPTX/clone_constexpr.ll
Index: llvm/test/Transforms/InferAddressSpaces/NVPTX/clone_constexpr.ll
===================================================================
--- llvm/test/Transforms/InferAddressSpaces/NVPTX/clone_constexpr.ll
+++ llvm/test/Transforms/InferAddressSpaces/NVPTX/clone_constexpr.ll
@@ -31,6 +31,51 @@
declare void @f2(i64*, i64) local_unnamed_addr #0
declare i32 @llvm.nvvm.read.ptx.sreg.tid.x() #1
+; Make sure we can clone GEP which uses complex constant expressions as indices.
+; https://bugs.llvm.org/show_bug.cgi?id=51099
+ at g2 = internal addrspace(3) global [128 x i8] undef, align 1
+
+; CHECK-LABEL: @complex_ce(
+; CHECK: %0 = load float, float addrspace(3)* bitcast
+; CHECK-SAME: i8 addrspace(3)* getelementptr (i8,
+; CHECK-SAME: i8 addrspace(3)* getelementptr inbounds ([128 x i8], [128 x i8] addrspace(3)* @g2, i64 0, i64 0),
+; CHECK-SAME: i64 sub (
+; CHECK-SAME i64 ptrtoint (
+; CHECK-SAME i8 addrspace(3)* getelementptr inbounds ([128 x i8], [128 x i8] addrspace(3)* @g2, i64 0, i64 123) to i64),
+; CHECK-SAME: i64 ptrtoint (
+; CHECK-SAME: i8 addrspace(3)* getelementptr inbounds ([128 x i8], [128 x i8] addrspace(3)* @g2, i64 2, i64 0) to i64)))
+; CHECK-SAME: to float addrspace(3)*)
+; Function Attrs: norecurse nounwind
+define float @complex_ce(i8* nocapture readnone %a, i8* nocapture readnone %b, i8* nocapture readnone %c) local_unnamed_addr #0 {
+entry:
+ %0 = load float, float* bitcast (
+ i8* getelementptr (
+ i8, i8* getelementptr inbounds (
+ [128 x i8],
+ [128 x i8]* addrspacecast ([128 x i8] addrspace(3)* @g2 to [128 x i8]*),
+ i64 0,
+ i64 0),
+ i64 sub (
+ i64 ptrtoint (
+ i8* getelementptr inbounds (
+ [128 x i8],
+ [128 x i8]* addrspacecast ([128 x i8] addrspace(3)* @g2 to [128 x i8]*),
+ i64 0,
+ i64 123)
+ to i64),
+ i64 ptrtoint (
+ i8* getelementptr inbounds (
+ [128 x i8],
+ [128 x i8]* addrspacecast ([128 x i8] addrspace(3)* @g2 to [128 x i8]*),
+ i64 2,
+ i64 0)
+ to i64)))
+ to float*), align 4
+ ret float %0
+}
+
+
+
attributes #0 = { convergent nounwind }
attributes #1 = { nounwind readnone }
attributes #2 = { nounwind }
Index: llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
===================================================================
--- llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
+++ llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
@@ -635,8 +635,10 @@
ConstantExpr *CE, unsigned NewAddrSpace,
const ValueToValueMapTy &ValueWithNewAddrSpace, const DataLayout *DL,
const TargetTransformInfo *TTI) {
- Type *TargetType = PointerType::getWithSamePointeeType(
- cast<PointerType>(CE->getType()), NewAddrSpace);
+ Type *TargetType = CE->getType()->isPointerTy()
+ ? PointerType::getWithSamePointeeType(
+ cast<PointerType>(CE->getType()), NewAddrSpace)
+ : CE->getType();
if (CE->getOpcode() == Instruction::AddrSpaceCast) {
// Because CE is flat, the source address space must be specific.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D106098.359123.patch
Type: text/x-patch
Size: 3145 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210715/bd502783/attachment.bin>
More information about the llvm-commits
mailing list