1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 | FileCheck %s -check-prefix=X32 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86-64 | FileCheck %s -check-prefix=X64 3*9880d681SAndroid Build Coastguard Worker; rdar://7367229 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workerdefine i32 @t(i32 %a, i32 %b) nounwind ssp { 6*9880d681SAndroid Build Coastguard Workerentry: 7*9880d681SAndroid Build Coastguard Worker; X32-LABEL: t: 8*9880d681SAndroid Build Coastguard Worker; X32: xorb 9*9880d681SAndroid Build Coastguard Worker; X32-NOT: andb 10*9880d681SAndroid Build Coastguard Worker; X32-NOT: shrb 11*9880d681SAndroid Build Coastguard Worker; X32: testb $64 12*9880d681SAndroid Build Coastguard Worker; X32: je 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker; X64-LABEL: t: 15*9880d681SAndroid Build Coastguard Worker; X64-NOT: setne 16*9880d681SAndroid Build Coastguard Worker; X64: xorl 17*9880d681SAndroid Build Coastguard Worker; X64: testb $64 18*9880d681SAndroid Build Coastguard Worker; X64: je 19*9880d681SAndroid Build Coastguard Worker %0 = and i32 %a, 16384 20*9880d681SAndroid Build Coastguard Worker %1 = icmp ne i32 %0, 0 21*9880d681SAndroid Build Coastguard Worker %2 = and i32 %b, 16384 22*9880d681SAndroid Build Coastguard Worker %3 = icmp ne i32 %2, 0 23*9880d681SAndroid Build Coastguard Worker %4 = xor i1 %1, %3 24*9880d681SAndroid Build Coastguard Worker br i1 %4, label %bb1, label %bb 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerbb: ; preds = %entry 27*9880d681SAndroid Build Coastguard Worker %5 = tail call i32 (...) @foo() nounwind ; <i32> [#uses=1] 28*9880d681SAndroid Build Coastguard Worker ret i32 %5 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Workerbb1: ; preds = %entry 31*9880d681SAndroid Build Coastguard Worker %6 = tail call i32 (...) @bar() nounwind ; <i32> [#uses=1] 32*9880d681SAndroid Build Coastguard Worker ret i32 %6 33*9880d681SAndroid Build Coastguard Worker} 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workerdeclare i32 @foo(...) 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Workerdeclare i32 @bar(...) 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerdefine i32 @t2(i32 %x, i32 %y) nounwind ssp { 40*9880d681SAndroid Build Coastguard Worker; X32-LABEL: t2: 41*9880d681SAndroid Build Coastguard Worker; X32: cmpl 42*9880d681SAndroid Build Coastguard Worker; X32: sete 43*9880d681SAndroid Build Coastguard Worker; X32: cmpl 44*9880d681SAndroid Build Coastguard Worker; X32: sete 45*9880d681SAndroid Build Coastguard Worker; X32-NOT: xor 46*9880d681SAndroid Build Coastguard Worker; X32: je 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Worker; X64-LABEL: t2: 49*9880d681SAndroid Build Coastguard Worker; X64: testl 50*9880d681SAndroid Build Coastguard Worker; X64: sete 51*9880d681SAndroid Build Coastguard Worker; X64: testl 52*9880d681SAndroid Build Coastguard Worker; X64: sete 53*9880d681SAndroid Build Coastguard Worker; X64-NOT: xor 54*9880d681SAndroid Build Coastguard Worker; X64: je 55*9880d681SAndroid Build Coastguard Workerentry: 56*9880d681SAndroid Build Coastguard Worker %0 = icmp eq i32 %x, 0 ; <i1> [#uses=1] 57*9880d681SAndroid Build Coastguard Worker %1 = icmp eq i32 %y, 0 ; <i1> [#uses=1] 58*9880d681SAndroid Build Coastguard Worker %2 = xor i1 %1, %0 ; <i1> [#uses=1] 59*9880d681SAndroid Build Coastguard Worker br i1 %2, label %bb, label %return 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerbb: ; preds = %entry 62*9880d681SAndroid Build Coastguard Worker %3 = tail call i32 (...) @foo() nounwind ; <i32> [#uses=0] 63*9880d681SAndroid Build Coastguard Worker ret i32 undef 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %entry 66*9880d681SAndroid Build Coastguard Worker ret i32 undef 67*9880d681SAndroid Build Coastguard Worker} 68