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
| ;RUN: llc -O2 -mtriple=thumbv7a-linux-gnueabihf -arm-implicit-it=always %s -o - | FileCheck %s
;RUN: llc -O2 -mtriple=thumbv7a-linux-gnueabihf -no-integrated-as %s -o - | FileCheck %s
; Check that we do not produce a CBZ instruction to jump over the inline
; assembly as the distance is too far if the implicit IT instructions are
; added.
define void @f0(i32 %p1, i32 %p2, i32 %p3) nounwind {
entry:
%cmp = icmp eq i32 %p1, 0
br i1 %cmp, label %if.else, label %if.then
if.then:
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
tail call void asm sideeffect "movseq r0, #0\0A", ""()
br label %if.end
if.else:
tail call void asm sideeffect "nop\0A", ""()
br label %if.end
if.end:
ret void
}
; CHECK-LABEL: f0:
; CHECK: beq .LBB0_{{[0-9]+}}
|