Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 1 | ; This test makes sure that these instructions are properly eliminated. |
| 2 | ; |
| 3 | |
Misha Brukman | edf4bab | 2003-09-16 15:29:54 +0000 | [diff] [blame] | 4 | ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep and |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 5 | |
| 6 | implementation |
| 7 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 8 | int %test1(int %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 9 | %B = and int %A, 0 ; zero result |
| 10 | ret int %B |
| 11 | } |
| 12 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 13 | int %test2(int %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 14 | %B = and int %A, -1 ; noop |
| 15 | ret int %B |
| 16 | } |
| 17 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 18 | bool %test3(bool %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 19 | %B = and bool %A, false ; always = false |
| 20 | ret bool %B |
| 21 | } |
| 22 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 23 | bool %test4(bool %A) { |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 24 | %B = and bool %A, true ; noop |
| 25 | ret bool %B |
| 26 | } |
| 27 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 28 | int %test5(int %A) { |
Chris Lattner | 6022ad0 | 2002-05-06 05:51:26 +0000 | [diff] [blame] | 29 | %B = and int %A, %A |
| 30 | ret int %B |
| 31 | } |
| 32 | |
Chris Lattner | 2deaf77 | 2003-02-18 18:06:44 +0000 | [diff] [blame] | 33 | bool %test6(bool %A) { |
Chris Lattner | 6022ad0 | 2002-05-06 05:51:26 +0000 | [diff] [blame] | 34 | %B = and bool %A, %A |
| 35 | ret bool %B |
| 36 | } |
Chris Lattner | 74e9547 | 2002-05-06 05:43:36 +0000 | [diff] [blame] | 37 | |
Chris Lattner | c5fccf3 | 2003-02-18 19:28:47 +0000 | [diff] [blame] | 38 | int %test7(int %A) { ; A & ~A == 0 |
| 39 | %NotA = xor int %A, -1 |
| 40 | %B = and int %A, %NotA |
| 41 | ret int %B |
Chris Lattner | f67d52d | 2003-03-10 22:43:56 +0000 | [diff] [blame] | 42 | } |
| 43 | |
| 44 | ubyte %test8(ubyte %A) { ; AND associates |
| 45 | %B = and ubyte %A, 3 |
| 46 | %C = and ubyte %B, 4 |
| 47 | ret ubyte %C |
| 48 | } |
Chris Lattner | dec1367 | 2003-03-10 23:52:54 +0000 | [diff] [blame] | 49 | |
Chris Lattner | 9af9880 | 2003-07-22 21:44:06 +0000 | [diff] [blame] | 50 | bool %test9(int %A) { |
| 51 | %B = and int %A, -2147483648 ; Test of sign bit, convert to setle %A, 0 |
Chris Lattner | dad4e27 | 2003-08-13 20:17:41 +0000 | [diff] [blame] | 52 | %C = setne int %B, 0 |
Chris Lattner | 9af9880 | 2003-07-22 21:44:06 +0000 | [diff] [blame] | 53 | ret bool %C |
| 54 | } |
| 55 | |
| 56 | bool %test9(uint %A) { |
| 57 | %B = and uint %A, 2147483648 ; Test of sign bit, convert to setle %A, 0 |
Chris Lattner | dad4e27 | 2003-08-13 20:17:41 +0000 | [diff] [blame] | 58 | %C = setne uint %B, 0 |
Chris Lattner | 9af9880 | 2003-07-22 21:44:06 +0000 | [diff] [blame] | 59 | ret bool %C |
| 60 | } |
Chris Lattner | aeef93c | 2003-07-23 17:56:34 +0000 | [diff] [blame] | 61 | |
| 62 | uint %test10(uint %A) { |
| 63 | %B = and uint %A, 12 |
| 64 | %C = xor uint %B, 15 |
Chris Lattner | d566323 | 2003-07-23 18:28:42 +0000 | [diff] [blame] | 65 | %D = and uint %C, 1 ; (X ^ C1) & C2 --> (X & C2) ^ (C1&C2) |
Chris Lattner | aeef93c | 2003-07-23 17:56:34 +0000 | [diff] [blame] | 66 | ret uint %D |
| 67 | } |
Chris Lattner | b69f30c | 2003-07-23 19:35:51 +0000 | [diff] [blame] | 68 | |
| 69 | uint %test11(uint %A, uint* %P) { |
| 70 | %B = or uint %A, 3 |
| 71 | %C = xor uint %B, 12 |
| 72 | store uint %C, uint* %P ; additional use of C |
| 73 | %D = and uint %C, 3 ; %C = and uint %B, 3 --> 3 |
| 74 | ret uint %D |
| 75 | } |
| 76 | |
Chris Lattner | daff644 | 2003-07-24 19:44:51 +0000 | [diff] [blame] | 77 | bool %test12(uint %A, uint %B) { |
| 78 | %C1 = setlt uint %A, %B |
| 79 | %C2 = setle uint %A, %B |
| 80 | %D = and bool %C1, %C2 ; (A < B) & (A <= B) === (A < B) |
| 81 | ret bool %D |
| 82 | } |
| 83 | |
| 84 | bool %test13(uint %A, uint %B) { |
| 85 | %C1 = setlt uint %A, %B |
| 86 | %C2 = setgt uint %A, %B |
| 87 | %D = and bool %C1, %C2 ; (A < B) & (A > B) === false |
| 88 | ret bool %D |
| 89 | } |
Chris Lattner | b69f30c | 2003-07-23 19:35:51 +0000 | [diff] [blame] | 90 | |
Chris Lattner | 9b741f1 | 2003-08-13 05:27:57 +0000 | [diff] [blame] | 91 | bool %test14(ubyte %A) { |
| 92 | %B = and ubyte %A, 128 |
| 93 | %C = setne ubyte %B, 0 |
| 94 | ret bool %C |
| 95 | } |
Chris Lattner | d441d40 | 2003-09-19 19:04:43 +0000 | [diff] [blame] | 96 | |
| 97 | ubyte %test15(ubyte %A) { |
| 98 | %B = shr ubyte %A, ubyte 7 |
| 99 | %C = and ubyte %B, 2 ; Always equals zero |
| 100 | ret ubyte %C |
| 101 | } |
| 102 | |
| 103 | ubyte %test16(ubyte %A) { |
| 104 | %B = shl ubyte %A, ubyte 2 |
| 105 | %C = and ubyte %B, 3 |
| 106 | ret ubyte %C |
| 107 | } |
Chris Lattner | d5829aa | 2004-06-18 06:07:17 +0000 | [diff] [blame] | 108 | |
| 109 | sbyte %test17(sbyte %X, sbyte %Y) { ;; ~(~X & Y) --> (X | ~Y) |
| 110 | %B = xor sbyte %X, -1 |
| 111 | %C = and sbyte %B, %Y |
| 112 | %D = xor sbyte %C, -1 |
| 113 | ret sbyte %D |
| 114 | } |
| 115 | |
Chris Lattner | 45a5ace | 2004-09-23 21:42:49 +0000 | [diff] [blame] | 116 | bool %test18(int %A) { |
| 117 | %B = and int %A, -128 |
| 118 | %C = setne int %B, 0 ;; C >= 128 |
| 119 | ret bool %C |
| 120 | } |
| 121 | |
Chris Lattner | 5f9319a | 2004-09-27 19:25:20 +0000 | [diff] [blame] | 122 | bool %test18a(ubyte %A) { |
| 123 | %B = and ubyte %A, 254 |
| 124 | %C = seteq ubyte %B, 0 |
| 125 | ret bool %C |
| 126 | } |
| 127 | |
Chris Lattner | 8c1c691 | 2004-09-24 15:18:43 +0000 | [diff] [blame] | 128 | int %test19(int %A) { |
| 129 | %B = shl int %A, ubyte 3 |
| 130 | %C = and int %B, -2 ;; Clearing a zero bit |
| 131 | ret int %C |
| 132 | } |
| 133 | |
| 134 | ubyte %test20(ubyte %A) { |
| 135 | %C = shr ubyte %A, ubyte 7 |
| 136 | %D = and ubyte %C, 1 ;; Unneeded |
| 137 | ret ubyte %D |
| 138 | } |
| 139 | |
Chris Lattner | 3cbcd25 | 2004-09-28 21:39:35 +0000 | [diff] [blame] | 140 | bool %test22(int %A) { |
| 141 | %B = seteq int %A, 1 |
| 142 | %C = setge int %A, 3 |
| 143 | %D = and bool %B, %C ;; False |
| 144 | ret bool %D |
| 145 | } |
| 146 | |
| 147 | bool %test23(int %A) { |
| 148 | %B = setgt int %A, 1 |
| 149 | %C = setle int %A, 2 |
| 150 | %D = and bool %B, %C ;; A == 2 |
| 151 | ret bool %D |
| 152 | } |
| 153 | |
| 154 | bool %test24(int %A) { |
| 155 | %B = setgt int %A, 1 |
| 156 | %C = setne int %A, 2 |
| 157 | %D = and bool %B, %C ;; A > 2 |
| 158 | ret bool %D |
| 159 | } |
| 160 | |
| 161 | bool %test25(int %A) { |
| 162 | %B = setge int %A, 50 |
| 163 | %C = setlt int %A, 100 |
| 164 | %D = and bool %B, %C ;; (A-50) <u 50 |
| 165 | ret bool %D |
| 166 | } |
| 167 | |
| 168 | bool %test26(int %A) { |
| 169 | %B = setne int %A, 50 |
| 170 | %C = setne int %A, 51 |
| 171 | %D = and bool %B, %C ;; (A-50) > 1 |
| 172 | ret bool %D |
| 173 | } |
| 174 | |
Chris Lattner | 9467062 | 2004-10-08 05:03:25 +0000 | [diff] [blame] | 175 | ubyte %test27(ubyte %A) { |
| 176 | %B = and ubyte %A, 4 |
| 177 | %C = sub ubyte %B, 16 |
| 178 | %D = and ubyte %C, 240 ;; 0xF0 |
| 179 | %E = add ubyte %D, 16 |
| 180 | ret ubyte %E |
| 181 | } |
Chris Lattner | 329d025 | 2005-01-01 16:13:19 +0000 | [diff] [blame] | 182 | |
| 183 | int %test28(int %X) { ;; This is juse a zero extending shr. |
| 184 | %Y = shr int %X, ubyte 24 ;; Sign extend |
| 185 | %Z = and int %Y, 255 ;; Mask out sign bits |
| 186 | ret int %Z |
| 187 | } |
| 188 | |
| 189 | int %test29(ubyte %X) { |
| 190 | %Y = cast ubyte %X to int |
| 191 | %Z = and int %Y, 255 ;; Zero extend makes this unneeded. |
| 192 | ret int %Z |
| 193 | } |
| 194 | |
Chris Lattner | 8169e16 | 2005-05-06 01:52:52 +0000 | [diff] [blame^] | 195 | int %test30(bool %X) { |
| 196 | %Y = cast bool %X to int |
| 197 | %Z = and int %Y, 1 |
| 198 | ret int %Z |
| 199 | } |