summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/SafeStack/X86
diff options
context:
space:
mode:
authorVlad Tsyrklevich <vlad@tsyrklevich.net>2018-08-30 20:44:51 +0000
committerVlad Tsyrklevich <vlad@tsyrklevich.net>2018-08-30 20:44:51 +0000
commit2499aeead93a28cff56816c6ce7c093d227a0084 (patch)
treecec8fefa533fbf9c87869b83e60fc59d6173aa0e /llvm/test/Transforms/SafeStack/X86
parente4c3c6c873bdb967ec6dc258939f7a6b908a269f (diff)
downloadbcm5719-llvm-2499aeead93a28cff56816c6ce7c093d227a0084.tar.gz
bcm5719-llvm-2499aeead93a28cff56816c6ce7c093d227a0084.zip
SafeStack: Prevent OOB reads with mem intrinsics
Summary: Currently, the SafeStack analysis disallows out-of-bounds writes but not out-of-bounds reads for mem intrinsics like llvm.memcpy. This could cause leaks of pointers to the safe stack by leaking spilled registers/ frame pointers. Check for allocas used as source or destination pointers to mem intrinsics. Reviewers: eugenis Reviewed By: eugenis Subscribers: pcc, llvm-commits, kcc Differential Revision: https://reviews.llvm.org/D51334 llvm-svn: 341116
Diffstat (limited to 'llvm/test/Transforms/SafeStack/X86')
-rw-r--r--llvm/test/Transforms/SafeStack/X86/memintrinsic-oob-read.ll14
1 files changed, 14 insertions, 0 deletions
diff --git a/llvm/test/Transforms/SafeStack/X86/memintrinsic-oob-read.ll b/llvm/test/Transforms/SafeStack/X86/memintrinsic-oob-read.ll
new file mode 100644
index 00000000000..90af6b3e540
--- /dev/null
+++ b/llvm/test/Transforms/SafeStack/X86/memintrinsic-oob-read.ll
@@ -0,0 +1,14 @@
+; RUN: opt -safe-stack -S -mtriple=i386-pc-linux-gnu < %s -o - | FileCheck %s
+; RUN: opt -safe-stack -S -mtriple=x86_64-pc-linux-gnu < %s -o - | FileCheck %s
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture writeonly, i8* nocapture readonly, i64, i1)
+
+; CHECK: __safestack_unsafe_stack_ptr
+define void @oob_read(i8* %ptr) safestack {
+ %1 = alloca i8
+ call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %ptr, i8* align 1 %1, i64 4, i1 false)
+ ret void
+}
OpenPOWER on IntegriCloud