Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 1 | ; This test makes sure that these instructions are properly eliminated. |
| 2 | ; |
Reid Spencer | 91948d4 | 2007-04-14 20:13:02 +0000 | [diff] [blame] | 3 | ; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \ |
| 4 | ; RUN: grep -v xor | not grep {or } |
Reid Spencer | ede8c3b | 2007-04-15 07:38:21 +0000 | [diff] [blame] | 5 | ; END. |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 6 | |
| 7 | implementation |
| 8 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 9 | int %test1(int %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 10 | %B = or int %A, 0 |
| 11 | ret int %B |
| 12 | } |
| 13 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 14 | int %test2(int %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 15 | %B = or int %A, -1 |
| 16 | ret int %B |
| 17 | } |
| 18 | |
Chris Lattner | f67d52d | 2003-03-10 22:43:56 +0000 | [diff] [blame] | 19 | ubyte %test2a(ubyte %A) { |
| 20 | %B = or ubyte %A, 255 |
| 21 | ret ubyte %B |
| 22 | } |
| 23 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 24 | bool %test3(bool %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 25 | %B = or bool %A, false |
| 26 | ret bool %B |
| 27 | } |
| 28 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 29 | bool %test4(bool %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 30 | %B = or bool %A, true |
| 31 | ret bool %B |
| 32 | } |
| 33 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 34 | bool %test5(bool %A) { |
Chris Lattner | 6022ad0 | 2002-05-06 05:51:26 +0000 | [diff] [blame] | 35 | %B = or bool %A, %A |
| 36 | ret bool %B |
| 37 | } |
| 38 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 39 | int %test6(int %A) { |
Chris Lattner | 6022ad0 | 2002-05-06 05:51:26 +0000 | [diff] [blame] | 40 | %B = or int %A, %A |
| 41 | ret int %B |
| 42 | } |
| 43 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 44 | int %test7(int %A) { ; A | ~A == -1 |
Chris Lattner | c5fccf3 | 2003-02-18 19:28:47 +0000 | [diff] [blame] | 45 | %NotA = xor int -1, %A |
| 46 | %B = or int %A, %NotA |
| 47 | ret int %B |
| 48 | } |
Chris Lattner | 96c4dd9 | 2003-03-10 18:24:04 +0000 | [diff] [blame] | 49 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 50 | ubyte %test8(ubyte %A) { |
Chris Lattner | f67d52d | 2003-03-10 22:43:56 +0000 | [diff] [blame] | 51 | %B = or ubyte %A, 254 |
| 52 | %C = or ubyte %B, 1 |
| 53 | ret ubyte %C |
| 54 | } |
Chris Lattner | dec1367 | 2003-03-10 23:52:54 +0000 | [diff] [blame] | 55 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 56 | ubyte %test9(ubyte %A, ubyte %B) { ; Test that (A|c1)|(B|c2) == (A|B)|(c1|c2) |
Chris Lattner | cb26914 | 2003-03-11 00:10:59 +0000 | [diff] [blame] | 57 | %C = or ubyte %A, 1 |
| 58 | %D = or ubyte %B, 254 |
| 59 | %E = or ubyte %C, %D |
| 60 | ret ubyte %E |
| 61 | } |
Chris Lattner | e1957a3 | 2003-06-04 04:37:46 +0000 | [diff] [blame] | 62 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 63 | ubyte %test10(ubyte %A) { |
Chris Lattner | d566323 | 2003-07-23 18:28:42 +0000 | [diff] [blame] | 64 | %B = or ubyte %A, 1 |
| 65 | %C = and ubyte %B, 254 |
| 66 | %D = or ubyte %C, 254 ; (X & C1) | C2 --> (X | C2) & (C1|C2) |
| 67 | ret ubyte %D |
| 68 | } |
| 69 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 70 | ubyte %test11(ubyte %A) { |
Chris Lattner | d566323 | 2003-07-23 18:28:42 +0000 | [diff] [blame] | 71 | %B = or ubyte %A, 254 |
| 72 | %C = xor ubyte %B, 13 |
| 73 | %D = or ubyte %C, 1 ; (X ^ C1) | C2 --> (X | C2) ^ (C1&~C2) |
| 74 | %E = xor ubyte %D, 12 |
| 75 | ret ubyte %E |
| 76 | } |
Chris Lattner | a439aaf | 2003-07-23 19:05:29 +0000 | [diff] [blame] | 77 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 78 | uint %test12(uint %A) { |
Chris Lattner | a439aaf | 2003-07-23 19:05:29 +0000 | [diff] [blame] | 79 | %B = or uint %A, 4 ; Should be eliminated |
| 80 | %C = and uint %B, 8 |
| 81 | ret uint %C |
| 82 | } |
| 83 | |
Chris Lattner | fbfe819 | 2003-07-23 21:11:56 +0000 | [diff] [blame] | 84 | uint %test13(uint %A) { |
Chris Lattner | fcd1efb | 2003-07-23 19:24:34 +0000 | [diff] [blame] | 85 | %B = or uint %A, 12 |
| 86 | %C = and uint %B, 8 ; Always equal to 8 |
| 87 | ret uint %C |
| 88 | } |
| 89 | |
Chris Lattner | 6dc37ab | 2003-07-24 19:31:08 +0000 | [diff] [blame] | 90 | bool %test14(uint %A, uint %B) { |
| 91 | %C1 = setlt uint %A, %B |
| 92 | %C2 = setgt uint %A, %B |
| 93 | %D = or bool %C1, %C2 ; (A < B) | (A > B) === A != B |
| 94 | ret bool %D |
| 95 | } |
| 96 | |
Chris Lattner | daff644 | 2003-07-24 19:44:51 +0000 | [diff] [blame] | 97 | bool %test15(uint %A, uint %B) { |
| 98 | %C1 = setlt uint %A, %B |
| 99 | %C2 = seteq uint %A, %B |
| 100 | %D = or bool %C1, %C2 ; (A < B) | (A == B) === A <= B |
| 101 | ret bool %D |
| 102 | } |
| 103 | |
Chris Lattner | 4d9385c | 2003-08-12 19:10:50 +0000 | [diff] [blame] | 104 | int %test16(int %A) { |
| 105 | %B = and int %A, 1 |
| 106 | %C = and int %A, -2 ; -2 = ~1 |
| 107 | %D = or int %B, %C ; %D = and int %B, -1 == %B |
| 108 | ret int %D |
| 109 | } |
| 110 | |
| 111 | int %test17(int %A) { |
| 112 | %B = and int %A, 1 |
| 113 | %C = and int %A, 4 |
| 114 | %D = or int %B, %C ; %D = and int %B, 5 |
| 115 | ret int %D |
| 116 | } |
Chris Lattner | efc0614 | 2004-09-28 22:31:49 +0000 | [diff] [blame] | 117 | |
| 118 | bool %test18(int %A) { |
| 119 | %B = setge int %A, 100 |
| 120 | %C = setlt int %A, 50 |
| 121 | %D = or bool %B, %C ;; (A-50) >u 50 |
| 122 | ret bool %D |
| 123 | } |
| 124 | |
| 125 | bool %test19(int %A) { |
| 126 | %B = seteq int %A, 50 |
| 127 | %C = seteq int %A, 51 |
| 128 | %D = or bool %B, %C ;; (A-50) < 2 |
| 129 | ret bool %D |
| 130 | } |
| 131 | |
Chris Lattner | ce8dd82 | 2005-05-06 00:58:09 +0000 | [diff] [blame] | 132 | int %test20(int %x) { |
| 133 | %y = and int %x, 123 |
| 134 | %z = or int %y, %x |
| 135 | ret int %z |
| 136 | } |
Chris Lattner | c6d63a9 | 2005-09-18 03:39:02 +0000 | [diff] [blame] | 137 | |
| 138 | uint %test21(uint %tmp.1) { |
| 139 | %tmp.1.mask1 = add uint %tmp.1, 2 |
| 140 | %tmp.3 = and uint %tmp.1.mask1, 4294967294 |
| 141 | %tmp.5 = and uint %tmp.1, 1 |
| 142 | %tmp.6 = or uint %tmp.5, %tmp.3 ;; add tmp.1, 2 |
| 143 | ret uint %tmp.6 |
| 144 | } |
Chris Lattner | e6ebe1a | 2006-02-12 08:01:35 +0000 | [diff] [blame] | 145 | |
| 146 | int %test22(int %B) { |
| 147 | %ELIM41 = and int %B, 1 ; <int> [#uses=1] |
| 148 | %ELIM7 = and int %B, -2 ; <int> [#uses=1] |
| 149 | %ELIM5 = or int %ELIM41, %ELIM7 ; <int> [#uses=1] |
| 150 | ret int %ELIM5 |
| 151 | } |
Chris Lattner | 69c68c3 | 2006-02-26 19:55:30 +0000 | [diff] [blame] | 152 | |
| 153 | ushort %test23(ushort %A) { |
| 154 | %B = shr ushort %A, ubyte 1 |
| 155 | %C = or ushort %B, 32768 ;; fold or into xor |
| 156 | %D = xor ushort %C, 8193 |
| 157 | ret ushort %D |
| 158 | } |