llvm-6502/test/Transforms/Inline/inline_ssp.ll
Bill Wendling 114baee1fa Add the IR attribute 'sspstrong'.
SSPStrong applies a heuristic to insert stack protectors in these situations:

* A Protector is required for functions which contain an array, regardless of
  type or length.

* A Protector is required for functions which contain a structure/union which
  contains an array, regardless of type or length.  Note, there is no limit to
  the depth of nesting.

* A protector is required when the address of a local variable (i.e., stack
  based variable) is exposed. (E.g., such as through a local whose address is
  taken as part of the RHS of an assignment or a local whose address is taken as
  part of a function argument.)

This patch implements the SSPString attribute to be equivalent to
SSPRequired. This will change in a subsequent patch.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@173230 91177308-0d34-0410-b5e6-96231b3b80d8
2013-01-23 06:41:41 +00:00

156 lines
4.0 KiB
LLVM

; RUN: opt -inline %s -S | FileCheck %s
; Ensure SSP attributes are propagated correctly when inlining.
@.str = private unnamed_addr constant [11 x i8] c"fun_nossp\0A\00", align 1
@.str1 = private unnamed_addr constant [9 x i8] c"fun_ssp\0A\00", align 1
@.str2 = private unnamed_addr constant [15 x i8] c"fun_sspstrong\0A\00", align 1
@.str3 = private unnamed_addr constant [12 x i8] c"fun_sspreq\0A\00", align 1
; These first four functions (@fun_sspreq, @fun_sspstrong, @fun_ssp, @fun_nossp)
; are used by the remaining functions to ensure that the SSP attributes are
; propagated correctly. The caller should have its SSP attribute set as:
; strictest(caller-ssp-attr, callee-ssp-attr), where strictness is ordered as:
; sspreq > sspstrong > ssp > [no ssp]
define internal void @fun_sspreq() nounwind uwtable sspreq {
entry:
%call = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([12 x i8]* @.str3, i32 0, i32 0))
ret void
}
define internal void @fun_sspstrong() nounwind uwtable sspstrong {
entry:
%call = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([15 x i8]* @.str2, i32 0, i32 0))
ret void
}
define internal void @fun_ssp() nounwind uwtable ssp {
entry:
%call = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([9 x i8]* @.str1, i32 0, i32 0))
ret void
}
define internal void @fun_nossp() nounwind uwtable {
entry:
%call = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([11 x i8]* @.str, i32 0, i32 0))
ret void
}
; Tests start below
define void @inline_req_req() nounwind uwtable sspreq {
entry:
; CHECK: @inline_req_req() nounwind uwtable sspreq
call void @fun_sspreq()
ret void
}
define void @inline_req_strong() nounwind uwtable sspstrong {
entry:
; CHECK: @inline_req_strong() nounwind uwtable sspreq
call void @fun_sspreq()
ret void
}
define void @inline_req_ssp() nounwind uwtable ssp {
entry:
; CHECK: @inline_req_ssp() nounwind uwtable sspreq
call void @fun_sspreq()
ret void
}
define void @inline_req_nossp() nounwind uwtable {
entry:
; CHECK: @inline_req_nossp() nounwind uwtable sspreq
call void @fun_sspreq()
ret void
}
define void @inline_strong_req() nounwind uwtable sspreq {
entry:
; CHECK: @inline_strong_req() nounwind uwtable sspreq
call void @fun_sspstrong()
ret void
}
define void @inline_strong_strong() nounwind uwtable sspstrong {
entry:
; CHECK: @inline_strong_strong() nounwind uwtable sspstrong
call void @fun_sspstrong()
ret void
}
define void @inline_strong_ssp() nounwind uwtable ssp {
entry:
; CHECK: @inline_strong_ssp() nounwind uwtable sspstrong
call void @fun_sspstrong()
ret void
}
define void @inline_strong_nossp() nounwind uwtable {
entry:
; CHECK: @inline_strong_nossp() nounwind uwtable sspstrong
call void @fun_sspstrong()
ret void
}
define void @inline_ssp_req() nounwind uwtable sspreq {
entry:
; CHECK: @inline_ssp_req() nounwind uwtable sspreq
call void @fun_ssp()
ret void
}
define void @inline_ssp_strong() nounwind uwtable sspstrong {
entry:
; CHECK: @inline_ssp_strong() nounwind uwtable sspstrong
call void @fun_ssp()
ret void
}
define void @inline_ssp_ssp() nounwind uwtable ssp {
entry:
; CHECK: @inline_ssp_ssp() nounwind uwtable ssp
call void @fun_ssp()
ret void
}
define void @inline_ssp_nossp() nounwind uwtable {
entry:
; CHECK: @inline_ssp_nossp() nounwind uwtable ssp
call void @fun_ssp()
ret void
}
define void @inline_nossp_req() nounwind uwtable sspreq {
entry:
; CHECK: @inline_nossp_req() nounwind uwtable sspreq
call void @fun_nossp()
ret void
}
define void @inline_nossp_strong() nounwind uwtable sspstrong {
entry:
; CHECK: @inline_nossp_strong() nounwind uwtable sspstrong
call void @fun_nossp()
ret void
}
define void @inline_nossp_ssp() nounwind uwtable ssp {
entry:
; CHECK: @inline_nossp_ssp() nounwind uwtable ssp
call void @fun_nossp()
ret void
}
define void @inline_nossp_nossp() nounwind uwtable {
entry:
; CHECK: @inline_nossp_nossp() nounwind uwtable
call void @fun_nossp()
ret void
}
declare i32 @printf(i8*, ...)