diff options
author | Craig Topper <craig.topper@gmail.com> | 2011-10-19 07:48:35 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@gmail.com> | 2011-10-19 07:48:35 +0000 |
commit | 717cdb0df88ddf704f057fb70ed7093836222609 (patch) | |
tree | 8079ca24b7ac3f3b762404d016891bce46121b2f /include/llvm/IntrinsicsX86.td | |
parent | fffc0fe42c4dc664c95031725850ab78a3932613 (diff) | |
download | external_llvm-717cdb0df88ddf704f057fb70ed7093836222609.zip external_llvm-717cdb0df88ddf704f057fb70ed7093836222609.tar.gz external_llvm-717cdb0df88ddf704f057fb70ed7093836222609.tar.bz2 |
Rename PEXTR to PEXT. Add intrinsics for BMI instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142480 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/IntrinsicsX86.td')
-rw-r--r-- | include/llvm/IntrinsicsX86.td | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/include/llvm/IntrinsicsX86.td b/include/llvm/IntrinsicsX86.td index d445a01..db9c9ce 100644 --- a/include/llvm/IntrinsicsX86.td +++ b/include/llvm/IntrinsicsX86.td @@ -1629,3 +1629,37 @@ let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.". Intrinsic<[llvm_x86mmx_ty], [llvm_x86mmx_ty, llvm_i32_ty, llvm_i32_ty], [IntrNoMem]>; } + +//===----------------------------------------------------------------------===// +// BMI + +let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.". + def int_x86_bmi_bextr_32 : GCCBuiltin<"__builtin_ia32_bextr_u32">, + Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_bextr_64 : GCCBuiltin<"__builtin_ia32_bextr_u64">, + Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_bzhi_32 : GCCBuiltin<"__builtin_ia32_bzhi_si">, + Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_bzhi_64 : GCCBuiltin<"__builtin_ia32_bzhi_di">, + Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_blsi_32 : + Intrinsic<[llvm_i32_ty], [llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_blsi_64 : + Intrinsic<[llvm_i64_ty], [llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_blsmsk_32 : + Intrinsic<[llvm_i32_ty], [llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_blsmsk_64 : + Intrinsic<[llvm_i64_ty], [llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_blsr_32 : + Intrinsic<[llvm_i32_ty], [llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_blsr_64 : + Intrinsic<[llvm_i64_ty], [llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_pdep_32 : + Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_pdep_64 : + Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty], [IntrNoMem]>; + def int_x86_bmi_pext_32 : + Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i32_ty], [IntrNoMem]>; + def int_x86_bmi_pext_64 : + Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty], [IntrNoMem]>; +} |