From: Jim Grosbach Date: Mon, 16 Jun 2014 21:55:58 +0000 (+0000) Subject: ARM: Support for __builtin_arm_rbit() intrinsic. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=16c0c02b2fa254f37a0b54f4627f75e97aa60db0;p=clang ARM: Support for __builtin_arm_rbit() intrinsic. Reverse the bits in a word. Maps to the RBIT instruction. rdar://9283021 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@211059 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/BuiltinsARM.def b/include/clang/Basic/BuiltinsARM.def index 9f650cc415..00cd2c1de4 100644 --- a/include/clang/Basic/BuiltinsARM.def +++ b/include/clang/Basic/BuiltinsARM.def @@ -24,6 +24,9 @@ BUILTIN(__builtin_arm_qsub, "iii", "nc") BUILTIN(__builtin_arm_ssat, "iiUi", "nc") BUILTIN(__builtin_arm_usat, "UiUiUi", "nc") +// Bit manipulation +BUILTIN(__builtin_arm_rbit, "UiUi", "nc") + // Store and load exclusive BUILTIN(__builtin_arm_ldrexd, "LLUiv*", "") BUILTIN(__builtin_arm_strexd, "iLLUiv*", "") diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index 47245cf2d8..f4e11509a9 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/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(); diff --git a/test/CodeGen/builtins-arm.c b/test/CodeGen/builtins-arm.c index c5e487aafd..13ffc60784 100644 --- a/test/CodeGen/builtins-arm.c +++ b/test/CodeGen/builtins-arm.c @@ -52,3 +52,9 @@ void test_barrier() { __builtin_arm_dmb(1); //CHECK: call {{.*}} @llvm.arm.dmb(i32 1) __builtin_arm_dsb(2); //CHECK: call {{.*}} @llvm.arm.dsb(i32 2) } + +// CHECK: call {{.*}} @llvm.arm.rbit(i32 %a) + +unsigned rbit(unsigned a) { + return __builtin_arm_rbit(a); +}