xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2012-08-07-CmpISelBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-macosx | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Cmp lowering should not look past the truncate unless the high bits are known
4*9880d681SAndroid Build Coastguard Worker; zero.
5*9880d681SAndroid Build Coastguard Worker; rdar://12027825
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workerdefine void @foo(i8 %arg4, i32 %arg5, i32* %arg14) nounwind {
8*9880d681SAndroid Build Coastguard Workerbb:
9*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: foo:
10*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: testl
11*9880d681SAndroid Build Coastguard Worker; CHECK: testb
12*9880d681SAndroid Build Coastguard Worker  %tmp48 = zext i8 %arg4 to i32
13*9880d681SAndroid Build Coastguard Worker  %tmp49 = and i32 %tmp48, 32
14*9880d681SAndroid Build Coastguard Worker  %tmp50 = add i32 %tmp49, 1593371643
15*9880d681SAndroid Build Coastguard Worker  %tmp55 = sub i32 %tmp50, 0
16*9880d681SAndroid Build Coastguard Worker  %tmp56 = add i32 %tmp55, 7787538
17*9880d681SAndroid Build Coastguard Worker  %tmp57 = xor i32 %tmp56, 1601159181
18*9880d681SAndroid Build Coastguard Worker  %tmp58 = xor i32 %arg5, 1601159181
19*9880d681SAndroid Build Coastguard Worker  %tmp59 = and i32 %tmp57, %tmp58
20*9880d681SAndroid Build Coastguard Worker  %tmp60 = add i32 %tmp59, -1263900958
21*9880d681SAndroid Build Coastguard Worker  %tmp67 = sub i32 %tmp60, 0
22*9880d681SAndroid Build Coastguard Worker  %tmp103 = xor i32 %tmp56, 13
23*9880d681SAndroid Build Coastguard Worker  %tmp104 = trunc i32 %tmp103 to i8
24*9880d681SAndroid Build Coastguard Worker  %tmp105 = sub i8 0, %tmp104
25*9880d681SAndroid Build Coastguard Worker  %tmp106 = add i8 %tmp105, -103
26*9880d681SAndroid Build Coastguard Worker  %tmp113 = sub i8 %tmp106, 0
27*9880d681SAndroid Build Coastguard Worker  %tmp114 = add i8 %tmp113, -72
28*9880d681SAndroid Build Coastguard Worker  %tmp141 = icmp ne i32 %tmp67, -1263900958
29*9880d681SAndroid Build Coastguard Worker  %tmp142 = select i1 %tmp141, i8 %tmp114, i8 undef
30*9880d681SAndroid Build Coastguard Worker  %tmp143 = xor i8 %tmp142, 81
31*9880d681SAndroid Build Coastguard Worker  %tmp144 = zext i8 %tmp143 to i32
32*9880d681SAndroid Build Coastguard Worker  %tmp145 = add i32 %tmp144, 2062143348
33*9880d681SAndroid Build Coastguard Worker  %tmp152 = sub i32 %tmp145, 0
34*9880d681SAndroid Build Coastguard Worker  store i32 %tmp152, i32* %arg14
35*9880d681SAndroid Build Coastguard Worker  ret void
36*9880d681SAndroid Build Coastguard Worker}
37