1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 02:52:53 +02:00
llvm-mirror/test/Instrumentation/ThreadSanitizer/tsan_address_space_attr.ll
Anna Zaks 3450346030 [asan] Do not instrument pointers with address space attributes
Do not instrument pointers with address space attributes since we cannot track
them anyway. Instrumenting them results in false positives in ASan and a
compiler crash in TSan. (The compiler should not crash in any case, but that's
a different problem.)

llvm-svn: 273339
2016-06-22 00:15:52 +00:00

34 lines
1.3 KiB
LLVM

; RUN: opt < %s -tsan -S | FileCheck %s
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-apple-macosx10.11.0"
; Checks that we do not instrument loads and stores comming from custom address space.
; These result in crashing the compiler.
; int foo(int argc, const char * argv[]) {
; void *__attribute__((address_space(256))) *gs_base = (((void * __attribute__((address_space(256))) *)0));
; void *somevalue = gs_base[-1];
; return somevalue;
; }
define i32 @foo(i32 %argc, i8** %argv) sanitize_thread {
entry:
%retval = alloca i32, align 4
%argc.addr = alloca i32, align 4
%argv.addr = alloca i8**, align 8
%gs_base = alloca i8* addrspace(256)*, align 8
%somevalue = alloca i8*, align 8
store i32 0, i32* %retval, align 4
store i32 %argc, i32* %argc.addr, align 4
store i8** %argv, i8*** %argv.addr, align 8
store i8* addrspace(256)* null, i8* addrspace(256)** %gs_base, align 8
%0 = load i8* addrspace(256)*, i8* addrspace(256)** %gs_base, align 8
%arrayidx = getelementptr inbounds i8*, i8* addrspace(256)* %0, i64 -1
%1 = load i8*, i8* addrspace(256)* %arrayidx, align 8
store i8* %1, i8** %somevalue, align 8
%2 = load i8*, i8** %somevalue, align 8
%3 = ptrtoint i8* %2 to i32
ret i32 %3
}
; CHECK-NOT: call void @__tsan_read
; CHECK-NOT: addrspacecast