aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-09-22 22:00:46 +0000
committerAnders Carlsson <andersca@mac.com>2009-09-22 22:00:46 +0000
commit592a2bbc1945358ab8ebf0d74c57f0b23c4434c0 (patch)
treea27fedeb3ca38e1ca1fd1f605f56673b9dda4555 /lib/CodeGen
parentdfd0330267742862342976eb7f2d5ef305790df4 (diff)
No need to null check implicit lvalue cast exprs.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@82580 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r--lib/CodeGen/CGExprScalar.cpp23
1 files changed, 15 insertions, 8 deletions
diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp
index 308376c179..1e923a9047 100644
--- a/lib/CodeGen/CGExprScalar.cpp
+++ b/lib/CodeGen/CGExprScalar.cpp
@@ -231,9 +231,9 @@ public:
if (E->getType()->isVariablyModifiedType())
CGF.EmitVLASize(E->getType());
- return EmitCastExpr(E->getSubExpr(), E->getType(), E->getCastKind());
+ return EmitCastExpr(E);
}
- Value *EmitCastExpr(const Expr *E, QualType T, CastExpr::CastKind Kind);
+ Value *EmitCastExpr(const CastExpr *E);
Value *VisitCallExpr(const CallExpr *E) {
if (E->getCallReturnType()->isReferenceType())
@@ -618,8 +618,11 @@ Value *ScalarExprEmitter::VisitArraySubscriptExpr(ArraySubscriptExpr *E) {
// VisitCastExpr - Emit code for an explicit or implicit cast. Implicit casts
// have to handle a more broad range of conversions than explicit casts, as they
// handle things like function to ptr-to-function decay etc.
-Value *ScalarExprEmitter::EmitCastExpr(const Expr *E, QualType DestTy,
- CastExpr::CastKind Kind) {
+Value *ScalarExprEmitter::EmitCastExpr(const CastExpr *CE) {
+ const Expr *E = CE->getSubExpr();
+ QualType DestTy = CE->getType();
+ CastExpr::CastKind Kind = CE->getCastKind();
+
if (!DestTy->isVoidType())
TestAndClearIgnoreResultAssign();
@@ -681,12 +684,16 @@ Value *ScalarExprEmitter::EmitCastExpr(const Expr *E, QualType DestTy,
Value *Src = Visit(const_cast<Expr*>(E));
// FIXME: This should be true, but that leads to a failure in virt.cpp
- bool NullCheckValue = false;
+ bool NullCheckValue = true;
- // We always assume that 'this' is never null.
- if (isa<CXXThisExpr>(E))
+ if (isa<CXXThisExpr>(E)) {
+ // We always assume that 'this' is never null.
NullCheckValue = false;
-
+ } else if (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(CE)) {
+ // And that lvalue casts are never null.
+ if (ICE->isLvalueCast())
+ NullCheckValue = false;
+ }
return CGF.GetAddressCXXOfBaseClass(Src, DerivedClassDecl, BaseClassDecl,
NullCheckValue);
}