diff options
author | Michael Gottesman <mgottesman@apple.com> | 2013-01-14 21:44:30 +0000 |
---|---|---|
committer | Michael Gottesman <mgottesman@apple.com> | 2013-01-14 21:44:30 +0000 |
commit | a2b5c4ba6ab5d904c460123cbb6d26874d28039c (patch) | |
tree | b0caa867d83d14dcdde578b43dfa8007eb8f8d7c /clang/lib/CodeGen/CGBuiltin.cpp | |
parent | 77ca8b83a98b7665e0c5dd37b6bafd999d52e975 (diff) | |
download | bcm5719-llvm-a2b5c4ba6ab5d904c460123cbb6d26874d28039c.tar.gz bcm5719-llvm-a2b5c4ba6ab5d904c460123cbb6d26874d28039c.zip |
Multiprecision subtraction builtins.
We lower these into 2x chained usub.with.overflow intrinsics.
llvm-svn: 172476
Diffstat (limited to 'clang/lib/CodeGen/CGBuiltin.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGBuiltin.cpp | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp index 1a53f624409..48ed65e3c7a 100644 --- a/clang/lib/CodeGen/CGBuiltin.cpp +++ b/clang/lib/CodeGen/CGBuiltin.cpp @@ -1348,7 +1348,11 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD, case Builtin::BI__builtin_addcs: case Builtin::BI__builtin_addc: case Builtin::BI__builtin_addcl: - case Builtin::BI__builtin_addcll: { + case Builtin::BI__builtin_addcll: + case Builtin::BI__builtin_subcs: + case Builtin::BI__builtin_subc: + case Builtin::BI__builtin_subcl: + case Builtin::BI__builtin_subcll: { // We translate all of these builtins from expressions of the form: // int x = ..., y = ..., carryin = ..., carryout, result; @@ -1374,7 +1378,23 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD, std::pair<llvm::Value*, unsigned> CarryOutPtr = EmitPointerWithAlignment(E->getArg(3)); - const llvm::Intrinsic::ID IntrinsicId = llvm::Intrinsic::uadd_with_overflow; + // Decide if we are lowering to a uadd.with.overflow or usub.with.overflow. + llvm::Intrinsic::ID IntrinsicId; + switch (BuiltinID) { + default: llvm_unreachable("Unknown multiprecision builtin id."); + case Builtin::BI__builtin_addcs: + case Builtin::BI__builtin_addc: + case Builtin::BI__builtin_addcl: + case Builtin::BI__builtin_addcll: + IntrinsicId = llvm::Intrinsic::uadd_with_overflow; + break; + case Builtin::BI__builtin_subcs: + case Builtin::BI__builtin_subc: + case Builtin::BI__builtin_subcl: + case Builtin::BI__builtin_subcll: + IntrinsicId = llvm::Intrinsic::usub_with_overflow; + break; + } // Construct our resulting LLVM IR expression. llvm::Value *Carry1; |