]> granicus.if.org Git - clang/commitdiff
Handle CK_BitCast in EmitCastLValue.
authorAnders Carlsson <andersca@mac.com>
Sat, 14 Nov 2009 21:21:42 +0000 (21:21 +0000)
committerAnders Carlsson <andersca@mac.com>
Sat, 14 Nov 2009 21:21:42 +0000 (21:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@88810 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExpr.cpp
test/CodeGenCXX/reinterpret-cast.cpp

index c297903a69cf03cccd520e1e51fa642ea78f7167..c446c0368972d5a1f7894f643f69fb0a0f23aaff 100644 (file)
@@ -1302,7 +1302,7 @@ LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
       if (ICE->isLvalueCast())
         return EmitLValue(E->getSubExpr());
     
-    assert(0 && "Unhandled cast!");
+    assert(false && "Unhandled cast!");
       
   case CastExpr::CK_NoOp:
   case CastExpr::CK_ConstructorConversion:
@@ -1327,13 +1327,22 @@ LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
     
     return LValue::MakeAddr(Base, MakeQualifiers(E->getType()));
   }
-
   case CastExpr::CK_ToUnion: {
     llvm::Value *Temp = CreateTempAlloca(ConvertType(E->getType()));
     EmitAnyExpr(E->getSubExpr(), Temp, false);
 
     return LValue::MakeAddr(Temp, MakeQualifiers(E->getType()));
-    }
+  }
+  case CastExpr::CK_BitCast: {
+    // This must be a reinterpret_cast.
+    const CXXReinterpretCastExpr *CE = cast<CXXReinterpretCastExpr>(E);
+    
+    LValue LV = EmitLValue(E->getSubExpr());
+    llvm::Value *V = Builder.CreateBitCast(LV.getAddress(),
+                                           ConvertType(CE->getTypeAsWritten()));
+    return LValue::MakeAddr(V, MakeQualifiers(E->getType()));
+  }
+
   }
 }
 
index 25be9b994828779d1edbd54c64de9765e24dfc47..58a980d5288c746685667f4a569443dc0dd182d7 100644 (file)
@@ -10,3 +10,8 @@ unsigned long f2() {
 unsigned long f3(void *p) {
   return reinterpret_cast<unsigned long>(p);
 }
+
+void f4(int*&);
+void f5(void*& u) {
+  f4(reinterpret_cast<int*&>(u));
+}
\ No newline at end of file