From 3b2a217a47b015f28c838418395912db5ed11bc8 Mon Sep 17 00:00:00 2001 From: Noah Goldstein Date: Mon, 8 May 2023 01:45:56 -0500 Subject: [PATCH] [X86] Add tests for `computeKnownBits` of `sdiv` and `udiv`; NFC Differential Revision: https://reviews.llvm.org/D150097 --- llvm/test/CodeGen/X86/knownbits-div.ll | 82 ++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 llvm/test/CodeGen/X86/knownbits-div.ll diff --git a/llvm/test/CodeGen/X86/knownbits-div.ll b/llvm/test/CodeGen/X86/knownbits-div.ll new file mode 100644 index 0000000..0c8501f --- /dev/null +++ b/llvm/test/CodeGen/X86/knownbits-div.ll @@ -0,0 +1,82 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py +; RUN: llc < %s -mtriple=x86_64-unknown | FileCheck %s + +define i8 @sdiv_neg_neg_high_bits(i8 %x, i8 %y) { +; CHECK-LABEL: sdiv_neg_neg_high_bits: +; CHECK: # %bb.0: +; CHECK-NEXT: orb $-128, %dil +; CHECK-NEXT: orb $-125, %sil +; CHECK-NEXT: movsbl %dil, %eax +; CHECK-NEXT: idivb %sil +; CHECK-NEXT: andb $-128, %al +; CHECK-NEXT: retq + %num = or i8 %x, 128 + %denum = or i8 %y, 131 + %div = sdiv i8 %num, %denum + %r = and i8 %div, 128 + ret i8 %r +} + +define i8 @sdiv_exact_odd_odd(i8 %x, i8 %y) { +; CHECK-LABEL: sdiv_exact_odd_odd: +; CHECK: # %bb.0: +; CHECK-NEXT: orb $1, %dil +; CHECK-NEXT: orb $1, %sil +; CHECK-NEXT: movsbl %dil, %eax +; CHECK-NEXT: idivb %sil +; CHECK-NEXT: andb $1, %al +; CHECK-NEXT: retq + %num = or i8 %x, 1 + %denum = or i8 %y, 1 + %div = sdiv exact i8 %num, %denum + %r = and i8 %div, 1 + ret i8 %r +} + +define i8 @sdiv_exact_even_even_fail_unknown(i8 %x, i8 %y) { +; CHECK-LABEL: sdiv_exact_even_even_fail_unknown: +; CHECK: # %bb.0: +; CHECK-NEXT: andb $-2, %dil +; CHECK-NEXT: andb $-2, %sil +; CHECK-NEXT: movsbl %dil, %eax +; CHECK-NEXT: idivb %sil +; CHECK-NEXT: andb $1, %al +; CHECK-NEXT: retq + %num = and i8 %x, -2 + %denum = and i8 %y, -2 + %div = sdiv exact i8 %num, %denum + %r = and i8 %div, 1 + ret i8 %r +} + +define i8 @udiv_exact_even_odd(i8 %x, i8 %y) { +; CHECK-LABEL: udiv_exact_even_odd: +; CHECK: # %bb.0: +; CHECK-NEXT: andb $-2, %dil +; CHECK-NEXT: orb $1, %sil +; CHECK-NEXT: movzbl %dil, %eax +; CHECK-NEXT: divb %sil +; CHECK-NEXT: andb $1, %al +; CHECK-NEXT: retq + %num = and i8 %x, -2 + %denum = or i8 %y, 1 + %div = udiv exact i8 %num, %denum + %r = and i8 %div, 1 + ret i8 %r +} + +define i8 @udiv_exact_even_even_fail_unknown(i8 %x, i8 %y) { +; CHECK-LABEL: udiv_exact_even_even_fail_unknown: +; CHECK: # %bb.0: +; CHECK-NEXT: andb $-2, %dil +; CHECK-NEXT: andb $-2, %sil +; CHECK-NEXT: movzbl %dil, %eax +; CHECK-NEXT: divb %sil +; CHECK-NEXT: andb $1, %al +; CHECK-NEXT: retq + %num = and i8 %x, -2 + %denum = and i8 %y, -2 + %div = udiv exact i8 %num, %denum + %r = and i8 %div, 1 + ret i8 %r +} -- 2.7.4