[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / SafeStack / X86 / array-aligned.ll
blobed05d387b511fd27b8820ab98677d4e55dec5d54
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 @.str = private unnamed_addr constant [4 x i8] c"%s\0A\00", align 1
6 ; array of [16 x i8]
8 define void @foo(ptr %a) nounwind uwtable safestack {
9 entry:
10   ; CHECK: %[[USP:.*]] = load ptr, ptr @__safestack_unsafe_stack_ptr
12   ; CHECK: %[[USST:.*]] = getelementptr i8, ptr %[[USP]], i32 -16
14   ; CHECK: store ptr %[[USST]], ptr @__safestack_unsafe_stack_ptr
16   %a.addr = alloca ptr, align 8
17   %buf = alloca [16 x i8], align 16
19   ; CHECK: %[[AADDR:.*]] = alloca ptr, align 8
20   ; CHECK: store ptr {{.*}}, ptr %[[AADDR]], align 8
21   store ptr %a, ptr %a.addr, align 8
23   ; CHECK: %[[A2:.*]] = load ptr, ptr %[[AADDR]], align 8
24   ; CHECK: %[[BUFPTR:.*]] = getelementptr i8, ptr %[[USP]], i32 -16
25   %a2 = load ptr, ptr %a.addr, align 8
27   ; CHECK: call ptr @strcpy(ptr %[[BUFPTR]], ptr %[[A2]])
28   %call = call ptr @strcpy(ptr %buf, ptr %a2)
30   ; CHECK: store ptr %[[USP]], ptr @__safestack_unsafe_stack_ptr
31   ret void
34 declare ptr @strcpy(ptr, ptr)