summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorJim Grosbach <grosbach@apple.com>2014-06-16 21:55:58 +0000
committerJim Grosbach <grosbach@apple.com>2014-06-16 21:55:58 +0000
commit171ec3454422decfcb0f04bf8ce8ee5fbc9f61ae (patch)
tree9e996cb3492b68bfc859bbae718942c4f6f4710b /clang/lib/CodeGen
parentcc71514d3a88b01726960a22297fd1f8ea508781 (diff)
downloadbcm5719-llvm-171ec3454422decfcb0f04bf8ce8ee5fbc9f61ae.tar.gz
bcm5719-llvm-171ec3454422decfcb0f04bf8ce8ee5fbc9f61ae.zip
ARM: Support for __builtin_arm_rbit() intrinsic.
Reverse the bits in a word. Maps to the RBIT instruction. rdar://9283021 llvm-svn: 211059
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CGBuiltin.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp
index 47245cf2d83..f4e11509a9d 100644
--- a/clang/lib/CodeGen/CGBuiltin.cpp
+++ b/clang/lib/CodeGen/CGBuiltin.cpp
@@ -3054,6 +3054,12 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
return Builder.CreateCall(F, llvm::ConstantInt::get(Int32Ty, HintID));
}
+ if (BuiltinID == ARM::BI__builtin_arm_rbit) {
+ return Builder.CreateCall(CGM.getIntrinsic(Intrinsic::arm_rbit),
+ EmitScalarExpr(E->getArg(0)),
+ "rbit");
+ }
+
if (BuiltinID == ARM::BI__clear_cache) {
assert(E->getNumArgs() == 2 && "__clear_cache takes 2 arguments");
const FunctionDecl *FD = E->getDirectCallee();
OpenPOWER on IntegriCloud