forked from OSchip/llvm-project
24 lines
914 B
LLVM
24 lines
914 B
LLVM
; Make sure we don't break the IR when moving non-instrumented allocas
|
|
|
|
; RUN: opt < %s -asan -asan-module -enable-new-pm=0 -S | FileCheck %s
|
|
; RUN: opt < %s -passes='asan-pipeline' -S | FileCheck %s
|
|
; RUN: opt < %s -asan -asan-module -enable-new-pm=0 -asan-instrument-dynamic-allocas -S | FileCheck %s
|
|
; RUN: opt < %s -passes='asan-pipeline' -asan-instrument-dynamic-allocas -S | FileCheck %s
|
|
|
|
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-apple-macosx10.10.0"
|
|
|
|
define i32 @foo() sanitize_address {
|
|
entry:
|
|
%non_instrumented1 = alloca i32, align 4
|
|
%t = load i32, i32* %non_instrumented1, align 4
|
|
%instrumented = alloca i32, align 4
|
|
%ptr = ptrtoint i32* %instrumented to i32
|
|
ret i32 %t
|
|
}
|
|
|
|
; CHECK: entry:
|
|
; CHECK: %non_instrumented1 = alloca i32, align 4
|
|
; CHECK: load i32, i32* %non_instrumented1
|
|
; CHECK: load i32, i32* @__asan_option_detect_stack_use_after_return
|