[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / GlobalOpt / 2009-01-13-phi-user.ll
blobb434fc10f87e6ed756b7830f2d511b49b159007a
1 ; RUN: opt < %s -passes=globalopt -S | FileCheck %s
2 ; CHECK: phi{{.*}}@head
3 ; PR3321
4 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
5 target triple = "x86_64-unknown-linux-gnu"
6         %struct.node = type { ptr, i32 }
7 @head = internal global ptr null                ; <ptr> [#uses=2]
8 @node = internal global %struct.node { ptr null, i32 42 }, align 16             ; <ptr> [#uses=1]
10 define i32 @f() nounwind {
11 entry:
12         store ptr @node, ptr @head, align 8
13         br label %bb1
15 bb:             ; preds = %bb1
16         %0 = getelementptr %struct.node, ptr %t.0, i64 0, i32 1         ; <ptr> [#uses=1]
17         %1 = load i32, ptr %0, align 4          ; <i32> [#uses=1]
18         %2 = getelementptr %struct.node, ptr %t.0, i64 0, i32 0         ; <ptr> [#uses=1]
19         br label %bb1
21 bb1:            ; preds = %bb, %entry
22         %value.0 = phi i32 [ undef, %entry ], [ %1, %bb ]               ; <i32> [#uses=1]
23         %t.0.in = phi ptr [ @head, %entry ], [ %2, %bb ]                ; <ptr> [#uses=1]
24         %t.0 = load ptr, ptr %t.0.in            ; <ptr> [#uses=3]
25         %3 = icmp eq ptr %t.0, null             ; <i1> [#uses=1]
26         br i1 %3, label %bb2, label %bb
28 bb2:            ; preds = %bb1
29         ret i32 %value.0
32 define i32 @main() nounwind {
33 entry:
34         %0 = call i32 @f() nounwind             ; <i32> [#uses=1]
35         ret i32 %0