diff options
-rw-r--r-- | llvm/test/CodeGen/X86/pr32588.ll | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/llvm/test/CodeGen/X86/pr32588.ll b/llvm/test/CodeGen/X86/pr32588.ll index eee1d651c3e..5b875cdc991 100644 --- a/llvm/test/CodeGen/X86/pr32588.ll +++ b/llvm/test/CodeGen/X86/pr32588.ll @@ -1,25 +1,26 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc < %s -mcpu=generic -mtriple=x86_64-linux | FileCheck %s @c = external local_unnamed_addr global i32, align 4 @b = external local_unnamed_addr global i32, align 4 @d = external local_unnamed_addr global i32, align 4 -; CHECK: cmpl $1, c(%rip) -; CHECK-NEXT: sbbl %eax, %eax -; CHECK-NEXT: andl $1, %eax -; CHECK-NEXT: movl %eax, d(%rip) -; CHECK-NEXT: retq - define void @fn1() { -entry: - %0 = load i32, i32* @c, align 4 - %tobool1 = icmp eq i32 %0, 0 +; CHECK-LABEL: fn1: +; CHECK: # %bb.0: +; CHECK-NEXT: cmpl $1, {{.*}}(%rip) +; CHECK-NEXT: sbbl %eax, %eax +; CHECK-NEXT: andl $1, %eax +; CHECK-NEXT: movl %eax, {{.*}}(%rip) +; CHECK-NEXT: retq + %t0 = load i32, i32* @c, align 4 + %tobool1 = icmp eq i32 %t0, 0 %xor = zext i1 %tobool1 to i32 - %1 = load i32, i32* @b, align 4 - %tobool2 = icmp ne i32 %1, 0 + %t1 = load i32, i32* @b, align 4 + %tobool2 = icmp ne i32 %t1, 0 %tobool4 = icmp ne i32 undef, 0 - %2 = and i1 %tobool4, %tobool2 - %sub = sext i1 %2 to i32 + %t2 = and i1 %tobool4, %tobool2 + %sub = sext i1 %t2 to i32 %div = sdiv i32 %sub, 2 %add = add nsw i32 %div, %xor store i32 %add, i32* @d, align 4 |