annotate test/CodeGen/SPARC/func-addr.ll @ 146:3fc4d5c3e21e

set tail call flag for code segment in CGCAll
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 19:23:36 +0900
parents 1172e4bd9c6f
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 ; RUN: llc < %s -march=sparc -relocation-model=static -code-model=small | FileCheck --check-prefix=abs32 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 ; RUN: llc < %s -march=sparcv9 -relocation-model=static -code-model=small | FileCheck --check-prefix=abs32 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 ; RUN: llc < %s -march=sparcv9 -relocation-model=static -code-model=medium | FileCheck --check-prefix=abs44 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 ; RUN: llc < %s -march=sparcv9 -relocation-model=static -code-model=large | FileCheck --check-prefix=abs64 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 ; RUN: llc < %s -march=sparc -relocation-model=pic -code-model=medium | FileCheck --check-prefix=v8pic32 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 ; RUN: llc < %s -march=sparcv9 -relocation-model=pic -code-model=medium | FileCheck --check-prefix=v9pic32 %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 define void @func1() #0 {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 define void @test() #0 {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 %pFunc = alloca void (...)*, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 store void (...)* bitcast (void ()* @func1 to void (...)*), void (...)** %pFunc, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 %0 = load void (...)*, void (...)** %pFunc, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 %callee.knr.cast = bitcast void (...)* %0 to void ()*
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 call void %callee.knr.cast()
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 ; abs32-LABEL: test
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 ; abs32: sethi %hi(func1), %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 ; abs32: add %i0, %lo(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 ; abs32: call %i0+%lo(func1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 ; abs44-LABEL: test
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 ; abs44: sethi %h44(func1), %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 ; abs44: add %i0, %m44(func1), %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 ; abs44: sllx %i0, 12, %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 ; abs44: add %i0, %l44(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 ; abs44: call %i0+%l44(func1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33 ; abs64-LABEL: test
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 ; abs64: sethi %hi(func1), %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 ; abs64: add %i0, %lo(func1), %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36 ; abs64: sethi %hh(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 ; abs64: add %i1, %hm(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39 ; v8pic32-LABEL: test
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 ; v8pic32: sethi %hi(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 ; v8pic32: add %i1, %lo(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 ; v8pic32: ld [%i0+%i1], %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 ; v9pic32-LABEL: test
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 ; v9pic32: sethi %hi(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46 ; v9pic32: add %i1, %lo(func1), %i1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 ; v9pic32: ldx [%i0+%i1], %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
48 ; v9pic32: call %i0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
49
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
50 ret void
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
51 }