[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / SafeStack / X86 / phi.ll
blob18380431f6398845adf0be70eef06d72e3501b24
1 ; RUN: opt -safe-stack -S -mtriple=i386-pc-linux-gnu < %s -o - | FileCheck %s
2 ; RUN: opt -safe-stack -S -mtriple=x86_64-pc-linux-gnu < %s -o - | FileCheck %s
4 define void @f(i1 %d1, i1 %d2) safestack {
5 entry:
6 ; CHECK-LABEL: define void @f(
7 ; CHECK:         %[[USP:.*]] = load ptr, ptr @__safestack_unsafe_stack_ptr
8 ; CHECK-NEXT:    getelementptr i8, ptr %[[USP]], i32 -16
9 ; CHECK:         br i1 %d1, label %[[BB0:.*]], label %[[BB1:.*]]
10   %a = alloca i32, align 8
11   %b = alloca i32, align 8
12   br i1 %d1, label %bb0, label %bb1
14 bb0:
15 ; CHECK: [[BB0]]:
16 ; CHECK: %[[Ai8:.*]] = getelementptr i8, ptr %unsafe_stack_ptr, i32
17 ; CHECK: br i1
18   br i1 %d2, label %bb2, label %bb2
20 bb1:
21 ; CHECK: [[BB1]]:
22 ; CHECK: %[[Bi8:.*]] = getelementptr i8, ptr %unsafe_stack_ptr, i32
23 ; CHECK: br label
24   br label %bb2
26 bb2:
27 ; CHECK: phi ptr [ %[[Ai8]], %[[BB0]] ], [ %[[Ai8]], %[[BB0]] ], [ %[[Bi8]], %[[BB1]] ]
28   %c = phi ptr [ %a, %bb0 ], [ %a, %bb0 ], [ %b, %bb1 ]
29   call void @capture(ptr %c)
30   ret void
33 declare void @capture(ptr)