From: Yi Kong Date: Mon, 14 Jul 2014 15:20:09 +0000 (+0000) Subject: ARM: Implement __builtin_arm_nop intrinsic X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dbc52fa0e2cadd3911c882c0c15e14db3e28e4de;p=clang ARM: Implement __builtin_arm_nop intrinsic This patch implements __builtin_arm_nop intrinsic for AArch32 and AArch64, which generates hint 0x0, the alias of NOP instruction. This intrinsic is necessary to implement ACLE __nop intrinsic. Differential Revision: http://reviews.llvm.org/D4495 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@212947 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/BuiltinsAArch64.def b/include/clang/Basic/BuiltinsAArch64.def index 8c6daa9146..76dddadb80 100644 --- a/include/clang/Basic/BuiltinsAArch64.def +++ b/include/clang/Basic/BuiltinsAArch64.def @@ -28,6 +28,7 @@ BUILTIN(__builtin_arm_rbit, "UiUi", "nc") BUILTIN(__builtin_arm_rbit64, "LUiLUi", "nc") // HINT +BUILTIN(__builtin_arm_nop, "v", "") BUILTIN(__builtin_arm_yield, "v", "") BUILTIN(__builtin_arm_wfe, "v", "") BUILTIN(__builtin_arm_wfi, "v", "") diff --git a/include/clang/Basic/BuiltinsARM.def b/include/clang/Basic/BuiltinsARM.def index d1cf9a76fb..2e5eac694f 100644 --- a/include/clang/Basic/BuiltinsARM.def +++ b/include/clang/Basic/BuiltinsARM.def @@ -68,6 +68,7 @@ BUILTIN(__builtin_arm_crc32d, "UiUiLLUi", "nc") BUILTIN(__builtin_arm_crc32cd, "UiUiLLUi", "nc") // HINT +BUILTIN(__builtin_arm_nop, "v", "") BUILTIN(__builtin_arm_yield, "v", "") BUILTIN(__builtin_arm_wfe, "v", "") BUILTIN(__builtin_arm_wfi, "v", "") diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index 4fd98bc1fd..0f1a146c05 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/lib/CodeGen/CGBuiltin.cpp @@ -3040,6 +3040,9 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID, unsigned HintID = static_cast(-1); switch (BuiltinID) { default: break; + case ARM::BI__builtin_arm_nop: + HintID = 0; + break; case ARM::BI__builtin_arm_yield: case ARM::BI__yield: HintID = 1; @@ -3804,6 +3807,9 @@ Value *CodeGenFunction::EmitAArch64BuiltinExpr(unsigned BuiltinID, unsigned HintID = static_cast(-1); switch (BuiltinID) { default: break; + case AArch64::BI__builtin_arm_nop: + HintID = 0; + break; case AArch64::BI__builtin_arm_yield: HintID = 1; break; diff --git a/test/CodeGen/builtins-arm.c b/test/CodeGen/builtins-arm.c index e55183c7f6..a51df15ce5 100644 --- a/test/CodeGen/builtins-arm.c +++ b/test/CodeGen/builtins-arm.c @@ -19,6 +19,12 @@ void test_eh_return_data_regno() res = __builtin_eh_return_data_regno(1); // CHECK: store volatile i32 1 } +void nop() { + __builtin_arm_nop(); +} + +// CHECK: call {{.*}} @llvm.arm.hint(i32 0) + void yield() { __builtin_arm_yield(); } diff --git a/test/CodeGen/builtins-arm64.c b/test/CodeGen/builtins-arm64.c index 8e15b846aa..8614be0592 100644 --- a/test/CodeGen/builtins-arm64.c +++ b/test/CodeGen/builtins-arm64.c @@ -16,6 +16,7 @@ unsigned long long rbit64(unsigned long long a) { } void hints() { + __builtin_arm_nop(); //CHECK: call {{.*}} @llvm.aarch64.hint(i32 0) __builtin_arm_yield(); //CHECK: call {{.*}} @llvm.aarch64.hint(i32 1) __builtin_arm_wfe(); //CHECK: call {{.*}} @llvm.aarch64.hint(i32 2) __builtin_arm_wfi(); //CHECK: call {{.*}} @llvm.aarch64.hint(i32 3)