File: 2010-07-20-Switch.ll

package info (click to toggle)
llvm-toolchain-21 1%3A21.1.4-5
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 2,236,516 kB
  • sloc: cpp: 7,619,569; ansic: 1,433,956; asm: 1,058,748; python: 252,181; f90: 94,671; objc: 70,753; lisp: 42,813; pascal: 18,401; sh: 8,601; ml: 5,111; perl: 4,720; makefile: 3,585; awk: 3,523; javascript: 2,272; xml: 892; fortran: 770
file content (233 lines) | stat: -rw-r--r-- 7,777 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc < %s -mtriple=mips -relocation-model=static | \
; RUN: FileCheck %s -check-prefix=STATIC-O32
; RUN: llc < %s -mtriple=mips -relocation-model=pic | \
; RUN: FileCheck %s -check-prefix=PIC-O32
; RUN: llc < %s -mtriple=mips64 -relocation-model=pic -mcpu=mips4 | \
; RUN:     FileCheck %s -check-prefix=PIC-N64
; RUN: llc < %s -mtriple=mips64 -relocation-model=static -mcpu=mips4 | \
; RUN:     FileCheck %s -check-prefix=STATIC-N64
; RUN: llc < %s -mtriple=mips64 -relocation-model=pic -mcpu=mips64 | \
; RUN:     FileCheck %s -check-prefix=PIC-N64
; RUN: llc < %s -mtriple=mips64 -relocation-model=static -mcpu=mips64 | \
; RUN:     FileCheck %s -check-prefix=STATIC-N64

