diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2010-06-07 17:26:50 +0000 |
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2010-06-07 17:26:50 +0000 |
| commit | a54062ef0ce083355c61fcf48afda49eb6cf7aed (patch) | |
| tree | 586b4e2113f0f16a16fe92f974e1cf533127b958 /clang/lib | |
| parent | c4dca3aeb64f3c2369cf5d2204bb470737d29867 (diff) | |
| download | bcm5719-llvm-a54062ef0ce083355c61fcf48afda49eb6cf7aed.tar.gz bcm5719-llvm-a54062ef0ce083355c61fcf48afda49eb6cf7aed.zip | |
Implement __clear_cache on ARM.
llvm-svn: 105537
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/CodeGen/CGBuiltin.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp index ae61c046d93..409829687a0 100644 --- a/clang/lib/CodeGen/CGBuiltin.cpp +++ b/clang/lib/CodeGen/CGBuiltin.cpp @@ -923,10 +923,15 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID, switch (BuiltinID) { default: return 0; - - case ARM::BI__builtin_thread_pointer: { - Value *AtomF = CGM.getIntrinsic(Intrinsic::arm_thread_pointer, 0, 0); - return Builder.CreateCall(AtomF); + case ARM::BI__clear_cache: { + const FunctionDecl *FD = E->getDirectCallee(); + Value *a = EmitScalarExpr(E->getArg(0)); + Value *b = EmitScalarExpr(E->getArg(1)); + const llvm::Type *Ty = CGM.getTypes().ConvertType(FD->getType()); + const llvm::FunctionType *FTy = cast<llvm::FunctionType>(Ty); + llvm::StringRef Name = FD->getName(); + return Builder.CreateCall2(CGM.CreateRuntimeFunction(FTy, Name), + a, b); } // FIXME: bitcast args, return. case ARM::BI__builtin_neon_vaba_v: |

