Protection against stack-based memory corruption errors using SafeStack
[oota-llvm.git] / test / Transforms / SafeStack / array.ll
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
3
4 ; array [4 x i8]
5 ; Requires protector.
6
7 define void @foo(i8* %a) nounwind uwtable safestack {
8 entry:
9   ; CHECK: %[[USP:.*]] = load i8*, i8** @__safestack_unsafe_stack_ptr
10
11   ; CHECK: %[[USST:.*]] = getelementptr i8, i8* %[[USP]], i32 -16
12
13   ; CHECK: store i8* %[[USST]], i8** @__safestack_unsafe_stack_ptr
14
15   ; CHECK: %[[AADDR:.*]] = alloca i8*, align 8
16   %a.addr = alloca i8*, align 8
17
18   ; CHECK: %[[BUFPTR:.*]] = getelementptr i8, i8* %[[USP]], i32 -4
19   ; CHECK: %[[BUFPTR2:.*]] = bitcast i8* %[[BUFPTR]] to [4 x i8]*
20   %buf = alloca [4 x i8], align 1
21
22   ; CHECK: store i8* {{.*}}, i8** %[[AADDR]], align 8
23   store i8* %a, i8** %a.addr, align 8
24
25   ; CHECK: %[[GEP:.*]] = getelementptr inbounds [4 x i8], [4 x i8]* %[[BUFPTR2]], i32 0, i32 0
26   %gep = getelementptr inbounds [4 x i8], [4 x i8]* %buf, i32 0, i32 0
27
28   ; CHECK: %[[A2:.*]] = load i8*, i8** %[[AADDR]], align 8
29   %a2 = load i8*, i8** %a.addr, align 8
30
31   ; CHECK: call i8* @strcpy(i8* %[[GEP]], i8* %[[A2]])
32   %call = call i8* @strcpy(i8* %gep, i8* %a2)
33
34   ; CHECK: store i8* %[[USP]], i8** @__safestack_unsafe_stack_ptr
35   ret void
36 }
37
38 declare i8* @strcpy(i8*, i8*)