annotate test/ExecutionEngine/OrcLazy/weak-function.ll @ 120:1172e4bd9c6f

update 4.0.0
author mir3636
date Fri, 25 Nov 2016 19:14:25 +0900
parents
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: lli -jit-kind=orc-lazy -extra-module %p/Inputs/weak-function-2.ll %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 ;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 ; Check that functions in two different modules agree on the address of weak
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 ; function 'baz'
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 define linkonce_odr i32 @baz() {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 ret i32 0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 define i8* @foo() {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 ret i8* bitcast (i32 ()* @baz to i8*)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 declare i8* @bar()
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 define i32 @main(i32 %argc, i8** %argv) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 %call = tail call i8* @foo()
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 %call1 = tail call i8* @bar()
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 %cmp = icmp ne i8* %call, %call1
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 %conv = zext i1 %cmp to i32
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 ret i32 %conv
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26