define i32 @main() nounwind readnone {
; STATIC-O32-LABEL: main:
; STATIC-O32:       # %bb.0: # %entry
; STATIC-O32-NEXT:    addiu $sp, $sp, -8
; STATIC-O32-NEXT:    addiu $1, $zero, 2
; STATIC-O32-NEXT:    sw $1, 4($sp)
; STATIC-O32-NEXT:    lw $2, 4($sp)
; STATIC-O32-NEXT:    sltiu $1, $2, 4
; STATIC-O32-NEXT:    beqz $1, $BB0_6
; STATIC-O32-NEXT:    nop
; STATIC-O32-NEXT:  # %bb.1: # %entry
; STATIC-O32-NEXT:    sll $1, $2, 2
; STATIC-O32-NEXT:    lui $2, %hi($JTI0_0)
; STATIC-O32-NEXT:    addu $1, $1, $2
; STATIC-O32-NEXT:    lw $1, %lo($JTI0_0)($1)
; STATIC-O32-NEXT:    jr $1
; STATIC-O32-NEXT:    nop
; STATIC-O32-NEXT:  $BB0_2: # %bb5
; STATIC-O32-NEXT:    addiu $2, $zero, 1
; STATIC-O32-NEXT:    jr $ra
; STATIC-O32-NEXT:    addiu $sp, $sp, 8
; STATIC-O32-NEXT:  $BB0_3: # %bb2
; STATIC-O32-NEXT:    addiu $2, $zero, 0
; STATIC-O32-NEXT:    jr $ra
; STATIC-O32-NEXT:    addiu $sp, $sp, 8
; STATIC-O32-NEXT:  $BB0_4: # %bb3
; STATIC-O32-NEXT:    addiu $2, $zero, 3
; STATIC-O32-NEXT:    jr $ra
; STATIC-O32-NEXT:    addiu $sp, $sp, 8
; STATIC-O32-NEXT:  $BB0_5: # %bb1
; STATIC-O32-NEXT:    addiu $2, $zero, 2
; STATIC-O32-NEXT:    jr $ra
; STATIC-O32-NEXT:    addiu $sp, $sp, 8
; STATIC-O32-NEXT:  $BB0_6: # %bb4
; STATIC-O32-NEXT:    addiu $2, $zero, 4
; STATIC-O32-NEXT:    jr $ra
; STATIC-O32-NEXT:    addiu $sp, $sp, 8
;
; PIC-O32-LABEL: main:
; PIC-O32:       # %bb.0: # %entry
; PIC-O32-NEXT:    lui $2, %hi(_gp_disp)
; PIC-O32-NEXT:    addiu $2, $2, %lo(_gp_disp)
; PIC-O32-NEXT:    addiu $sp, $sp, -8
; PIC-O32-NEXT:    addiu $1, $zero, 2
; PIC-O32-NEXT:    sw $1, 4($sp)
; PIC-O32-NEXT:    lw $3, 4($sp)
; PIC-O32-NEXT:    sltiu $1, $3, 4
; PIC-O32-NEXT:    beqz $1, $BB0_6
; PIC-O32-NEXT:    addu $2, $2, $25
; PIC-O32-NEXT:  # %bb.1: # %entry
; PIC-O32-NEXT:    sll $1, $3, 2
; PIC-O32-NEXT:    lw $3, %got($JTI0_0)($2)
; PIC-O32-NEXT:    addu $1, $1, $3
; PIC-O32-NEXT:    lw $1, %lo($JTI0_0)($1)
; PIC-O32-NEXT:    addu $1, $2, $1
; PIC-O32-NEXT:    jr $1
; PIC-O32-NEXT:    nop
; PIC-O32-NEXT:  $BB0_2: # %bb5
; PIC-O32-NEXT:    addiu $2, $zero, 1
; PIC-O32-NEXT:    jr $ra
; PIC-O32-NEXT:    addiu $sp, $sp, 8
; PIC-O32-NEXT:  $BB0_3: # %bb2
; PIC-O32-NEXT:    addiu $2, $zero, 0
; PIC-O32-NEXT:    jr $ra
; PIC-O32-NEXT:    addiu $sp, $sp, 8
; PIC-O32-NEXT:  $BB0_4: # %bb3
; PIC-O32-NEXT:    addiu $2, $zero, 3
; PIC-O32-NEXT:    jr $ra
; PIC-O32-NEXT:    addiu $sp, $sp, 8
; PIC-O32-NEXT:  $BB0_5: # %bb1
; PIC-O32-NEXT:    addiu $2, $zero, 2
; PIC-O32-NEXT:    jr $ra
; PIC-O32-NEXT:    addiu $sp, $sp, 8
; PIC-O32-NEXT:  $BB0_6: # %bb4
; PIC-O32-NEXT:    addiu $2, $zero, 4
; PIC-O32-NEXT:    jr $ra
; PIC-O32-NEXT:    addiu $sp, $sp, 8
;
; PIC-N64-LABEL: main:
; PIC-N64:       # %bb.0: # %entry
; PIC-N64-NEXT:    daddiu $sp, $sp, -16
; PIC-N64-NEXT:    lui $1, %hi(%neg(%gp_rel(main)))
; PIC-N64-NEXT:    daddu $2, $1, $25
; PIC-N64-NEXT:    addiu $1, $zero, 2
; PIC-N64-NEXT:    sw $1, 12($sp)
; PIC-N64-NEXT:    lw $1, 12($sp)
; PIC-N64-NEXT:    sltiu $4, $1, 4
; PIC-N64-NEXT:    dsll $3, $1, 32
; PIC-N64-NEXT:    beqz $4, .LBB0_6
; PIC-N64-NEXT:    nop
; PIC-N64-NEXT:  # %bb.1: # %entry
; PIC-N64-NEXT:    daddiu $1, $2, %lo(%neg(%gp_rel(main)))
; PIC-N64-NEXT:    dsrl $2, $3, 32
; PIC-N64-NEXT:    dsll $2, $2, 3
; PIC-N64-NEXT:    ld $3, %got_page(.LJTI0_0)($1)
; PIC-N64-NEXT:    daddu $2, $2, $3
; PIC-N64-NEXT:    ld $2, %got_ofst(.LJTI0_0)($2)
; PIC-N64-NEXT:    daddu $1, $1, $2
; PIC-N64-NEXT:    jr $1
; PIC-N64-NEXT:    nop
; PIC-N64-NEXT:  .LBB0_2: # %bb5
; PIC-N64-NEXT:    addiu $2, $zero, 1
; PIC-N64-NEXT:    jr $ra
; PIC-N64-NEXT:    daddiu $sp, $sp, 16
; PIC-N64-NEXT:  .LBB0_3: # %bb2
; PIC-N64-NEXT:    addiu $2, $zero, 0
; PIC-N64-NEXT:    jr $ra
; PIC-N64-NEXT:    daddiu $sp, $sp, 16
; PIC-N64-NEXT:  .LBB0_4: # %bb3
; PIC-N64-NEXT:    addiu $2, $zero, 3
; PIC-N64-NEXT:    jr $ra
; PIC-N64-NEXT:    daddiu $sp, $sp, 16
; PIC-N64-NEXT:  .LBB0_5: # %bb1
; PIC-N64-NEXT:    addiu $2, $zero, 2
; PIC-N64-NEXT:    jr $ra
; PIC-N64-NEXT:    daddiu $sp, $sp, 16
; PIC-N64-NEXT:  .LBB0_6: # %bb4
; PIC-N64-NEXT:    addiu $2, $zero, 4
; PIC-N64-NEXT:    jr $ra
; PIC-N64-NEXT:    daddiu $sp, $sp, 16
;
; STATIC-N64-LABEL: main:
; STATIC-N64:       # %bb.0: # %entry
; STATIC-N64-NEXT:    daddiu $sp, $sp, -16
; STATIC-N64-NEXT:    addiu $1, $zero, 2
; STATIC-N64-NEXT:    sw $1, 12($sp)
; STATIC-N64-NEXT:    lw $1, 12($sp)
; STATIC-N64-NEXT:    sltiu $3, $1, 4
; STATIC-N64-NEXT:    dsll $2, $1, 32
; STATIC-N64-NEXT:    beqz $3, .LBB0_6
; STATIC-N64-NEXT:    nop
; STATIC-N64-NEXT:  # %bb.1: # %entry
; STATIC-N64-NEXT:    dsrl $1, $2, 32
; STATIC-N64-NEXT:    dsll $1, $1, 3
; STATIC-N64-NEXT:    lui $2, %highest(.LJTI0_0)
; STATIC-N64-NEXT:    daddiu $2, $2, %higher(.LJTI0_0)
; STATIC-N64-NEXT:    dsll $2, $2, 16
; STATIC-N64-NEXT:    daddiu $2, $2, %hi(.LJTI0_0)
; STATIC-N64-NEXT:    dsll $2, $2, 16
; STATIC-N64-NEXT:    daddu $1, $1, $2
; STATIC-N64-NEXT:    ld $1, %lo(.LJTI0_0)($1)
; STATIC-N64-NEXT:    jr $1
; STATIC-N64-NEXT:    nop
; STATIC-N64-NEXT:  .LBB0_2: # %bb5
; STATIC-N64-NEXT:    addiu $2, $zero, 1
; STATIC-N64-NEXT:    jr $ra
; STATIC-N64-NEXT:    daddiu $sp, $sp, 16
; STATIC-N64-NEXT:  .LBB0_3: # %bb2
; STATIC-N64-NEXT:    addiu $2, $zero, 0
; STATIC-N64-NEXT:    jr $ra
; STATIC-N64-NEXT:    daddiu $sp, $sp, 16
; STATIC-N64-NEXT:  .LBB0_4: # %bb3
; STATIC-N64-NEXT:    addiu $2, $zero, 3
; STATIC-N64-NEXT:    jr $ra
; STATIC-N64-NEXT:    daddiu $sp, $sp, 16
; STATIC-N64-NEXT:  .LBB0_5: # %bb1
; STATIC-N64-NEXT:    addiu $2, $zero, 2
; STATIC-N64-NEXT:    jr $ra
; STATIC-N64-NEXT:    daddiu $sp, $sp, 16
; STATIC-N64-NEXT:  .LBB0_6: # %bb4
; STATIC-N64-NEXT:    addiu $2, $zero, 4
; STATIC-N64-NEXT:    jr $ra
; STATIC-N64-NEXT:    daddiu $sp, $sp, 16
entry:
  %x = alloca i32, align 4                        ; <ptr> [#uses=2]
  store volatile i32 2, ptr %x, align 4
  %0 = load volatile i32, ptr %x, align 4             ; <i32> [#uses=1]



  switch i32 %0, label %bb4 [
    i32 0, label %bb5
    i32 1, label %bb1
    i32 2, label %bb2
    i32 3, label %bb3
  ]

bb1:                                              ; preds = %entry
  ret i32 2

bb2:                                              ; preds = %entry
  ret i32 0

bb3:                                              ; preds = %entry
  ret i32 3

bb4:                                              ; preds = %entry
  ret i32 4

bb5:                                              ; preds = %entry
  ret i32 1
}
; UTC_ARGS: --disable

; STATIC-O32: .p2align  2
; STATIC-O32: $JTI0_0:
; STATIC-O32: .4byte
; STATIC-O32: .4byte
; STATIC-O32: .4byte
; STATIC-O32: .4byte
; PIC-O32: .p2align  2
; PIC-O32: $JTI0_0:
; PIC-O32: .gpword
; PIC-O32: .gpword
; PIC-O32: .gpword
; PIC-O32: .gpword
; STATIC-N64: .p2align  3
; STATIC-N64: LJTI0_0:
; STATIC-N64: .8byte
; STATIC-N64: .8byte
; STATIC-N64: .8byte
; STATIC-N64: .8byte
; PIC-N64: .p2align  3
; PIC-N64: .LJTI0_0:
; PIC-N64: .gpdword
; PIC-N64: .gpdword
; PIC-N64: .gpdword
; PIC-N64: .gpdword