llvm-6502/test/CodeGen/SystemZ/03-RetXorImmSubreg.ll
2009-09-09 00:09:15 +00:00

59 lines
988 B
LLVM

; RUN: llc < %s -march=systemz | grep xilf | count 9
; RUN: llc < %s -march=systemz | grep llgfr | count 3
; RUN: llc < %s -march=systemz | grep lgfr | count 6
define i32 @foo1(i32 %a, i32 %b) {
entry:
%c = xor i32 %a, 1
ret i32 %c
}
define i32 @foo2(i32 %a, i32 %b) {
entry:
%c = xor i32 %a, 131072
ret i32 %c
}
define i32 @foo7(i32 %a, i32 %b) {
entry:
%c = xor i32 %a, 123456
ret i32 %c
}
define i32 @foo3(i32 %a, i32 %b) zeroext {
entry:
%c = xor i32 %a, 1
ret i32 %c
}
define i32 @foo8(i32 %a, i32 %b) zeroext {
entry:
%c = xor i32 %a, 123456
ret i32 %c
}
define i32 @foo4(i32 %a, i32 %b) signext {
entry:
%c = xor i32 %a, 131072
ret i32 %c
}
define i32 @foo5(i32 %a, i32 %b) zeroext {
entry:
%c = xor i32 %a, 1
ret i32 %c
}
define i32 @foo6(i32 %a, i32 %b) signext {
entry:
%c = xor i32 %a, 131072
ret i32 %c
}
define i32 @foo9(i32 %a, i32 %b) signext {
entry:
%c = xor i32 %a, 123456
ret i32 %c
}