1 ; RUN: opt < %s -cost-model -analyze -mtriple=systemz-unknown -mcpu=z13 | FileCheck %s 2 3 define void @sext() { 4 %v0 = sext i8 undef to i16 5 %v1 = sext i8 undef to i32 6 %v2 = sext i8 undef to i64 7 %v3 = sext i16 undef to i32 8 %v4 = sext i16 undef to i64 9 %v5 = sext i32 undef to i64 10 %v6 = sext <2 x i8> undef to <2 x i16> 11 %v7 = sext <2 x i8> undef to <2 x i32> 12 %v8 = sext <2 x i8> undef to <2 x i64> 13 %v9 = sext <2 x i16> undef to <2 x i32> 14 %v10 = sext <2 x i16> undef to <2 x i64> 15 %v11 = sext <2 x i32> undef to <2 x i64> 16 %v12 = sext <4 x i8> undef to <4 x i16> 17 %v13 = sext <4 x i8> undef to <4 x i32> 18 %v14 = sext <4 x i8> undef to <4 x i64> 19 %v15 = sext <4 x i16> undef to <4 x i32> 20 %v16 = sext <4 x i16> undef to <4 x i64> 21 %v17 = sext <4 x i32> undef to <4 x i64> 22 %v18 = sext <8 x i8> undef to <8 x i16> 23 %v19 = sext <8 x i8> undef to <8 x i32> 24 %v20 = sext <8 x i8> undef to <8 x i64> 25 %v21 = sext <8 x i16> undef to <8 x i32> 26 %v22 = sext <8 x i16> undef to <8 x i64> 27 %v23 = sext <8 x i32> undef to <8 x i64> 28 %v24 = sext <16 x i8> undef to <16 x i16> 29 %v25 = sext <16 x i8> undef to <16 x i32> 30 %v26 = sext <16 x i8> undef to <16 x i64> 31 %v27 = sext <16 x i16> undef to <16 x i32> 32 %v28 = sext <16 x i16> undef to <16 x i64> 33 %v29 = sext <16 x i32> undef to <16 x i64> 34 35 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v0 = sext i8 undef to i16 36 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v1 = sext i8 undef to i32 37 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v2 = sext i8 undef to i64 38 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v3 = sext i16 undef to i32 39 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v4 = sext i16 undef to i64 40 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v5 = sext i32 undef to i64 41 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v6 = sext <2 x i8> undef to <2 x i16> 42 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v7 = sext <2 x i8> undef to <2 x i32> 43 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v8 = sext <2 x i8> undef to <2 x i64> 44 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v9 = sext <2 x i16> undef to <2 x i32> 45 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v10 = sext <2 x i16> undef to <2 x i64> 46 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v11 = sext <2 x i32> undef to <2 x i64> 47 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v12 = sext <4 x i8> undef to <4 x i16> 48 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v13 = sext <4 x i8> undef to <4 x i32> 49 ; CHECK: Cost Model: Found an estimated cost of 7 for instruction: %v14 = sext <4 x i8> undef to <4 x i64> 50 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v15 = sext <4 x i16> undef to <4 x i32> 51 ; CHECK: Cost Model: Found an estimated cost of 5 for instruction: %v16 = sext <4 x i16> undef to <4 x i64> 52 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v17 = sext <4 x i32> undef to <4 x i64> 53 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v18 = sext <8 x i8> undef to <8 x i16> 54 ; CHECK: Cost Model: Found an estimated cost of 5 for instruction: %v19 = sext <8 x i8> undef to <8 x i32> 55 ; CHECK: Cost Model: Found an estimated cost of 15 for instruction: %v20 = sext <8 x i8> undef to <8 x i64> 56 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v21 = sext <8 x i16> undef to <8 x i32> 57 ; CHECK: Cost Model: Found an estimated cost of 11 for instruction: %v22 = sext <8 x i16> undef to <8 x i64> 58 ; CHECK: Cost Model: Found an estimated cost of 6 for instruction: %v23 = sext <8 x i32> undef to <8 x i64> 59 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v24 = sext <16 x i8> undef to <16 x i16> 60 ; CHECK: Cost Model: Found an estimated cost of 11 for instruction: %v25 = sext <16 x i8> undef to <16 x i32> 61 ; CHECK: Cost Model: Found an estimated cost of 31 for instruction: %v26 = sext <16 x i8> undef to <16 x i64> 62 ; CHECK: Cost Model: Found an estimated cost of 6 for instruction: %v27 = sext <16 x i16> undef to <16 x i32> 63 ; CHECK: Cost Model: Found an estimated cost of 22 for instruction: %v28 = sext <16 x i16> undef to <16 x i64> 64 ; CHECK: Cost Model: Found an estimated cost of 12 for instruction: %v29 = sext <16 x i32> undef to <16 x i64> 65 66 ret void 67 } 68 69 define void @zext() { 70 %v0 = zext i8 undef to i16 71 %v1 = zext i8 undef to i32 72 %v2 = zext i8 undef to i64 73 %v3 = zext i16 undef to i32 74 %v4 = zext i16 undef to i64 75 %v5 = zext i32 undef to i64 76 %v6 = zext <2 x i8> undef to <2 x i16> 77 %v7 = zext <2 x i8> undef to <2 x i32> 78 %v8 = zext <2 x i8> undef to <2 x i64> 79 %v9 = zext <2 x i16> undef to <2 x i32> 80 %v10 = zext <2 x i16> undef to <2 x i64> 81 %v11 = zext <2 x i32> undef to <2 x i64> 82 %v12 = zext <4 x i8> undef to <4 x i16> 83 %v13 = zext <4 x i8> undef to <4 x i32> 84 %v14 = zext <4 x i8> undef to <4 x i64> 85 %v15 = zext <4 x i16> undef to <4 x i32> 86 %v16 = zext <4 x i16> undef to <4 x i64> 87 %v17 = zext <4 x i32> undef to <4 x i64> 88 %v18 = zext <8 x i8> undef to <8 x i16> 89 %v19 = zext <8 x i8> undef to <8 x i32> 90 %v20 = zext <8 x i8> undef to <8 x i64> 91 %v21 = zext <8 x i16> undef to <8 x i32> 92 %v22 = zext <8 x i16> undef to <8 x i64> 93 %v23 = zext <8 x i32> undef to <8 x i64> 94 %v24 = zext <16 x i8> undef to <16 x i16> 95 %v25 = zext <16 x i8> undef to <16 x i32> 96 %v26 = zext <16 x i8> undef to <16 x i64> 97 %v27 = zext <16 x i16> undef to <16 x i32> 98 %v28 = zext <16 x i16> undef to <16 x i64> 99 %v29 = zext <16 x i32> undef to <16 x i64> 100 101 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v0 = zext i8 undef to i16 102 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v1 = zext i8 undef to i32 103 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v2 = zext i8 undef to i64 104 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v3 = zext i16 undef to i32 105 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v4 = zext i16 undef to i64 106 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v5 = zext i32 undef to i64 107 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v6 = zext <2 x i8> undef to <2 x i16> 108 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v7 = zext <2 x i8> undef to <2 x i32> 109 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v8 = zext <2 x i8> undef to <2 x i64> 110 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v9 = zext <2 x i16> undef to <2 x i32> 111 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v10 = zext <2 x i16> undef to <2 x i64> 112 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v11 = zext <2 x i32> undef to <2 x i64> 113 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v12 = zext <4 x i8> undef to <4 x i16> 114 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v13 = zext <4 x i8> undef to <4 x i32> 115 ; CHECK: Cost Model: Found an estimated cost of 7 for instruction: %v14 = zext <4 x i8> undef to <4 x i64> 116 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v15 = zext <4 x i16> undef to <4 x i32> 117 ; CHECK: Cost Model: Found an estimated cost of 5 for instruction: %v16 = zext <4 x i16> undef to <4 x i64> 118 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v17 = zext <4 x i32> undef to <4 x i64> 119 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v18 = zext <8 x i8> undef to <8 x i16> 120 ; CHECK: Cost Model: Found an estimated cost of 5 for instruction: %v19 = zext <8 x i8> undef to <8 x i32> 121 ; CHECK: Cost Model: Found an estimated cost of 15 for instruction: %v20 = zext <8 x i8> undef to <8 x i64> 122 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v21 = zext <8 x i16> undef to <8 x i32> 123 ; CHECK: Cost Model: Found an estimated cost of 11 for instruction: %v22 = zext <8 x i16> undef to <8 x i64> 124 ; CHECK: Cost Model: Found an estimated cost of 6 for instruction: %v23 = zext <8 x i32> undef to <8 x i64> 125 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v24 = zext <16 x i8> undef to <16 x i16> 126 ; CHECK: Cost Model: Found an estimated cost of 11 for instruction: %v25 = zext <16 x i8> undef to <16 x i32> 127 ; CHECK: Cost Model: Found an estimated cost of 31 for instruction: %v26 = zext <16 x i8> undef to <16 x i64> 128 ; CHECK: Cost Model: Found an estimated cost of 6 for instruction: %v27 = zext <16 x i16> undef to <16 x i32> 129 ; CHECK: Cost Model: Found an estimated cost of 22 for instruction: %v28 = zext <16 x i16> undef to <16 x i64> 130 ; CHECK: Cost Model: Found an estimated cost of 12 for instruction: %v29 = zext <16 x i32> undef to <16 x i64> 131 132 ret void 133 } 134 135 define void @trunc() { 136 %v0 = trunc i16 undef to i8 137 %v1 = trunc i32 undef to i16 138 %v2 = trunc i32 undef to i8 139 %v3 = trunc i64 undef to i32 140 %v4 = trunc i64 undef to i16 141 %v5 = trunc i64 undef to i8 142 %v6 = trunc <2 x i16> undef to <2 x i8> 143 %v7 = trunc <2 x i32> undef to <2 x i16> 144 %v8 = trunc <2 x i32> undef to <2 x i8> 145 %v9 = trunc <2 x i64> undef to <2 x i32> 146 %v10 = trunc <2 x i64> undef to <2 x i16> 147 %v11 = trunc <2 x i64> undef to <2 x i8> 148 %v12 = trunc <4 x i16> undef to <4 x i8> 149 %v13 = trunc <4 x i32> undef to <4 x i16> 150 %v14 = trunc <4 x i32> undef to <4 x i8> 151 %v15 = trunc <4 x i64> undef to <4 x i32> 152 %v16 = trunc <4 x i64> undef to <4 x i16> 153 %v17 = trunc <4 x i64> undef to <4 x i8> 154 %v18 = trunc <8 x i16> undef to <8 x i8> 155 %v19 = trunc <8 x i32> undef to <8 x i16> 156 %v20 = trunc <8 x i32> undef to <8 x i8> 157 %v21 = trunc <8 x i64> undef to <8 x i32> 158 %v22 = trunc <8 x i64> undef to <8 x i16> 159 %v23 = trunc <8 x i64> undef to <8 x i8> 160 %v24 = trunc <16 x i16> undef to <16 x i8> 161 %v25 = trunc <16 x i32> undef to <16 x i16> 162 %v26 = trunc <16 x i32> undef to <16 x i8> 163 %v27 = trunc <16 x i64> undef to <16 x i32> 164 %v28 = trunc <16 x i64> undef to <16 x i16> 165 %v29 = trunc <16 x i64> undef to <16 x i8> 166 167 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v0 = trunc i16 undef to i8 168 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v1 = trunc i32 undef to i16 169 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v2 = trunc i32 undef to i8 170 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v3 = trunc i64 undef to i32 171 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v4 = trunc i64 undef to i16 172 ; CHECK: Cost Model: Found an estimated cost of 0 for instruction: %v5 = trunc i64 undef to i8 173 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v6 = trunc <2 x i16> undef to <2 x i8> 174 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v7 = trunc <2 x i32> undef to <2 x i16> 175 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v8 = trunc <2 x i32> undef to <2 x i8> 176 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v9 = trunc <2 x i64> undef to <2 x i32> 177 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v10 = trunc <2 x i64> undef to <2 x i16> 178 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v11 = trunc <2 x i64> undef to <2 x i8> 179 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v12 = trunc <4 x i16> undef to <4 x i8> 180 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v13 = trunc <4 x i32> undef to <4 x i16> 181 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v14 = trunc <4 x i32> undef to <4 x i8> 182 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v15 = trunc <4 x i64> undef to <4 x i32> 183 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v16 = trunc <4 x i64> undef to <4 x i16> 184 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v17 = trunc <4 x i64> undef to <4 x i8> 185 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v18 = trunc <8 x i16> undef to <8 x i8> 186 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v19 = trunc <8 x i32> undef to <8 x i16> 187 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v20 = trunc <8 x i32> undef to <8 x i8> 188 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v21 = trunc <8 x i64> undef to <8 x i32> 189 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v22 = trunc <8 x i64> undef to <8 x i16> 190 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v23 = trunc <8 x i64> undef to <8 x i8> 191 ; CHECK: Cost Model: Found an estimated cost of 1 for instruction: %v24 = trunc <16 x i16> undef to <16 x i8> 192 ; CHECK: Cost Model: Found an estimated cost of 2 for instruction: %v25 = trunc <16 x i32> undef to <16 x i16> 193 ; CHECK: Cost Model: Found an estimated cost of 3 for instruction: %v26 = trunc <16 x i32> undef to <16 x i8> 194 ; CHECK: Cost Model: Found an estimated cost of 4 for instruction: %v27 = trunc <16 x i64> undef to <16 x i32> 195 ; CHECK: Cost Model: Found an estimated cost of 6 for instruction: %v28 = trunc <16 x i64> undef to <16 x i16> 196 ; CHECK: Cost Model: Found an estimated cost of 7 for instruction: %v29 = trunc <16 x i64> undef to <16 x i8> 197 198 ret void 199 } 200