blob: 44dde7b1cd0661e9c47aeadfab4f698484012787 [file] [log] [blame]
Evandro Menezeseb97e352016-10-25 19:53:51 +00001; RUN: llc %s -O2 -print-machineinstrs -mtriple=aarch64-linux-gnu -jump-table-density=40 -o /dev/null 2> %t; FileCheck %s --check-prefixes=CHECK,CHECK0 < %t
2; RUN: llc %s -O2 -print-machineinstrs -mtriple=aarch64-linux-gnu -jump-table-density=40 -max-jump-table-size=4 -o /dev/null 2> %t; FileCheck %s --check-prefixes=CHECK,CHECK4 < %t
3; RUN: llc %s -O2 -print-machineinstrs -mtriple=aarch64-linux-gnu -jump-table-density=40 -max-jump-table-size=8 -o /dev/null 2> %t; FileCheck %s --check-prefixes=CHECK,CHECK8 < %t
4; RUN: llc %s -O2 -print-machineinstrs -mtriple=aarch64-linux-gnu -jump-table-density=40 -mcpu=exynos-m1 -o /dev/null 2> %t; FileCheck %s --check-prefixes=CHECK,CHECKM1 < %t
Evandro Menezes9f9daa12018-01-30 15:40:16 +00005; RUN: llc %s -O2 -print-machineinstrs -mtriple=aarch64-linux-gnu -jump-table-density=40 -mcpu=exynos-m3 -o /dev/null 2> %t; FileCheck %s --check-prefixes=CHECK,CHECKM3 < %t
Evandro Menezese45de8a2016-09-26 15:32:33 +00006
7declare void @ext(i32)
8
9define i32 @jt1(i32 %a, i32 %b) {
10entry:
11 switch i32 %a, label %return [
12 i32 1, label %bb1
13 i32 2, label %bb2
14 i32 3, label %bb3
15 i32 4, label %bb4
16 i32 5, label %bb5
17 i32 6, label %bb6
18 i32 7, label %bb7
19 i32 8, label %bb8
20 i32 9, label %bb9
21 i32 10, label %bb10
22 i32 11, label %bb11
23 i32 12, label %bb12
24 i32 13, label %bb13
25 i32 14, label %bb14
26 i32 15, label %bb15
27 i32 16, label %bb16
28 i32 17, label %bb17
29 ]
30; CHECK-LABEL: function jt1:
Evandro Menezes601f4cb2016-10-25 19:11:43 +000031; CHECK-NEXT: Jump Tables:
Francis Visoiu Mistrihb41dbbe2017-12-13 10:30:59 +000032; CHECK0-NEXT: %jump-table.0:
33; CHECK0-NOT: %jump-table.1:
34; CHECK4-NEXT: %jump-table.0:
35; CHECK4-SAME: %jump-table.1:
36; CHECK4-SAME: %jump-table.2:
37; CHECK4-SAME: %jump-table.3:
38; CHECK4-NOT: %jump-table.4:
39; CHECK8-NEXT: %jump-table.0:
40; CHECK8-SAME: %jump-table.1:
41; CHECK8-NOT: %jump-table.2:
42; CHECKM1-NEXT: %jump-table.0:
43; CHECKM1-SAME: %jump-table.1
44; CHECKM1-NOT: %jump-table.2:
Evandro Menezes9f9daa12018-01-30 15:40:16 +000045; CHECKM3-NEXT: %jump-table.0:
46; CHECKM3-NOT: %jump-table.1:
Evandro Menezese45de8a2016-09-26 15:32:33 +000047
48bb1: tail call void @ext(i32 0) br label %return
49bb2: tail call void @ext(i32 2) br label %return
50bb3: tail call void @ext(i32 4) br label %return
51bb4: tail call void @ext(i32 6) br label %return
52bb5: tail call void @ext(i32 8) br label %return
53bb6: tail call void @ext(i32 10) br label %return
54bb7: tail call void @ext(i32 12) br label %return
55bb8: tail call void @ext(i32 14) br label %return
56bb9: tail call void @ext(i32 16) br label %return
57bb10: tail call void @ext(i32 18) br label %return
58bb11: tail call void @ext(i32 20) br label %return
59bb12: tail call void @ext(i32 22) br label %return
60bb13: tail call void @ext(i32 24) br label %return
61bb14: tail call void @ext(i32 26) br label %return
62bb15: tail call void @ext(i32 28) br label %return
63bb16: tail call void @ext(i32 30) br label %return
64bb17: tail call void @ext(i32 32) br label %return
65
66return: ret i32 %b
67}
68
69define void @jt2(i32 %x) {
70entry:
71 switch i32 %x, label %return [
72 i32 1, label %bb1
73 i32 2, label %bb2
74 i32 3, label %bb3
75 i32 4, label %bb4
76
77 i32 14, label %bb5
78 i32 15, label %bb6
79 ]
80; CHECK-LABEL: function jt2:
Evandro Menezes601f4cb2016-10-25 19:11:43 +000081; CHECK-NEXT: Jump Tables:
Francis Visoiu Mistrihb41dbbe2017-12-13 10:30:59 +000082; CHECK0-NEXT: %jump-table.0: %bb.1 %bb.2 %bb.3 %bb.4 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.5 %bb.6{{$}}
Evandro Menezes9f9daa12018-01-30 15:40:16 +000083; CHECK0-NOT: %jump-table.1
Francis Visoiu Mistrihb41dbbe2017-12-13 10:30:59 +000084; CHECK4-NEXT: %jump-table.0: %bb.1 %bb.2 %bb.3 %bb.4{{$}}
Evandro Menezes9f9daa12018-01-30 15:40:16 +000085; CHECK4-NOT: %jump-table.1
Francis Visoiu Mistrihb41dbbe2017-12-13 10:30:59 +000086; CHECK8-NEXT: %jump-table.0: %bb.1 %bb.2 %bb.3 %bb.4{{$}}
Evandro Menezes9f9daa12018-01-30 15:40:16 +000087; CHECK8-NOT: %jump-table.1
Francis Visoiu Mistrihb41dbbe2017-12-13 10:30:59 +000088; CHECKM1-NEXT: %jump-table.0: %bb.1 %bb.2 %bb.3 %bb.4{{$}}
Evandro Menezes9f9daa12018-01-30 15:40:16 +000089; CHECKM1-NOT: %jump-table.1
90; CHECKM3-NEXT: %jump-table.0: %bb.1 %bb.2 %bb.3 %bb.4 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.7 %bb.5 %bb.6{{$}}
91; CHECKM3-NOT: %jump-table.1
Jessica Paquettef90edbe2018-07-27 20:18:27 +000092; CHECK-DAG: End machine code for function jt2.
Evandro Menezese45de8a2016-09-26 15:32:33 +000093
94bb1: tail call void @ext(i32 1) br label %return
95bb2: tail call void @ext(i32 2) br label %return
96bb3: tail call void @ext(i32 3) br label %return
97bb4: tail call void @ext(i32 4) br label %return
98bb5: tail call void @ext(i32 5) br label %return
99bb6: tail call void @ext(i32 6) br label %return
100return: ret void
101}