blob: 37b0c7834737301affaad8c5a06d7404ab9f056c [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+sse2,+bmi2 | FileCheck %s
declare i32 @llvm.x86.bmi.bzhi.32(i32, i32) nounwind readnone
declare i64 @llvm.x86.bmi.bzhi.64(i64, i64) nounwind readnone
define i32 @test_bzhi32_zero(i32 %a) nounwind {
; CHECK-LABEL: test_bzhi32_zero:
; CHECK: # %bb.0:
; CHECK-NEXT: xorl %eax, %eax
; CHECK-NEXT: retq
%1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 %a, i32 0)
ret i32 %1
}
define i64 @test_bzhi64_zero(i64 %a) nounwind readnone {
; CHECK-LABEL: test_bzhi64_zero:
; CHECK: # %bb.0:
; CHECK-NEXT: xorl %eax, %eax
; CHECK-NEXT: retq
%1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 %a, i64 0)
ret i64 %1
}
define i32 @test_bzhi32_constfold() nounwind readnone {
; CHECK-LABEL: test_bzhi32_constfold:
; CHECK: # %bb.0:
; CHECK-NEXT: movl $1, %eax
; CHECK-NEXT: retq
%1 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 5, i32 1)
ret i32 %1
}
define i64 @test_bzhi64_constfold() nounwind readnone {
; CHECK-LABEL: test_bzhi64_constfold:
; CHECK: # %bb.0:
; CHECK-NEXT: movl $1, %eax
; CHECK-NEXT: retq
%1 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 5, i64 1)
ret i64 %1
}
define i32 @test_bzhi32_minvaluefold(i32 %arg) nounwind readnone {
; CHECK-LABEL: test_bzhi32_minvaluefold:
; CHECK: # %bb.0:
; CHECK-NEXT: movl $5, %eax
; CHECK-NEXT: retq
%2 = or i32 %arg, 32
%3 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 5, i32 %2)
ret i32 %3
}
define i64 @test_bzhi64_minvaluefold(i64 %arg) nounwind readnone {
; CHECK-LABEL: test_bzhi64_minvaluefold:
; CHECK: # %bb.0:
; CHECK-NEXT: movabsq $30064771072, %rax # imm = 0x700000000
; CHECK-NEXT: retq
%2 = or i64 %arg, 64
%3 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 30064771072, i64 %2)
ret i64 %3
}
define i32 @test_bzhi32_range(i32 %arg) nounwind readnone {
; CHECK-LABEL: test_bzhi32_range:
; CHECK: # %bb.0:
; CHECK-NEXT: movl $42, %eax
; CHECK-NEXT: retq
%2 = or i32 %arg, 6
%3 = and i32 %2, 7
%4 = tail call i32 @llvm.x86.bmi.bzhi.32(i32 699050, i32 %3)
ret i32 %4
}
define i64 @test_bzhi64_range(i64 %arg) nounwind readnone {
; CHECK-LABEL: test_bzhi64_range:
; CHECK: # %bb.0:
; CHECK-NEXT: movl $40, %eax
; CHECK-NEXT: retq
%2 = or i64 %arg, 6
%3 = and i64 %2, 7
%4 = tail call i64 @llvm.x86.bmi.bzhi.64(i64 30064771240, i64 %3)
ret i64 %4
}