2002-05-06 05:43:36 +00:00
|
|
|
; This test makes sure that these instructions are properly eliminated.
|
|
|
|
;
|
|
|
|
|
2003-09-16 15:29:54 +00:00
|
|
|
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep and
|
2002-05-06 05:43:36 +00:00
|
|
|
|
|
|
|
implementation
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
int %test1(int %A) {
|
2002-05-06 05:43:36 +00:00
|
|
|
%B = and int %A, 0 ; zero result
|
|
|
|
ret int %B
|
|
|
|
}
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
int %test2(int %A) {
|
2002-05-06 05:43:36 +00:00
|
|
|
%B = and int %A, -1 ; noop
|
|
|
|
ret int %B
|
|
|
|
}
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
bool %test3(bool %A) {
|
2002-05-06 05:43:36 +00:00
|
|
|
%B = and bool %A, false ; always = false
|
|
|
|
ret bool %B
|
|
|
|
}
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
bool %test4(bool %A) {
|
2002-05-06 05:43:36 +00:00
|
|
|
%B = and bool %A, true ; noop
|
|
|
|
ret bool %B
|
|
|
|
}
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
int %test5(int %A) {
|
2002-05-06 05:51:26 +00:00
|
|
|
%B = and int %A, %A
|
|
|
|
ret int %B
|
|
|
|
}
|
|
|
|
|
2003-02-18 18:06:44 +00:00
|
|
|
bool %test6(bool %A) {
|
2002-05-06 05:51:26 +00:00
|
|
|
%B = and bool %A, %A
|
|
|
|
ret bool %B
|
|
|
|
}
|
2002-05-06 05:43:36 +00:00
|
|
|
|
2003-02-18 19:28:47 +00:00
|
|
|
int %test7(int %A) { ; A & ~A == 0
|
|
|
|
%NotA = xor int %A, -1
|
|
|
|
%B = and int %A, %NotA
|
|
|
|
ret int %B
|
2003-03-10 22:43:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ubyte %test8(ubyte %A) { ; AND associates
|
|
|
|
%B = and ubyte %A, 3
|
|
|
|
%C = and ubyte %B, 4
|
|
|
|
ret ubyte %C
|
|
|
|
}
|
2003-03-10 23:52:54 +00:00
|
|
|
|
2003-07-22 21:44:06 +00:00
|
|
|
bool %test9(int %A) {
|
|
|
|
%B = and int %A, -2147483648 ; Test of sign bit, convert to setle %A, 0
|
2003-08-13 20:17:41 +00:00
|
|
|
%C = setne int %B, 0
|
2003-07-22 21:44:06 +00:00
|
|
|
ret bool %C
|
|
|
|
}
|
|
|
|
|
|
|
|
bool %test9(uint %A) {
|
|
|
|
%B = and uint %A, 2147483648 ; Test of sign bit, convert to setle %A, 0
|
2003-08-13 20:17:41 +00:00
|
|
|
%C = setne uint %B, 0
|
2003-07-22 21:44:06 +00:00
|
|
|
ret bool %C
|
|
|
|
}
|
2003-07-23 17:56:34 +00:00
|
|
|
|
|
|
|
uint %test10(uint %A) {
|
|
|
|
%B = and uint %A, 12
|
|
|
|
%C = xor uint %B, 15
|
2003-07-23 18:28:42 +00:00
|
|
|
%D = and uint %C, 1 ; (X ^ C1) & C2 --> (X & C2) ^ (C1&C2)
|
2003-07-23 17:56:34 +00:00
|
|
|
ret uint %D
|
|
|
|
}
|
2003-07-23 19:35:51 +00:00
|
|
|
|
|
|
|
uint %test11(uint %A, uint* %P) {
|
|
|
|
%B = or uint %A, 3
|
|
|
|
%C = xor uint %B, 12
|
|
|
|
store uint %C, uint* %P ; additional use of C
|
|
|
|
%D = and uint %C, 3 ; %C = and uint %B, 3 --> 3
|
|
|
|
ret uint %D
|
|
|
|
}
|
|
|
|
|
2003-07-24 19:44:51 +00:00
|
|
|
bool %test12(uint %A, uint %B) {
|
|
|
|
%C1 = setlt uint %A, %B
|
|
|
|
%C2 = setle uint %A, %B
|
|
|
|
%D = and bool %C1, %C2 ; (A < B) & (A <= B) === (A < B)
|
|
|
|
ret bool %D
|
|
|
|
}
|
|
|
|
|
|
|
|
bool %test13(uint %A, uint %B) {
|
|
|
|
%C1 = setlt uint %A, %B
|
|
|
|
%C2 = setgt uint %A, %B
|
|
|
|
%D = and bool %C1, %C2 ; (A < B) & (A > B) === false
|
|
|
|
ret bool %D
|
|
|
|
}
|
2003-07-23 19:35:51 +00:00
|
|
|
|
2003-08-13 05:27:57 +00:00
|
|
|
bool %test14(ubyte %A) {
|
|
|
|
%B = and ubyte %A, 128
|
|
|
|
%C = setne ubyte %B, 0
|
|
|
|
ret bool %C
|
|
|
|
}
|
2003-09-19 19:04:43 +00:00
|
|
|
|
|
|
|
ubyte %test15(ubyte %A) {
|
|
|
|
%B = shr ubyte %A, ubyte 7
|
|
|
|
%C = and ubyte %B, 2 ; Always equals zero
|
|
|
|
ret ubyte %C
|
|
|
|
}
|
|
|
|
|
|
|
|
ubyte %test16(ubyte %A) {
|
|
|
|
%B = shl ubyte %A, ubyte 2
|
|
|
|
%C = and ubyte %B, 3
|
|
|
|
ret ubyte %C
|
|
|
|
}
|
2004-06-18 06:07:17 +00:00
|
|
|
|
|
|
|
sbyte %test17(sbyte %X, sbyte %Y) { ;; ~(~X & Y) --> (X | ~Y)
|
|
|
|
%B = xor sbyte %X, -1
|
|
|
|
%C = and sbyte %B, %Y
|
|
|
|
%D = xor sbyte %C, -1
|
|
|
|
ret sbyte %D
|
|
|
|
}
|
|
|
|
|