[RS4GC] Add an assert which fails if there is a (yet unsupported) addrspacecast.
authorManuel Jacob <me@manueljacob.de>
Mon, 21 Dec 2015 01:26:46 +0000 (01:26 +0000)
committerManuel Jacob <me@manueljacob.de>
Mon, 21 Dec 2015 01:26:46 +0000 (01:26 +0000)
The slightly strange indentation comes from clang-format.

llvm-svn: 256132

llvm/lib/Transforms/Scalar/RewriteStatepointsForGC.cpp

index 16ee5bb..049a7fc 100644 (file)
@@ -454,6 +454,11 @@ static BaseDefiningValueResult findBaseDefiningValue(Value *I) {
 
   if (CastInst *CI = dyn_cast<CastInst>(I)) {
     Value *Def = CI->stripPointerCasts();
+    // If stripping pointer casts changes the address space there is an
+    // addrspacecast in between.
+    assert(cast<PointerType>(Def->getType())->getAddressSpace() ==
+               cast<PointerType>(CI->getType())->getAddressSpace() &&
+           "unsupported addrspacecast");
     // If we find a cast instruction here, it means we've found a cast which is
     // not simply a pointer cast (i.e. an inttoptr).  We don't know how to
     // handle int->ptr conversion.