The module flag to indicate use of hostcall is insufficient to catch all cases where hostcall might be in use by a kernel. This is now replaced by a function attribute that gets propagated to top-level kernel functions via their respective call-graph. If the attribute "amdgpu-no-hostcall-ptr" is absent on a kernel, the default behaviour is to emit kernel metadata indicating that the kernel uses the hostcall buffer pointer passed as an implicit argument. The attribute may be placed explicitly by the user, or inferred by the AMDGPU attributor by examining the call-graph. The attribute is inferred only if the function is not being sanitized, and the implictarg_ptr does not result in a load of any byte in the hostcall pointer argument. Reviewed By: jdoerfert, arsenm, kpyzhov Differential Revision: https://reviews.llvm.org/D119216
32 lines
1.4 KiB
Plaintext
32 lines
1.4 KiB
Plaintext
// Create a sample address sanitizer bitcode library.
|
|
|
|
// RUN: %clang_cc1 -x ir -fcuda-is-device -triple amdgcn-amd-amdhsa -emit-llvm-bc \
|
|
// RUN: -disable-llvm-passes -o %t.asanrtl.bc %S/Inputs/amdgpu-asanrtl.ll
|
|
|
|
// Check sanitizer runtime library functions survive
|
|
// optimizations without being removed or parameters altered.
|
|
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=amdgcn-amd-amdhsa \
|
|
// RUN: -fcuda-is-device -target-cpu gfx906 -fsanitize=address \
|
|
// RUN: -mlink-bitcode-file %t.asanrtl.bc -x hip \
|
|
// RUN: | FileCheck -check-prefixes=ASAN %s
|
|
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=amdgcn-amd-amdhsa \
|
|
// RUN: -fcuda-is-device -target-cpu gfx906 -fsanitize=address \
|
|
// RUN: -O3 -mlink-bitcode-file %t.asanrtl.bc -x hip \
|
|
// RUN: | FileCheck -check-prefixes=ASAN %s
|
|
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=amdgcn-amd-amdhsa \
|
|
// RUN: -fcuda-is-device -target-cpu gfx906 -x hip \
|
|
// RUN: | FileCheck %s
|
|
|
|
// REQUIRES: amdgpu-registered-target
|
|
|
|
// ASAN-DAG: define weak void @__amdgpu_device_library_preserve_asan_functions()
|
|
// ASAN-DAG: @__amdgpu_device_library_preserve_asan_functions_ptr = weak addrspace(1) constant void ()* @__amdgpu_device_library_preserve_asan_functions
|
|
// ASAN-DAG: @llvm.compiler.used = {{.*}}@__amdgpu_device_library_preserve_asan_functions_ptr
|
|
// ASAN-DAG: define weak void @__asan_report_load1(i64 %{{.*}})
|
|
|
|
// CHECK-NOT: @__amdgpu_device_library_preserve_asan_functions
|
|
// CHECK-NOT: @__asan_report_load1
|