diff options
| author | John McCall <rjmccall@apple.com> | 2010-08-22 04:16:24 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2010-08-22 04:16:24 +0000 |
| commit | 84fa510aa9ee3ee97ded906fe4635c2952596fe9 (patch) | |
| tree | 99fc717368577049fd788cb8060618198f79f9ab /clang/lib/CodeGen/CGExprAgg.cpp | |
| parent | a8bbb82c55a3c8885b5cf23dd84f80b2a08c069a (diff) | |
| download | llvm-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.cpp | 16 |
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; } } |
