mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
06fe9815da
This adds support for TSan C++ exception handling, where we need to add extra calls to __tsan_func_exit when a function is exitted via exception mechanisms. Otherwise the shadow stack gets corrupted (leaked). This patch moves and enhances the existing implementation of EscapeEnumerator that finds all possible function exit points, and adds extra EH cleanup blocks where needed. Differential Revision: https://reviews.llvm.org/D26177 llvm-svn: 286893
37 lines
1.0 KiB
LLVM
37 lines
1.0 KiB
LLVM
; RUN: opt < %s -tsan -S | FileCheck %s
|
|
|
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
; no sanitize_thread attribute here
|
|
define i32 @read_4_bytes(i32* %a) {
|
|
entry:
|
|
%tmp1 = load i32, i32* %a, align 4
|
|
ret i32 %tmp1
|
|
}
|
|
|
|
; CHECK: define i32 @read_4_bytes(i32* %a) {
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NEXT: %tmp1 = load i32, i32* %a, align 4
|
|
; CHECK: ret i32 %tmp1
|
|
|
|
; no sanitize_thread attribute here
|
|
define i32 @read_4_bytes_and_call(i32* %a) {
|
|
entry:
|
|
call void @foo()
|
|
%tmp1 = load i32, i32* %a, align 4
|
|
ret i32 %tmp1
|
|
}
|
|
|
|
; CHECK: define i32 @read_4_bytes_and_call(i32* %a) {
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NEXT: %0 = call i8* @llvm.returnaddress(i32 0)
|
|
; CHECK-NEXT: call void @__tsan_func_entry(i8* %0)
|
|
; CHECK-NEXT: call void @foo()
|
|
; CHECK-NEXT: %tmp1 = load i32, i32* %a, align 4
|
|
; CHECK-NEXT: call void @__tsan_func_exit()
|
|
; CHECK-NEXT: ret i32 %tmp1
|
|
|
|
declare void @foo() nounwind
|
|
|