annotate llvm/test/Feature/indirectcall.ll @ 266:00f31e85ec16 default tip

Added tag current for changeset 31d058e83c98
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:55 +0900
parents 1f2b6ac9f198
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; RUN: llvm-as < %s | llvm-dis > %t1.ll
anatofuz
parents:
diff changeset
2 ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
anatofuz
parents:
diff changeset
3 ; RUN: diff %t1.ll %t2.ll
anatofuz
parents:
diff changeset
4
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
5 declare i32 @atoi(ptr)
150
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 define i64 @fib(i64 %n) {
anatofuz
parents:
diff changeset
8 icmp ult i64 %n, 2 ; <i1>:1 [#uses=1]
anatofuz
parents:
diff changeset
9 br i1 %1, label %BaseCase, label %RecurseCase
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 BaseCase: ; preds = %0
anatofuz
parents:
diff changeset
12 ret i64 1
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 RecurseCase: ; preds = %0
anatofuz
parents:
diff changeset
15 %n2 = sub i64 %n, 2 ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
16 %n1 = sub i64 %n, 1 ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
17 %f2 = call i64 @fib( i64 %n2 ) ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
18 %f1 = call i64 @fib( i64 %n1 ) ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
19 %result = add i64 %f2, %f1 ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
20 ret i64 %result
anatofuz
parents:
diff changeset
21 }
anatofuz
parents:
diff changeset
22
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
23 define i64 @realmain(i32 %argc, ptr %argv) {
150
anatofuz
parents:
diff changeset
24 ; <label>:0
anatofuz
parents:
diff changeset
25 icmp eq i32 %argc, 2 ; <i1>:1 [#uses=1]
anatofuz
parents:
diff changeset
26 br i1 %1, label %HasArg, label %Continue
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 HasArg: ; preds = %0
anatofuz
parents:
diff changeset
29 %n1 = add i32 1, 1 ; <i32> [#uses=1]
anatofuz
parents:
diff changeset
30 br label %Continue
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 Continue: ; preds = %HasArg, %0
anatofuz
parents:
diff changeset
33 %n = phi i32 [ %n1, %HasArg ], [ 1, %0 ] ; <i32> [#uses=1]
anatofuz
parents:
diff changeset
34 %N = sext i32 %n to i64 ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
35 %F = call i64 @fib( i64 %N ) ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
36 ret i64 %F
anatofuz
parents:
diff changeset
37 }
anatofuz
parents:
diff changeset
38
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
39 define i64 @trampoline(i64 %n, ptr %fibfunc) {
150
anatofuz
parents:
diff changeset
40 %F = call i64 %fibfunc( i64 %n ) ; <i64> [#uses=1]
anatofuz
parents:
diff changeset
41 ret i64 %F
anatofuz
parents:
diff changeset
42 }
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 define i32 @main() {
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
45 %Result = call i64 @trampoline( i64 10, ptr @fib ) ; <i64> [#uses=1]
150
anatofuz
parents:
diff changeset
46 %Result.upgrd.1 = trunc i64 %Result to i32 ; <i32> [#uses=1]
anatofuz
parents:
diff changeset
47 ret i32 %Result.upgrd.1
anatofuz
parents:
diff changeset
48 }
anatofuz
parents:
diff changeset
49