xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/xor-icmp.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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