[llvm] r295387 - Bug 31948: Fix assertion when bitcasting constantexpr pointers

Matt Arsenault via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 16 16:32:20 PST 2017


Author: arsenm
Date: Thu Feb 16 18:32:19 2017
New Revision: 295387

URL: http://llvm.org/viewvc/llvm-project?rev=295387&view=rev
Log:
Bug 31948: Fix assertion when bitcasting constantexpr pointers

Added:
    llvm/trunk/test/Transforms/InferAddressSpaces/AMDGPU/lit.local.cfg
      - copied, changed from r295383, llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg
    llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/
    llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/bug31948.ll
    llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/lit.local.cfg
Removed:
    llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg
Modified:
    llvm/trunk/lib/Transforms/Scalar/InferAddressSpaces.cpp

Modified: llvm/trunk/lib/Transforms/Scalar/InferAddressSpaces.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/InferAddressSpaces.cpp?rev=295387&r1=295386&r2=295387&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/InferAddressSpaces.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/InferAddressSpaces.cpp Thu Feb 16 18:32:19 2017
@@ -448,6 +448,12 @@ static Value *cloneConstantExprWithNewAd
     return ConstantExpr::getBitCast(CE->getOperand(0), TargetType);
   }
 
+  if (CE->getOpcode() == Instruction::BitCast) {
+    if (Value *NewOperand = ValueWithNewAddrSpace.lookup(CE->getOperand(0)))
+      return ConstantExpr::getBitCast(cast<Constant>(NewOperand), TargetType);
+    return ConstantExpr::getAddrSpaceCast(CE, TargetType);
+  }
+
   if (CE->getOpcode() == Instruction::Select) {
     Constant *Src0 = CE->getOperand(1);
     Constant *Src1 = CE->getOperand(2);

Copied: llvm/trunk/test/Transforms/InferAddressSpaces/AMDGPU/lit.local.cfg (from r295383, llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg)
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InferAddressSpaces/AMDGPU/lit.local.cfg?p2=llvm/trunk/test/Transforms/InferAddressSpaces/AMDGPU/lit.local.cfg&p1=llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg&r1=295383&r2=295387&rev=295387&view=diff
==============================================================================
    (empty)

Added: llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/bug31948.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/bug31948.ll?rev=295387&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/bug31948.ll (added)
+++ llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/bug31948.ll Thu Feb 16 18:32:19 2017
@@ -0,0 +1,24 @@
+; RUN: opt -S -mtriple=nvptx64-nvidia-cuda -infer-address-spaces %s | FileCheck %s
+
+target datalayout = "e-i64:64-v16:16-v32:32-n16:32:64"
+
+%struct.bar = type { float, float* }
+
+ at var1 = local_unnamed_addr addrspace(3) externally_initialized global %struct.bar undef, align 8
+
+; CHECK-LABEL: @bug31948(
+; CHECK: %tmp = load float*, float* addrspace(3)* getelementptr inbounds (%struct.bar, %struct.bar addrspace(3)* @var1, i64 0, i32 1), align 8
+; CHECK: %tmp1 = load float, float* %tmp, align 4
+; CHECK: store float %conv1, float* %tmp, align 4
+; CHECK: store i32 32, i32 addrspace(3)* addrspacecast (i32* bitcast (float** getelementptr (%struct.bar, %struct.bar* addrspacecast (%struct.bar addrspace(3)* @var1 to %struct.bar*), i64 0, i32 1) to i32*) to i32 addrspace(3)*), align 4
+define void @bug31948(float %a, float* nocapture readnone %x, float* nocapture readnone %y) local_unnamed_addr #0 {
+entry:
+  %tmp = load float*, float** getelementptr (%struct.bar, %struct.bar* addrspacecast (%struct.bar addrspace(3)* @var1 to %struct.bar*), i64 0, i32 1), align 8
+  %tmp1 = load float, float* %tmp, align 4
+  %conv1 = fadd float %tmp1, 1.000000e+00
+  store float %conv1, float* %tmp, align 4
+  store i32 32, i32* bitcast (float** getelementptr (%struct.bar, %struct.bar* addrspacecast (%struct.bar addrspace(3)* @var1 to %struct.bar*), i64 0, i32 1) to i32*), align 4
+  ret void
+}
+
+attributes #0 = { norecurse nounwind }

Added: llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/lit.local.cfg
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/lit.local.cfg?rev=295387&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/lit.local.cfg (added)
+++ llvm/trunk/test/Transforms/InferAddressSpaces/NVPTX/lit.local.cfg Thu Feb 16 18:32:19 2017
@@ -0,0 +1,2 @@
+if not 'NVPTX' in config.root.targets:
+    config.unsupported = True

Removed: llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg?rev=295386&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg (original)
+++ llvm/trunk/test/Transforms/InferAddressSpaces/lit.local.cfg (removed)
@@ -1,3 +0,0 @@
-if not 'AMDGPU' in config.root.targets:
-    config.unsupported = True
-




More information about the llvm-commits mailing list