1; RUN: opt < %s -cost-model -analyze -mtriple=systemz-unknown -mcpu=z13 | FileCheck %s 2 3define void @and() { 4 %res0 = and i8 undef, undef 5 %res1 = and i16 undef, undef 6 %res2 = and i32 undef, undef 7 %res3 = and i64 undef, undef 8 %res4 = and <2 x i8> undef, undef 9 %res5 = and <2 x i16> undef, undef 10 %res6 = and <2 x i32> undef, undef 11 %res7 = and <2 x i64> undef, undef 12 %res8 = and <4 x i8> undef, undef 13 %res9 = and <4 x i16> undef, undef 14 %res10 = and <4 x i32> undef, undef 15 %res11 = and <4 x i64> undef, undef 16 %res12 = and <8 x i8> undef, undef 17 %res13 = and <8 x i16> undef, undef 18 %res14 = and <8 x i32> undef, undef 19 %res15 = and <8 x i64> undef, undef 20 %res16 = and <16 x i8> undef, undef 21 %res17 = and <16 x i16> undef, undef 22 %res18 = and <16 x i32> undef, undef 23 %res19 = and <16 x i64> undef, undef 24 25; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res0 = and i8 undef, undef 26; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res1 = and i16 undef, undef 27; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = and i32 undef, undef 28; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = and i64 undef, undef 29; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = and <2 x i8> undef, undef 30; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = and <2 x i16> undef, undef 31; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = and <2 x i32> undef, undef 32; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = and <2 x i64> undef, undef 33; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = and <4 x i8> undef, undef 34; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = and <4 x i16> undef, undef 35; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = and <4 x i32> undef, undef 36; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = and <4 x i64> undef, undef 37; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = and <8 x i8> undef, undef 38; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = and <8 x i16> undef, undef 39; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = and <8 x i32> undef, undef 40; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = and <8 x i64> undef, undef 41; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = and <16 x i8> undef, undef 42; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = and <16 x i16> undef, undef 43; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = and <16 x i32> undef, undef 44; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = and <16 x i64> undef, undef 45 46 ret void; 47} 48 49define void @ashr() { 50 %res0 = ashr i8 undef, undef 51 %res1 = ashr i16 undef, undef 52 %res2 = ashr i32 undef, undef 53 %res3 = ashr i64 undef, undef 54 %res4 = ashr <2 x i8> undef, undef 55 %res5 = ashr <2 x i16> undef, undef 56 %res6 = ashr <2 x i32> undef, undef 57 %res7 = ashr <2 x i64> undef, undef 58 %res8 = ashr <4 x i8> undef, undef 59 %res9 = ashr <4 x i16> undef, undef 60 %res10 = ashr <4 x i32> undef, undef 61 %res11 = ashr <4 x i64> undef, undef 62 %res12 = ashr <8 x i8> undef, undef 63 %res13 = ashr <8 x i16> undef, undef 64 %res14 = ashr <8 x i32> undef, undef 65 %res15 = ashr <8 x i64> undef, undef 66 %res16 = ashr <16 x i8> undef, undef 67 %res17 = ashr <16 x i16> undef, undef 68 %res18 = ashr <16 x i32> undef, undef 69 %res19 = ashr <16 x i64> undef, undef 70 71; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res0 = ashr i8 undef, undef 72; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res1 = ashr i16 undef, undef 73; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = ashr i32 undef, undef 74; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = ashr i64 undef, undef 75; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = ashr <2 x i8> undef, undef 76; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = ashr <2 x i16> undef, undef 77; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = ashr <2 x i32> undef, undef 78; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = ashr <2 x i64> undef, undef 79; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = ashr <4 x i8> undef, undef 80; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = ashr <4 x i16> undef, undef 81; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = ashr <4 x i32> undef, undef 82; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = ashr <4 x i64> undef, undef 83; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = ashr <8 x i8> undef, undef 84; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = ashr <8 x i16> undef, undef 85; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = ashr <8 x i32> undef, undef 86; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = ashr <8 x i64> undef, undef 87; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = ashr <16 x i8> undef, undef 88; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = ashr <16 x i16> undef, undef 89; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = ashr <16 x i32> undef, undef 90; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = ashr <16 x i64> undef, undef 91 92 ret void; 93} 94 95define void @lshr() { 96 %res0 = lshr i8 undef, undef 97 %res1 = lshr i16 undef, undef 98 %res2 = lshr i32 undef, undef 99 %res3 = lshr i64 undef, undef 100 %res4 = lshr <2 x i8> undef, undef 101 %res5 = lshr <2 x i16> undef, undef 102 %res6 = lshr <2 x i32> undef, undef 103 %res7 = lshr <2 x i64> undef, undef 104 %res8 = lshr <4 x i8> undef, undef 105 %res9 = lshr <4 x i16> undef, undef 106 %res10 = lshr <4 x i32> undef, undef 107 %res11 = lshr <4 x i64> undef, undef 108 %res12 = lshr <8 x i8> undef, undef 109 %res13 = lshr <8 x i16> undef, undef 110 %res14 = lshr <8 x i32> undef, undef 111 %res15 = lshr <8 x i64> undef, undef 112 %res16 = lshr <16 x i8> undef, undef 113 %res17 = lshr <16 x i16> undef, undef 114 %res18 = lshr <16 x i32> undef, undef 115 %res19 = lshr <16 x i64> undef, undef 116 117; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res0 = lshr i8 undef, undef 118; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res1 = lshr i16 undef, undef 119; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = lshr i32 undef, undef 120; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = lshr i64 undef, undef 121; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = lshr <2 x i8> undef, undef 122; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = lshr <2 x i16> undef, undef 123; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = lshr <2 x i32> undef, undef 124; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = lshr <2 x i64> undef, undef 125; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = lshr <4 x i8> undef, undef 126; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = lshr <4 x i16> undef, undef 127; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = lshr <4 x i32> undef, undef 128; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = lshr <4 x i64> undef, undef 129; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = lshr <8 x i8> undef, undef 130; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = lshr <8 x i16> undef, undef 131; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = lshr <8 x i32> undef, undef 132; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = lshr <8 x i64> undef, undef 133; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = lshr <16 x i8> undef, undef 134; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = lshr <16 x i16> undef, undef 135; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = lshr <16 x i32> undef, undef 136; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = lshr <16 x i64> undef, undef 137 138 ret void; 139} 140 141define void @or() { 142 %res0 = or i8 undef, undef 143 %res1 = or i16 undef, undef 144 %res2 = or i32 undef, undef 145 %res3 = or i64 undef, undef 146 %res4 = or <2 x i8> undef, undef 147 %res5 = or <2 x i16> undef, undef 148 %res6 = or <2 x i32> undef, undef 149 %res7 = or <2 x i64> undef, undef 150 %res8 = or <4 x i8> undef, undef 151 %res9 = or <4 x i16> undef, undef 152 %res10 = or <4 x i32> undef, undef 153 %res11 = or <4 x i64> undef, undef 154 %res12 = or <8 x i8> undef, undef 155 %res13 = or <8 x i16> undef, undef 156 %res14 = or <8 x i32> undef, undef 157 %res15 = or <8 x i64> undef, undef 158 %res16 = or <16 x i8> undef, undef 159 %res17 = or <16 x i16> undef, undef 160 %res18 = or <16 x i32> undef, undef 161 %res19 = or <16 x i64> undef, undef 162 163; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res0 = or i8 undef, undef 164; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res1 = or i16 undef, undef 165; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = or i32 undef, undef 166; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = or i64 undef, undef 167; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = or <2 x i8> undef, undef 168; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = or <2 x i16> undef, undef 169; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = or <2 x i32> undef, undef 170; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = or <2 x i64> undef, undef 171; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = or <4 x i8> undef, undef 172; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = or <4 x i16> undef, undef 173; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = or <4 x i32> undef, undef 174; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = or <4 x i64> undef, undef 175; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = or <8 x i8> undef, undef 176; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = or <8 x i16> undef, undef 177; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = or <8 x i32> undef, undef 178; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = or <8 x i64> undef, undef 179; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = or <16 x i8> undef, undef 180; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = or <16 x i16> undef, undef 181; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = or <16 x i32> undef, undef 182; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = or <16 x i64> undef, undef 183 184 ret void; 185} 186 187define void @shl() { 188 %res0 = shl i8 undef, undef 189 %res1 = shl i16 undef, undef 190 %res2 = shl i32 undef, undef 191 %res3 = shl i64 undef, undef 192 %res4 = shl <2 x i8> undef, undef 193 %res5 = shl <2 x i16> undef, undef 194 %res6 = shl <2 x i32> undef, undef 195 %res7 = shl <2 x i64> undef, undef 196 %res8 = shl <4 x i8> undef, undef 197 %res9 = shl <4 x i16> undef, undef 198 %res10 = shl <4 x i32> undef, undef 199 %res11 = shl <4 x i64> undef, undef 200 %res12 = shl <8 x i8> undef, undef 201 %res13 = shl <8 x i16> undef, undef 202 %res14 = shl <8 x i32> undef, undef 203 %res15 = shl <8 x i64> undef, undef 204 %res16 = shl <16 x i8> undef, undef 205 %res17 = shl <16 x i16> undef, undef 206 %res18 = shl <16 x i32> undef, undef 207 %res19 = shl <16 x i64> undef, undef 208 209; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res0 = shl i8 undef, undef 210; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res1 = shl i16 undef, undef 211; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = shl i32 undef, undef 212; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = shl i64 undef, undef 213; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = shl <2 x i8> undef, undef 214; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = shl <2 x i16> undef, undef 215; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = shl <2 x i32> undef, undef 216; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = shl <2 x i64> undef, undef 217; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = shl <4 x i8> undef, undef 218; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = shl <4 x i16> undef, undef 219; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = shl <4 x i32> undef, undef 220; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = shl <4 x i64> undef, undef 221; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = shl <8 x i8> undef, undef 222; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = shl <8 x i16> undef, undef 223; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = shl <8 x i32> undef, undef 224; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = shl <8 x i64> undef, undef 225; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = shl <16 x i8> undef, undef 226; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = shl <16 x i16> undef, undef 227; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = shl <16 x i32> undef, undef 228; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = shl <16 x i64> undef, undef 229 230 ret void; 231} 232 233define void @xor() { 234 %res0 = xor i8 undef, undef 235 %res1 = xor i16 undef, undef 236 %res2 = xor i32 undef, undef 237 %res3 = xor i64 undef, undef 238 %res4 = xor <2 x i8> undef, undef 239 %res5 = xor <2 x i16> undef, undef 240 %res6 = xor <2 x i32> undef, undef 241 %res7 = xor <2 x i64> undef, undef 242 %res8 = xor <4 x i8> undef, undef 243 %res9 = xor <4 x i16> undef, undef 244 %res10 = xor <4 x i32> undef, undef 245 %res11 = xor <4 x i64> undef, undef 246 %res12 = xor <8 x i8> undef, undef 247 %res13 = xor <8 x i16> undef, undef 248 %res14 = xor <8 x i32> undef, undef 249 %res15 = xor <8 x i64> undef, undef 250 %res16 = xor <16 x i8> undef, undef 251 %res17 = xor <16 x i16> undef, undef 252 %res18 = xor <16 x i32> undef, undef 253 %res19 = xor <16 x i64> undef, undef 254 255; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res0 = xor i8 undef, undef 256; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res1 = xor i16 undef, undef 257; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res2 = xor i32 undef, undef 258; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res3 = xor i64 undef, undef 259; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res4 = xor <2 x i8> undef, undef 260; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res5 = xor <2 x i16> undef, undef 261; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res6 = xor <2 x i32> undef, undef 262; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res7 = xor <2 x i64> undef, undef 263; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res8 = xor <4 x i8> undef, undef 264; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res9 = xor <4 x i16> undef, undef 265; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res10 = xor <4 x i32> undef, undef 266; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res11 = xor <4 x i64> undef, undef 267; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res12 = xor <8 x i8> undef, undef 268; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res13 = xor <8 x i16> undef, undef 269; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res14 = xor <8 x i32> undef, undef 270; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res15 = xor <8 x i64> undef, undef 271; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %res16 = xor <16 x i8> undef, undef 272; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %res17 = xor <16 x i16> undef, undef 273; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %res18 = xor <16 x i32> undef, undef 274; CHECK: Cost Model: Found an estimated cost of 8 for instruction: %res19 = xor <16 x i64> undef, undef 275 276 ret void; 277} 278