1 ; RUN: llc -march=x86-64 -print-machineinstrs=expand-isel-pseudos %s -o /dev/null 2>&1 | FileCheck %s 2 3 declare void @foo(i32) 4 5 ; CHECK-LABEL: test 6 7 define void @test(i32 %x) nounwind { 8 entry: 9 switch i32 %x, label %sw.default [ 10 i32 1, label %sw.bb 11 i32 155, label %sw.bb 12 i32 156, label %sw.bb 13 i32 157, label %sw.bb 14 i32 158, label %sw.bb 15 i32 159, label %sw.bb 16 i32 1134, label %sw.bb 17 i32 1140, label %sw.bb 18 ], !prof !1 19 20 sw.bb: 21 call void @foo(i32 0) 22 br label %sw.epilog 23 24 sw.default: 25 call void @foo(i32 1) 26 br label %sw.epilog 27 28 sw.epilog: 29 ret void 30 31 ; Check if weights are correctly assigned to edges generated from switch 32 ; statement. 33 ; 34 ; CHECK: BB#0: 35 ; BB#0 to BB#4: [0, 1133] (65 = 60 + 5) 36 ; BB#0 to BB#5: [1134, UINT32_MAX] (25 = 20 + 5) 37 ; CHECK: Successors according to CFG: BB#4({{[0-9a-fx/= ]+}}72.22%) BB#5({{[0-9a-fx/= ]+}}27.78%) 38 ; 39 ; CHECK: BB#4: 40 ; BB#4 to BB#1: [155, 159] (50) 41 ; BB#4 to BB#5: [0, 1133] - [155, 159] (15 = 10 + 5) 42 ; CHECK: Successors according to CFG: BB#1({{[0-9a-fx/= ]+}}76.92%) BB#7({{[0-9a-fx/= ]+}}23.08%) 43 ; 44 ; CHECK: BB#5: 45 ; BB#5 to BB#1: {1140} (10) 46 ; BB#5 to BB#6: [1134, UINT32_MAX] - {1140} (15 = 10 + 5) 47 ; CHECK: Successors according to CFG: BB#1({{[0-9a-fx/= ]+}}40.00%) BB#6({{[0-9a-fx/= ]+}}60.00%) 48 ; 49 ; CHECK: BB#6: 50 ; BB#6 to BB#1: {1134} (10) 51 ; BB#6 to BB#2: [1134, UINT32_MAX] - {1134, 1140} (5) 52 ; CHECK: Successors according to CFG: BB#1({{[0-9a-fx/= ]+}}66.67%) BB#2({{[0-9a-fx/= ]+}}33.33%) 53 } 54 55 ; CHECK-LABEL: test2 56 57 define void @test2(i32 %x) nounwind { 58 entry: 59 60 ; In this switch statement, there is an edge from jump table to default 61 ; statement. 62 63 switch i32 %x, label %sw.default [ 64 i32 1, label %sw.bb 65 i32 10, label %sw.bb2 66 i32 11, label %sw.bb3 67 i32 12, label %sw.bb4 68 i32 13, label %sw.bb5 69 i32 14, label %sw.bb5 70 ], !prof !3 71 72 sw.bb: 73 call void @foo(i32 0) 74 br label %sw.epilog 75 76 sw.bb2: 77 call void @foo(i32 2) 78 br label %sw.epilog 79 80 sw.bb3: 81 call void @foo(i32 3) 82 br label %sw.epilog 83 84 sw.bb4: 85 call void @foo(i32 4) 86 br label %sw.epilog 87 88 sw.bb5: 89 call void @foo(i32 5) 90 br label %sw.epilog 91 92 sw.default: 93 call void @foo(i32 1) 94 br label %sw.epilog 95 96 sw.epilog: 97 ret void 98 99 ; Check if weights are correctly assigned to edges generated from switch 100 ; statement. 101 ; 102 ; CHECK: BB#0: 103 ; BB#0 to BB#6: {0} + [15, UINT32_MAX] (5) 104 ; BB#0 to BB#8: [1, 14] (jump table) (65 = 60 + 5) 105 ; CHECK: Successors according to CFG: BB#6({{[0-9a-fx/= ]+}}7.14%) BB#8({{[0-9a-fx/= ]+}}92.86% 106 ; 107 ; CHECK: BB#8: 108 ; BB#8 to BB#1: {1} (10) 109 ; BB#8 to BB#6: [2, 9] (5) 110 ; BB#8 to BB#2: {10} (10) 111 ; BB#8 to BB#3: {11} (10) 112 ; BB#8 to BB#4: {12} (10) 113 ; BB#8 to BB#5: {13, 14} (20) 114 ; CHECK: Successors according to CFG: BB#1({{[0-9a-fx/= ]+}}15.38%) BB#6({{[0-9a-fx/= ]+}}7.69%) BB#2({{[0-9a-fx/= ]+}}15.38%) BB#3({{[0-9a-fx/= ]+}}15.38%) BB#4({{[0-9a-fx/= ]+}}15.38%) BB#5({{[0-9a-fx/= ]+}}30.77%) 115 } 116 117 ; CHECK-LABEL: test3 118 119 define void @test3(i32 %x) nounwind { 120 entry: 121 122 ; In this switch statement, there is no edge from jump table to default 123 ; statement. 124 125 switch i32 %x, label %sw.default [ 126 i32 10, label %sw.bb 127 i32 11, label %sw.bb2 128 i32 12, label %sw.bb3 129 i32 13, label %sw.bb4 130 i32 14, label %sw.bb5 131 ], !prof !2 132 133 sw.bb: 134 call void @foo(i32 0) 135 br label %sw.epilog 136 137 sw.bb2: 138 call void @foo(i32 2) 139 br label %sw.epilog 140 141 sw.bb3: 142 call void @foo(i32 3) 143 br label %sw.epilog 144 145 sw.bb4: 146 call void @foo(i32 4) 147 br label %sw.epilog 148 149 sw.bb5: 150 call void @foo(i32 5) 151 br label %sw.epilog 152 153 sw.default: 154 call void @foo(i32 1) 155 br label %sw.epilog 156 157 sw.epilog: 158 ret void 159 160 ; Check if weights are correctly assigned to edges generated from switch 161 ; statement. 162 ; 163 ; CHECK: BB#0: 164 ; BB#0 to BB#6: [0, 9] + [15, UINT32_MAX] {10} 165 ; BB#0 to BB#8: [10, 14] (jump table) (50) 166 ; CHECK: Successors according to CFG: BB#6({{[0-9a-fx/= ]+}}16.67%) BB#8({{[0-9a-fx/= ]+}}83.33%) 167 ; 168 ; CHECK: BB#8: 169 ; BB#8 to BB#1: {10} (10) 170 ; BB#8 to BB#2: {11} (10) 171 ; BB#8 to BB#3: {12} (10) 172 ; BB#8 to BB#4: {13} (10) 173 ; BB#8 to BB#5: {14} (10) 174 ; CHECK: Successors according to CFG: BB#1({{[0-9a-fx/= ]+}}20.00%) BB#2({{[0-9a-fx/= ]+}}20.00%) BB#3({{[0-9a-fx/= ]+}}20.00%) BB#4({{[0-9a-fx/= ]+}}20.00%) BB#5({{[0-9a-fx/= ]+}}20.00%) 175 } 176 177 ; CHECK-LABEL: test4 178 179 define void @test4(i32 %x) nounwind { 180 entry: 181 182 ; In this switch statement, there is no edge from bit test to default basic 183 ; block. 184 185 switch i32 %x, label %sw.default [ 186 i32 1, label %sw.bb 187 i32 111, label %sw.bb2 188 i32 112, label %sw.bb3 189 i32 113, label %sw.bb3 190 i32 114, label %sw.bb2 191 i32 115, label %sw.bb2 192 ], !prof !3 193 194 sw.bb: 195 call void @foo(i32 0) 196 br label %sw.epilog 197 198 sw.bb2: 199 call void @foo(i32 2) 200 br label %sw.epilog 201 202 sw.bb3: 203 call void @foo(i32 3) 204 br label %sw.epilog 205 206 sw.default: 207 call void @foo(i32 1) 208 br label %sw.epilog 209 210 sw.epilog: 211 ret void 212 213 ; Check if weights are correctly assigned to edges generated from switch 214 ; statement. 215 ; 216 ; CHECK: BB#0: 217 ; BB#0 to BB#6: [0, 110] + [116, UINT32_MAX] (20) 218 ; BB#0 to BB#7: [111, 115] (bit test) (50) 219 ; CHECK: Successors according to CFG: BB#6({{[0-9a-fx/= ]+}}28.57%) BB#7({{[0-9a-fx/= ]+}}71.43%) 220 ; 221 ; CHECK: BB#7: 222 ; BB#7 to BB#2: {111, 114, 115} (30) 223 ; BB#7 to BB#3: {112, 113} (20) 224 ; CHECK: Successors according to CFG: BB#2({{[0-9a-fx/= ]+}}60.00%) BB#3({{[0-9a-fx/= ]+}}40.00%) 225 } 226 227 ; CHECK-LABEL: test5 228 229 define void @test5(i32 %x) nounwind { 230 entry: 231 232 ; In this switch statement, there is an edge from jump table to default basic 233 ; block. 234 235 switch i32 %x, label %sw.default [ 236 i32 4, label %sw.bb 237 i32 20, label %sw.bb2 238 i32 28, label %sw.bb3 239 i32 36, label %sw.bb4 240 i32 124, label %sw.bb5 241 ], !prof !2 242 243 sw.bb: 244 call void @foo(i32 0) 245 br label %sw.epilog 246 247 sw.bb2: 248 call void @foo(i32 1) 249 br label %sw.epilog 250 251 sw.bb3: 252 call void @foo(i32 2) 253 br label %sw.epilog 254 255 sw.bb4: 256 call void @foo(i32 3) 257 br label %sw.epilog 258 259 sw.bb5: 260 call void @foo(i32 4) 261 br label %sw.epilog 262 263 sw.default: 264 call void @foo(i32 5) 265 br label %sw.epilog 266 267 sw.epilog: 268 ret void 269 270 ; Check if weights are correctly assigned to edges generated from switch 271 ; statement. 272 ; 273 ; CHECK: BB#0: 274 ; BB#0 to BB#6: [10, UINT32_MAX] (15) 275 ; BB#0 to BB#8: [4, 20, 28, 36] (jump table) (45) 276 ; CHECK: Successors according to CFG: BB#8({{[0-9a-fx/= ]+}}25.00%) BB#9({{[0-9a-fx/= ]+}}75.00%) 277 } 278 279 !1 = !{!"branch_weights", i32 10, i32 10, i32 10, i32 10, i32 10, i32 10, i32 10, i32 10, i32 10} 280 !2 = !{!"branch_weights", i32 10, i32 10, i32 10, i32 10, i32 10, i32 10} 281 !3 = !{!"branch_weights", i32 10, i32 10, i32 10, i32 10, i32 10, i32 10, i32 10} 282