| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc < %s -mtriple=i686--| FileCheck %s --check-prefixes=X86 |
| ; RUN: llc < %s -mtriple=x86_64--| FileCheck %s --check-prefixes=X64 |
| |
| ; |
| ; PR35202 |
| ; |
| |
| declare void @on_less() |
| declare void @on_equal() |
| declare void @on_greater() |
| |
| define void @eq_first(i32 %0, i32 %1) { |
| ; X86-LABEL: eq_first: |
| ; X86: # %bb.0: |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: cmpl %eax, {{[0-9]+}}(%esp) |
| ; X86-NEXT: jl on_less@PLT # TAILCALL |
| ; X86-NEXT: # %bb.1: |
| ; X86-NEXT: je on_equal@PLT # TAILCALL |
| ; X86-NEXT: # %bb.2: |
| ; X86-NEXT: jmp on_greater@PLT # TAILCALL |
| ; |
| ; X64-LABEL: eq_first: |
| ; X64: # %bb.0: |
| ; X64-NEXT: cmpl %esi, %edi |
| ; X64-NEXT: jl on_less@PLT # TAILCALL |
| ; X64-NEXT: # %bb.1: |
| ; X64-NEXT: je on_equal@PLT # TAILCALL |
| ; X64-NEXT: # %bb.2: |
| ; X64-NEXT: jmp on_greater@PLT # TAILCALL |
| %3 = icmp slt i32 %0, %1 |
| br i1 %3, label %4, label %5 |
| 4: |
| tail call void @on_less() |
| br label %9 |
| 5: |
| %6 = icmp eq i32 %0, %1 |
| br i1 %6, label %7, label %8 |
| 7: |
| tail call void @on_equal() |
| br label %9 |
| 8: |
| tail call void @on_greater() |
| br label %9 |
| 9: |
| ret void |
| } |
| |
| define void @gt_first(i32 %0, i32 %1) { |
| ; X86-LABEL: gt_first: |
| ; X86: # %bb.0: |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx |
| ; X86-NEXT: cmpl %eax, %ecx |
| ; X86-NEXT: jl on_less@PLT # TAILCALL |
| ; X86-NEXT: # %bb.1: |
| ; X86-NEXT: jg on_greater@PLT # TAILCALL |
| ; X86-NEXT: # %bb.2: |
| ; X86-NEXT: jmp on_equal@PLT # TAILCALL |
| ; |
| ; X64-LABEL: gt_first: |
| ; X64: # %bb.0: |
| ; X64-NEXT: cmpl %esi, %edi |
| ; X64-NEXT: jl on_less@PLT # TAILCALL |
| ; X64-NEXT: # %bb.1: |
| ; X64-NEXT: jg on_greater@PLT # TAILCALL |
| ; X64-NEXT: # %bb.2: |
| ; X64-NEXT: jmp on_equal@PLT # TAILCALL |
| %3 = icmp slt i32 %0, %1 |
| br i1 %3, label %4, label %5 |
| 4: |
| tail call void @on_less() |
| br label %9 |
| 5: |
| %6 = icmp slt i32 %1, %0 |
| br i1 %6, label %7, label %8 |
| 7: |
| tail call void @on_greater() |
| br label %9 |
| 8: |
| tail call void @on_equal() |
| br label %9 |
| 9: |
| ret void |
| } |
| |
| define void @cmp_sub_same_order(i32 %x, i32 %y, ptr %p) { |
| ; X86-LABEL: cmp_sub_same_order: |
| ; X86: # %bb.0: # %entry |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: subl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: jge .LBB2_2 |
| ; X86-NEXT: # %bb.1: # %cond.true |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx |
| ; X86-NEXT: movl %eax, (%ecx) |
| ; X86-NEXT: .LBB2_2: # %cond.end |
| ; X86-NEXT: retl |
| ; |
| ; X64-LABEL: cmp_sub_same_order: |
| ; X64: # %bb.0: # %entry |
| ; X64-NEXT: subl %esi, %edi |
| ; X64-NEXT: jge .LBB2_2 |
| ; X64-NEXT: # %bb.1: # %cond.true |
| ; X64-NEXT: movl %edi, (%rdx) |
| ; X64-NEXT: .LBB2_2: # %cond.end |
| ; X64-NEXT: retq |
| entry: |
| %cmp = icmp slt i32 %x, %y |
| br i1 %cmp, label %cond.true, label %cond.end |
| |
| cond.true: |
| %sub = sub nsw i32 %x, %y |
| store i32 %sub, ptr %p |
| br label %cond.end |
| |
| cond.end: |
| ret void |
| } |
| |
| define void @cmp_sub_different_order(i32 %x, i32 %y, ptr %p) { |
| ; X86-LABEL: cmp_sub_different_order: |
| ; X86: # %bb.0: # %entry |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: subl {{[0-9]+}}(%esp), %eax |
| ; X86-NEXT: jge .LBB3_2 |
| ; X86-NEXT: # %bb.1: # %cond.true |
| ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx |
| ; X86-NEXT: movl %eax, (%ecx) |
| ; X86-NEXT: .LBB3_2: # %cond.end |
| ; X86-NEXT: retl |
| ; |
| ; X64-LABEL: cmp_sub_different_order: |
| ; X64: # %bb.0: # %entry |
| ; X64-NEXT: subl %esi, %edi |
| ; X64-NEXT: jge .LBB3_2 |
| ; X64-NEXT: # %bb.1: # %cond.true |
| ; X64-NEXT: movl %edi, (%rdx) |
| ; X64-NEXT: .LBB3_2: # %cond.end |
| ; X64-NEXT: retq |
| entry: |
| %cmp = icmp sgt i32 %y, %x |
| br i1 %cmp, label %cond.true, label %cond.end |
| |
| cond.true: |
| %sub = sub nsw i32 %x, %y |
| store i32 %sub, ptr %p |
| br label %cond.end |
| |
| cond.end: |
| ret void |
| } |
| |
| declare void @use(i32) |