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