mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-28 12:30:22 +00:00
IRGen: Call SetLLVMFunctionAttributes{,ForDefinition} on __cfi_check_fail.
This has the main effect of causing target-cpu and target-features to be set on __cfi_check_fail, causing the function to become ABI-compatible with other functions in the case where these attributes affect ABI (e.g. reserve-x18). Technically we only need to call SetLLVMFunctionAttributes to get the target-* attributes set, but since we're creating a definition we probably ought to call the ForDefinition function as well. Fixes PR44094. Differential Revision: https://reviews.llvm.org/D70692
This commit is contained in:
parent
1b42cc0df1
commit
90b8bc003c
@ -3200,6 +3200,9 @@ void CodeGenFunction::EmitCfiCheckFail() {
|
||||
llvm::Function *F = llvm::Function::Create(
|
||||
llvm::FunctionType::get(VoidTy, {VoidPtrTy, VoidPtrTy}, false),
|
||||
llvm::GlobalValue::WeakODRLinkage, "__cfi_check_fail", &CGM.getModule());
|
||||
|
||||
CGM.SetLLVMFunctionAttributes(GlobalDecl(), FI, F);
|
||||
CGM.SetLLVMFunctionAttributesForDefinition(nullptr, F);
|
||||
F->setVisibility(llvm::GlobalValue::HiddenVisibility);
|
||||
|
||||
StartFunction(GlobalDecl(), CGM.getContext().VoidTy, F, FI, Args,
|
||||
|
5
clang/test/CodeGen/cfi-check-fail-attrs.c
Normal file
5
clang/test/CodeGen/cfi-check-fail-attrs.c
Normal file
@ -0,0 +1,5 @@
|
||||
// RUN: %clang_cc1 -triple aarch64-unknown-linux -fsanitize-cfi-cross-dso -target-feature +reserve-x18 -emit-llvm -o - %s | FileCheck %s
|
||||
|
||||
// CHECK: define weak_odr hidden void @__cfi_check_fail{{.*}} [[ATTR:#[0-9]*]]
|
||||
|
||||
// CHECK: attributes [[ATTR]] = {{.*}} "target-features"="+reserve-x18"
|
Loading…
x
Reference in New Issue
Block a user