mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
e112fc03eb
This is only adding support to the dfsan instrumentation pass but not to the runtime. Added more RUN lines for testing: for each instrumentation test that had a -dfsan-fast-16-labels invocation, a new invocation was added using fast8. Reviewed By: stephan.yichao.zhao Differential Revision: https://reviews.llvm.org/D98734
58 lines
2.8 KiB
LLVM
58 lines
2.8 KiB
LLVM
; RUN: opt -mtriple=x86_64-unknown-linux-gnu < %s -dfsan -S --dfsan-abilist=%S/Inputs/shadow-args-abilist.txt | FileCheck %s
|
|
; RUN: opt -mtriple=x86_64-unknown-linux-gnu < %s -dfsan -S --dfsan-abilist=%S/Inputs/shadow-args-abilist.txt -dfsan-fast-16-labels | FileCheck %s
|
|
; RUN: opt -mtriple=x86_64-unknown-linux-gnu < %s -dfsan -S --dfsan-abilist=%S/Inputs/shadow-args-abilist.txt -dfsan-fast-8-labels | FileCheck %s
|
|
|
|
; REQUIRES: x86-registered-target
|
|
|
|
; Test that the custom abi marks shadow parameters as zero extended.
|
|
|
|
; CHECK: @__dfsan_shadow_width_bits = weak_odr constant i32 [[#SBITS:]]
|
|
; CHECK: @__dfsan_shadow_width_bytes = weak_odr constant i32 [[#SBYTES:]]
|
|
|
|
define i32 @m() {
|
|
; CHECK-LABEL: @"dfs$m"
|
|
; CHECK: %{{.*}} = call zeroext i16 @__dfsw_dfsan_get_label(i64 signext 56, i[[#SBITS]] zeroext 0, i[[#SBITS]]* %{{.*}})
|
|
|
|
entry:
|
|
%call = call zeroext i16 @dfsan_get_label(i64 signext 56)
|
|
%conv = zext i16 %call to i32
|
|
ret i32 %conv
|
|
}
|
|
|
|
define i32 @k() {
|
|
; CHECK-LABEL: @"dfs$k"
|
|
; CHECK: %{{.*}} = call zeroext i16 @__dfsw_k2(i64 signext 56, i64 signext 67, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]]* %{{.*}})
|
|
|
|
entry:
|
|
%call = call zeroext i16 @k2(i64 signext 56, i64 signext 67)
|
|
%conv = zext i16 %call to i32
|
|
ret i32 %conv
|
|
}
|
|
|
|
define i32 @k3() {
|
|
; CHECK-LABEL: @"dfs$k3"
|
|
; CHECK: %{{.*}} = call zeroext i16 @__dfsw_k4(i64 signext 56, i64 signext 67, i64 signext 78, i64 signext 89, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]] zeroext {{.*}}, i[[#SBITS]]* %{{.*}})
|
|
|
|
entry:
|
|
%call = call zeroext i16 @k4(i64 signext 56, i64 signext 67, i64 signext 78, i64 signext 89)
|
|
%conv = zext i16 %call to i32
|
|
ret i32 %conv
|
|
}
|
|
|
|
declare zeroext i16 @dfsan_get_label(i64 signext)
|
|
; CHECK-LABEL: @"dfsw$dfsan_get_label"
|
|
; CHECK: %{{.*}} = call i16 @__dfsw_dfsan_get_label(i64 %0, i[[#SBITS]] zeroext %1, i[[#SBITS]]* %{{.*}})
|
|
|
|
declare zeroext i16 @k2(i64 signext, i64 signext)
|
|
; CHECK-LABEL: @"dfsw$k2"
|
|
; CHECK: %{{.*}} = call i16 @__dfsw_k2(i64 %{{.*}}, i64 %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]]* %{{.*}})
|
|
|
|
declare zeroext i16 @k4(i64 signext, i64 signext, i64 signext, i64 signext)
|
|
; CHECK-LABEL: @"dfsw$k4"
|
|
; CHECK: %{{.*}} = call i16 @__dfsw_k4(i64 %{{.*}}, i64 %{{.*}}, i64 %{{.*}}, i64 %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]] zeroext %{{.*}}, i[[#SBITS]]* %{{.*}})
|
|
|
|
|
|
; CHECK: declare zeroext i16 @__dfsw_dfsan_get_label(i64 signext, i[[#SBITS]], i[[#SBITS]]*)
|
|
; CHECK: declare zeroext i16 @__dfsw_k2(i64 signext, i64 signext, i[[#SBITS]], i[[#SBITS]], i[[#SBITS]]*)
|
|
; CHECK: declare zeroext i16 @__dfsw_k4(i64 signext, i64 signext, i64 signext, i64 signext, i[[#SBITS]], i[[#SBITS]], i[[#SBITS]], i[[#SBITS]], i[[#SBITS]]*)
|