xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/test-shrink-bug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Codegen shouldn't reduce the comparison down to testb $-1, %al
4*9880d681SAndroid Build Coastguard Worker; because that changes the result of the signed test.
5*9880d681SAndroid Build Coastguard Worker; PR5132
6*9880d681SAndroid Build Coastguard Worker; CHECK: testw  $255, %ax
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
9*9880d681SAndroid Build Coastguard Workertarget triple = "i386-apple-darwin10.0"
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Worker@g_14 = global i8 -6, align 1                     ; <i8*> [#uses=1]
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Workerdeclare i32 @func_16(i8 signext %p_19, i32 %p_20) nounwind
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerdefine i32 @func_35(i64 %p_38) nounwind ssp {
16*9880d681SAndroid Build Coastguard Workerentry:
17*9880d681SAndroid Build Coastguard Worker  %tmp = load i8, i8* @g_14                           ; <i8> [#uses=2]
18*9880d681SAndroid Build Coastguard Worker  %conv = zext i8 %tmp to i32                     ; <i32> [#uses=1]
19*9880d681SAndroid Build Coastguard Worker  %cmp = icmp sle i32 1, %conv                    ; <i1> [#uses=1]
20*9880d681SAndroid Build Coastguard Worker  %conv2 = zext i1 %cmp to i32                    ; <i32> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker  %call = call i32 @func_16(i8 signext %tmp, i32 %conv2) ssp ; <i32> [#uses=1]
22*9880d681SAndroid Build Coastguard Worker  ret i32 1
23*9880d681SAndroid Build Coastguard Worker}
24