[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / sub-with-overflow.ll
blob6de0beeabdfe089cb3e40d67bae6447e5196eb8d
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-linux | FileCheck %s
4 @ok = internal constant [4 x i8] c"%d\0A\00"
5 @no = internal constant [4 x i8] c"no\0A\00"
7 define i1 @func1(i32 %v1, i32 %v2) nounwind {
8 ; CHECK-LABEL: func1:
9 ; CHECK:       # %bb.0: # %entry
10 ; CHECK-NEXT:    subl $12, %esp
11 ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
12 ; CHECK-NEXT:    subl {{[0-9]+}}(%esp), %eax
13 ; CHECK-NEXT:    jno .LBB0_1
14 ; CHECK-NEXT:  # %bb.2: # %overflow
15 ; CHECK-NEXT:    movl $no, (%esp)
16 ; CHECK-NEXT:    calll printf
17 ; CHECK-NEXT:    xorl %eax, %eax
18 ; CHECK-NEXT:    addl $12, %esp
19 ; CHECK-NEXT:    retl
20 ; CHECK-NEXT:  .LBB0_1: # %normal
21 ; CHECK-NEXT:    movl %eax, {{[0-9]+}}(%esp)
22 ; CHECK-NEXT:    movl $ok, (%esp)
23 ; CHECK-NEXT:    calll printf
24 ; CHECK-NEXT:    movb $1, %al
25 ; CHECK-NEXT:    addl $12, %esp
26 ; CHECK-NEXT:    retl
27 entry:
28   %t = call {i32, i1} @llvm.ssub.with.overflow.i32(i32 %v1, i32 %v2)
29   %sum = extractvalue {i32, i1} %t, 0
30   %obit = extractvalue {i32, i1} %t, 1
31   br i1 %obit, label %overflow, label %normal
33 normal:
34   %t1 = tail call i32 (i8*, ...) @printf( i8* getelementptr ([4 x i8], [4 x i8]* @ok, i32 0, i32 0), i32 %sum ) nounwind
35   ret i1 true
37 overflow:
38   %t2 = tail call i32 (i8*, ...) @printf( i8* getelementptr ([4 x i8], [4 x i8]* @no, i32 0, i32 0) ) nounwind
39   ret i1 false
43 define i1 @func2(i32 %v1, i32 %v2) nounwind {
44 ; CHECK-LABEL: func2:
45 ; CHECK:       # %bb.0: # %entry
46 ; CHECK-NEXT:    subl $12, %esp
47 ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
48 ; CHECK-NEXT:    subl {{[0-9]+}}(%esp), %eax
49 ; CHECK-NEXT:    jae .LBB1_1
50 ; CHECK-NEXT:  # %bb.2: # %carry
51 ; CHECK-NEXT:    movl $no, (%esp)
52 ; CHECK-NEXT:    calll printf
53 ; CHECK-NEXT:    xorl %eax, %eax
54 ; CHECK-NEXT:    addl $12, %esp
55 ; CHECK-NEXT:    retl
56 ; CHECK-NEXT:  .LBB1_1: # %normal
57 ; CHECK-NEXT:    movl %eax, {{[0-9]+}}(%esp)
58 ; CHECK-NEXT:    movl $ok, (%esp)
59 ; CHECK-NEXT:    calll printf
60 ; CHECK-NEXT:    movb $1, %al
61 ; CHECK-NEXT:    addl $12, %esp
62 ; CHECK-NEXT:    retl
63 entry:
64   %t = call {i32, i1} @llvm.usub.with.overflow.i32(i32 %v1, i32 %v2)
65   %sum = extractvalue {i32, i1} %t, 0
66   %obit = extractvalue {i32, i1} %t, 1
67   br i1 %obit, label %carry, label %normal
69 normal:
70   %t1 = tail call i32 (i8*, ...) @printf( i8* getelementptr ([4 x i8], [4 x i8]* @ok, i32 0, i32 0), i32 %sum ) nounwind
71   ret i1 true
73 carry:
74   %t2 = tail call i32 (i8*, ...) @printf( i8* getelementptr ([4 x i8], [4 x i8]* @no, i32 0, i32 0) ) nounwind
75   ret i1 false
79 declare i32 @printf(i8*, ...) nounwind
80 declare {i32, i1} @llvm.ssub.with.overflow.i32(i32, i32)
81 declare {i32, i1} @llvm.usub.with.overflow.i32(i32, i32)
83 define i1 @func3(i32 %x) nounwind {
84 ; CHECK-LABEL: func3:
85 ; CHECK:       # %bb.0: # %entry
86 ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
87 ; CHECK-NEXT:    decl %eax
88 ; CHECK-NEXT:    seto %al
89 ; CHECK-NEXT:    retl
90 entry:
91   %t = call {i32, i1} @llvm.ssub.with.overflow.i32(i32 %x, i32 1)
92   %obit = extractvalue {i32, i1} %t, 1
93   ret i1 %obit