aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/CodeGen/CGExprAgg.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-08-22 04:16:24 +0000
committerJohn McCall <rjmccall@apple.com>2010-08-22 04:16:24 +0000
commit84fa510aa9ee3ee97ded906fe4635c2952596fe9 (patch)
tree99fc717368577049fd788cb8060618198f79f9ab /clang/lib/CodeGen/CGExprAgg.cpp
parenta8bbb82c55a3c8885b5cf23dd84f80b2a08c069a (diff)
downloadllvm-84fa510aa9ee3ee97ded906fe4635c2952596fe9.zip
llvm-84fa510aa9ee3ee97ded906fe4635c2952596fe9.tar.gz
llvm-84fa510aa9ee3ee97ded906fe4635c2952596fe9.tar.bz2
Abstract more member-pointerness out.
llvm-svn: 111771
Diffstat (limited to 'clang/lib/CodeGen/CGExprAgg.cpp')
-rw-r--r--clang/lib/CodeGen/CGExprAgg.cpp16
1 files changed, 5 insertions, 11 deletions
diff --git a/clang/lib/CodeGen/CGExprAgg.cpp b/clang/lib/CodeGen/CGExprAgg.cpp
index 7b198bc..1f8964d 100644
--- a/clang/lib/CodeGen/CGExprAgg.cpp
+++ b/clang/lib/CodeGen/CGExprAgg.cpp
@@ -293,15 +293,9 @@ void AggExprEmitter::VisitCastExpr(CastExpr *E) {
if (E->getSubExpr()->getType()->isNullPtrType())
Visit(E->getSubExpr());
- const llvm::Type *PtrDiffTy =
- CGF.ConvertType(CGF.getContext().getPointerDiffType());
-
- llvm::Value *NullValue = llvm::Constant::getNullValue(PtrDiffTy);
- llvm::Value *Ptr = Builder.CreateStructGEP(DestPtr, 0, "ptr");
- Builder.CreateStore(NullValue, Ptr, VolatileDest);
-
- llvm::Value *Adj = Builder.CreateStructGEP(DestPtr, 1, "adj");
- Builder.CreateStore(NullValue, Adj, VolatileDest);
+ CGF.CGM.getCXXABI().EmitNullMemberFunctionPointer(CGF,
+ E->getType()->getAs<MemberPointerType>(),
+ DestPtr, VolatileDest);
break;
}
@@ -329,8 +323,8 @@ void AggExprEmitter::VisitCastExpr(CastExpr *E) {
// ABIs where an actual null check is thus required; fortunately,
// the Itanium and ARM ABIs ignore the adjustment value when
// considering null-ness.
- CGF.CGM.getCXXABI().EmitMemberPointerConversion(CGF, E, Src,
- DestPtr, VolatileDest);
+ CGF.CGM.getCXXABI().EmitMemberFunctionPointerConversion(CGF, E, Src,
+ DestPtr, VolatileDest);
break;
}
}