| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| ; RUN: opt < %s -passes=instcombine -mtriple=x86_64-unknown-unknown -S | FileCheck %s |
| |
| declare i32 @llvm.x86.tbm.bextri.u32(i32, i32) nounwind readnone |
| declare i64 @llvm.x86.tbm.bextri.u64(i64, i64) nounwind readnone |
| declare i32 @llvm.x86.bmi.bextr.32(i32, i32) nounwind readnone |
| declare i64 @llvm.x86.bmi.bextr.64(i64, i64) nounwind readnone |
| declare i32 @llvm.x86.bmi.bzhi.32(i32, i32) nounwind readnone |
| declare i64 @llvm.x86.bmi.bzhi.64(i64, i64) nounwind readnone |
| declare i32 @llvm.x86.bmi.pext.32(i32, i32) nounwind readnone |
| declare i64 @llvm.x86.bmi.pext.64(i64, i64) nounwind readnone |
| declare i32 @llvm.x86.bmi.pdep.32(i32, i32) nounwind readnone |
| declare i64 @llvm.x86.bmi.pdep.64(i64, i64) nounwind readnone |
| |
| define i32 @test_x86_tbm_bextri_u32(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i32 @llvm.x86.tbm.bextri.u32(i32 [[A:%.*]], i32 1296) |
| ; CHECK-NEXT: ret i32 [[TMP1]] |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 %a, i32 1296) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_tbm_bextri_u32_zero_length(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32_zero_length( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 %a, i32 1) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_tbm_bextri_u32_large_shift(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32_large_shift( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 %a, i32 288) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i64 @llvm.x86.tbm.bextri.u64(i64 [[A:%.*]], i64 1312) |
| ; CHECK-NEXT: ret i64 [[TMP1]] |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 %a, i64 1312) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64_zero_length(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64_zero_length( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 %a, i64 1) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64_large_shift(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64_large_shift( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 %a, i64 320) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_tbm_bextri_u32_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32_constfold( |
| ; CHECK-NEXT: ret i32 57005 |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 3735928559, i32 4112) ; extract bits 31:16 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_tbm_bextri_u32_constfold2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32_constfold2( |
| ; CHECK-NEXT: ret i32 233495534 |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 3735928559, i32 8196) ; extract bits 35:4 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_tbm_bextri_u32_constfold3() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u32_constfold3( |
| ; CHECK-NEXT: ret i32 233495534 |
| ; |
| %1 = tail call i32 @llvm.x86.tbm.bextri.u32(i32 3735928559, i32 16388) ; extract bits 67:4 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64_constfold( |
| ; CHECK-NEXT: ret i64 57005 |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 3735928559, i64 4112) ; extract bits 31:16 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64_constfold2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64_constfold2( |
| ; CHECK-NEXT: ret i64 233495534 |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 3735928559, i64 16388) ; extract bits 67:4 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_tbm_bextri_u64_constfold3() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_tbm_bextri_u64_constfold3( |
| ; CHECK-NEXT: ret i64 233495534 |
| ; |
| %1 = tail call i64 @llvm.x86.tbm.bextri.u64(i64 3735928559, i64 32772) ; extract bits 131:4 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i32 @llvm.x86.bmi.bextr.32(i32 [[A:%.*]], i32 1296) |
| ; CHECK-NEXT: ret i32 [[TMP1]] |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 %a, i32 1296) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32_zero_length(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32_zero_length( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 %a, i32 1) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32_large_shift(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32_large_shift( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 %a, i32 288) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i64 @llvm.x86.bmi.bextr.64(i64 [[A:%.*]], i64 1312) |
| ; CHECK-NEXT: ret i64 [[TMP1]] |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 %a, i64 1312) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64_zero_length(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64_zero_length( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 %a, i64 1) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64_large_shift(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64_large_shift( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 %a, i64 320) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32_constfold( |
| ; CHECK-NEXT: ret i32 57005 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 3735928559, i32 4112) ; extract bits 31:16 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32_constfold2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32_constfold2( |
| ; CHECK-NEXT: ret i32 233495534 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 3735928559, i32 8196) ; extract bits 35:4 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bextri_32_constfold3() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_32_constfold3( |
| ; CHECK-NEXT: ret i32 233495534 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bextr.32(i32 3735928559, i32 16388) ; extract bits 67:4 from 0xDEADBEEF |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64_constfold( |
| ; CHECK-NEXT: ret i64 57005 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 3735928559, i64 4112) ; extract bits 31:16 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64_constfold2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64_constfold2( |
| ; CHECK-NEXT: ret i64 233495534 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 3735928559, i64 16388) ; extract bits 67:4 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bextri_64_constfold3() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bextri_64_constfold3( |
| ; CHECK-NEXT: ret i64 233495534 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bextr.64(i64 3735928559, i64 32772) ; extract bits 131:4 from 0xDEADBEEF |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_bmi_bzhi_32(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_32( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i32 @llvm.x86.bmi.bzhi.32(i32 [[A:%.*]], i32 31) |
| ; CHECK-NEXT: ret i32 [[TMP1]] |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 %a, i32 31) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bzhi_32_zero(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_32_zero( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 %a, i32 0) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bzhi_32_max(i32 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_32_max( |
| ; CHECK-NEXT: ret i32 [[A:%.*]] |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 %a, i32 32) |
| ret i32 %1 |
| } |
| |
| define i32 @test_x86_bmi_bzhi_32_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_32_constfold( |
| ; CHECK-NEXT: ret i32 1 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 5, i32 1) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_bmi_bzhi_64(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_64( |
| ; CHECK-NEXT: [[TMP1:%.*]] = tail call i64 @llvm.x86.bmi.bzhi.64(i64 [[A:%.*]], i64 63) |
| ; CHECK-NEXT: ret i64 [[TMP1]] |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 %a, i64 63) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bzhi_64_zero(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_64_zero( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 %a, i64 0) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bzhi_64_max(i64 %a) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_64_max( |
| ; CHECK-NEXT: ret i64 [[A:%.*]] |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 %a, i64 64) |
| ret i64 %1 |
| } |
| |
| define i64 @test_x86_bmi_bzhi_64_constfold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_bmi_bzhi_64_constfold( |
| ; CHECK-NEXT: ret i64 1 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 5, i64 1) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pext_32_zero_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_32_zero_mask( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pext.32(i32 %x, i32 0) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pext_64_zero_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_64_zero_mask( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pext.64(i64 %x, i64 0) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pext_32_allones_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_32_allones_mask( |
| ; CHECK-NEXT: ret i32 %x |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pext.32(i32 %x, i32 -1) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pext_64_allones_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_64_allones_mask( |
| ; CHECK-NEXT: ret i64 %x |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pext.64(i64 %x, i64 -1) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pext_32_shifted_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_32_shifted_mask( |
| ; CHECK-NEXT: %1 = lshr i32 %x, 1 |
| ; CHECK-NEXT: %2 = and i32 %1, 3 |
| ; CHECK-NEXT: ret i32 %2 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pext.32(i32 %x, i32 6) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pext_64_shifted_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_64_shifted_mask( |
| ; CHECK-NEXT: %1 = lshr i64 %x, 1 |
| ; CHECK-NEXT: %2 = and i64 %1, 3 |
| ; CHECK-NEXT: ret i64 %2 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pext.64(i64 %x, i64 6) |
| ret i64 %1 |
| } |
| |
| |
| define i32 @test_x86_pext_32_constant_fold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_32_constant_fold( |
| ; CHECK-NEXT: ret i32 30001 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pext.32(i32 1985229328, i32 4042322160) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pext_64_constant_fold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_64_constant_fold( |
| ; CHECK-NEXT: ret i64 1966210489 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pext.64(i64 8526495043095935640, i64 -1085102592571150096) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pext_32_constant_fold_2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_32_constant_fold_2( |
| ; CHECK-NEXT: ret i32 30224 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pext.32(i32 1985229328, i32 4278190335) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pext_64_constant_fold_2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pext_64_constant_fold_2( |
| ; CHECK-NEXT: ret i64 1980816570 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pext.64(i64 8526495043095935640, i64 -72056498804490496) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pdep_32_zero_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_32_zero_mask( |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pdep.32(i32 %x, i32 0) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pdep_64_zero_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_64_zero_mask( |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pdep.64(i64 %x, i64 0) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pdep_32_allones_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_32_allones_mask( |
| ; CHECK-NEXT: ret i32 %x |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pdep.32(i32 %x, i32 -1) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pdep_64_allones_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_64_allones_mask( |
| ; CHECK-NEXT: ret i64 %x |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pdep.64(i64 %x, i64 -1) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pdep_32_shifted_mask(i32 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_32_shifted_mask( |
| ; CHECK-NEXT: %1 = shl i32 %x, 2 |
| ; CHECK-NEXT: %2 = and i32 %1, 12 |
| ; CHECK-NEXT: ret i32 %2 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pdep.32(i32 %x, i32 12) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pdep_64_shifted_mask(i64 %x) nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_64_shifted_mask( |
| ; CHECK-NEXT: %1 = shl i64 %x, 2 |
| ; CHECK-NEXT: %2 = and i64 %1, 12 |
| ; CHECK-NEXT: ret i64 %2 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pdep.64(i64 %x, i64 12) |
| ret i64 %1 |
| } |
| |
| |
| define i32 @test_x86_pdep_32_constant_fold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_32_constant_fold( |
| ; CHECK-NEXT: ret i32 807407616 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pdep.32(i32 1985229328, i32 4042322160) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pdep_64_constant_fold() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_64_constant_fold( |
| ; CHECK-NEXT: ret i64 -1089641583808049024 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pdep.64(i64 8526495043095935640, i64 -1085102592571150096) |
| ret i64 %1 |
| } |
| |
| define i32 @test_x86_pdep_32_constant_fold_2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_32_constant_fold_2( |
| ; CHECK-NEXT: ret i32 838860816 |
| ; |
| %1 = tail call i32 @llvm.x86.bmi.pdep.32(i32 1985229328, i32 4278190335) |
| ret i32 %1 |
| } |
| |
| define i64 @test_x86_pdep_64_constant_fold_2() nounwind readnone { |
| ; CHECK-LABEL: @test_x86_pdep_64_constant_fold_2( |
| ; CHECK-NEXT: ret i64 -144114243170822144 |
| ; |
| %1 = tail call i64 @llvm.x86.bmi.pdep.64(i64 8526495043095935640, i64 -72056498804490496) |
| ret i64 %1 |
| } |