annotate test/CodeGen/Hexagon/rdf-phi-up.ll @ 128:c347d3398279 default tip

fix
author mir3636
date Wed, 06 Dec 2017 14:37:17 +0900
parents 803732b1fca8
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 -march=hexagon -verify-machineinstrs < %s | FileCheck %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 ; Check that this testcase compiles successfully.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 ; CHECK-LABEL: fred:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 ; CHECK: call foo
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 target triple = "hexagon"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 %struct.0 = type { i32, i16, i8* }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
10 declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture) #1
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
11 declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture) #1
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 define i32 @fred(i8* readonly %p0, i32* %p1) local_unnamed_addr #0 {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 entry:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 %v0 = alloca i16, align 2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 %v1 = icmp eq i8* %p0, null
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 br i1 %v1, label %if.then, label %lor.lhs.false
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 lor.lhs.false: ; preds = %entry
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 %v2 = bitcast i8* %p0 to %struct.0**
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 %v3 = load %struct.0*, %struct.0** %v2, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 %v4 = icmp eq %struct.0* %v3, null
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 br i1 %v4, label %if.then, label %if.else
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25 if.then: ; preds = %lor.lhs.false, %ent
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 %v5 = icmp eq i32* %p1, null
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 br i1 %v5, label %cleanup, label %if.then3
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 if.then3: ; preds = %if.then
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 store i32 0, i32* %p1, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 br label %cleanup
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33 if.else: ; preds = %lor.lhs.false
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 %v6 = bitcast i16* %v0 to i8*
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
35 call void @llvm.lifetime.start.p0i8(i64 2, i8* nonnull %v6) #0
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36 store i16 0, i16* %v0, align 2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 %v7 = call i32 @foo(%struct.0* nonnull %v3, i16* nonnull %v0) #0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 %v8 = icmp eq i32* %p1, null
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39 br i1 %v8, label %if.end7, label %if.then6
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 if.then6: ; preds = %if.else
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 %v9 = load i16, i16* %v0, align 2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 %v10 = zext i16 %v9 to i32
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 store i32 %v10, i32* %p1, align 4
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 br label %if.end7
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 if.end7: ; preds = %if.else, %if.then6
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
48 call void @llvm.lifetime.end.p0i8(i64 2, i8* nonnull %v6) #0
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
49 br label %cleanup
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
50
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
51 cleanup: ; preds = %if.then3, %if.then,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
52 %v11 = phi i32 [ %v7, %if.end7 ], [ -2147024809, %if.then ], [ -2147024809, %if.then3 ]
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
53 ret i32 %v11
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
54 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
55
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
56 declare i32 @foo(%struct.0*, i16*) local_unnamed_addr #0
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
57
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
58 attributes #0 = { nounwind }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
59 attributes #1 = { argmemonly nounwind }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
60