From 1e14289ef9ef10d438510e463e30a22ce3fe8c15 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 9 Sep 2006 06:17:12 +0000 Subject: [PATCH] Add cbe support for powi git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30226 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/CBackend/CBackend.cpp | 10 ++++++++++ lib/Target/CBackend/Writer.cpp | 10 ++++++++++ 2 files changed, 20 insertions(+) diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index c50b5a40e95..330a7bc53f8 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -1693,6 +1693,8 @@ void CWriter::lowerIntrinsics(Function &F) { case Intrinsic::longjmp: case Intrinsic::prefetch: case Intrinsic::dbg_stoppoint: + case Intrinsic::powi_f32: + case Intrinsic::powi_f64: // We directly implement these intrinsics break; default: @@ -1785,6 +1787,14 @@ void CWriter::visitCallInst(CallInst &I) { writeOperand(I.getOperand(1)); Out << ')'; return; + case Intrinsic::powi_f32: + case Intrinsic::powi_f64: + Out << "__builtin_powi("; + writeOperand(I.getOperand(1)); + Out << ", "; + writeOperand(I.getOperand(2)); + Out << ')'; + return; case Intrinsic::setjmp: #if defined(HAVE__SETJMP) && defined(HAVE__LONGJMP) Out << "_"; // Use _setjmp on systems that support it! diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp index c50b5a40e95..330a7bc53f8 100644 --- a/lib/Target/CBackend/Writer.cpp +++ b/lib/Target/CBackend/Writer.cpp @@ -1693,6 +1693,8 @@ void CWriter::lowerIntrinsics(Function &F) { case Intrinsic::longjmp: case Intrinsic::prefetch: case Intrinsic::dbg_stoppoint: + case Intrinsic::powi_f32: + case Intrinsic::powi_f64: // We directly implement these intrinsics break; default: @@ -1785,6 +1787,14 @@ void CWriter::visitCallInst(CallInst &I) { writeOperand(I.getOperand(1)); Out << ')'; return; + case Intrinsic::powi_f32: + case Intrinsic::powi_f64: + Out << "__builtin_powi("; + writeOperand(I.getOperand(1)); + Out << ", "; + writeOperand(I.getOperand(2)); + Out << ')'; + return; case Intrinsic::setjmp: #if defined(HAVE__SETJMP) && defined(HAVE__LONGJMP) Out << "_"; // Use _setjmp on systems that support it!