diff options
| author | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2016-10-31 22:28:10 +0000 | 
|---|---|---|
| committer | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2016-10-31 22:28:10 +0000 | 
| commit | f75430963df0c86adad1145e334105a20bcca77c (patch) | |
| tree | 6981c156ba3906c4e8bb8d7752322d73ba6fddc1 /clang/lib/CodeGen | |
| parent | e1aa782bd073925dae4c3069e396bdd77e2199a1 (diff) | |
| download | bcm5719-llvm-f75430963df0c86adad1145e334105a20bcca77c.tar.gz bcm5719-llvm-f75430963df0c86adad1145e334105a20bcca77c.zip | |
[cfi] Fix missing !type annotation.
CFI (only in the cross-dso mode) fails to set !type annotations when
a function is used before it is defined.
llvm-svn: 285650
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CodeGenModule.cpp | 14 | 
1 files changed, 9 insertions, 5 deletions
| diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 81d9ead3d16..291ff8ed57b 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -929,6 +929,11 @@ void CodeGenModule::SetLLVMFunctionAttributesForDefinition(const Decl *D,      if (F->getAlignment() < 2 && isa<CXXMethodDecl>(D))        F->setAlignment(2);    } + +  // In the cross-dso CFI mode, we want !type attributes on definitions only. +  if (CodeGenOpts.SanitizeCfiCrossDso) +    if (auto *FD = dyn_cast<FunctionDecl>(D)) +      CreateFunctionTypeMetadata(FD, F);  }  void CodeGenModule::SetCommonAttributes(const Decl *D, @@ -1011,10 +1016,6 @@ void CodeGenModule::CreateFunctionTypeMetadata(const FunctionDecl *FD,    // Additionally, if building with cross-DSO support...    if (CodeGenOpts.SanitizeCfiCrossDso) { -    // Don't emit entries for function declarations. In cross-DSO mode these are -    // handled with better precision at run time. -    if (!FD->hasBody()) -      return;      // Skip available_externally functions. They won't be codegen'ed in the      // current module anyway.      if (getContext().GetGVALinkageForFunction(FD) == GVA_AvailableExternally) @@ -1087,7 +1088,10 @@ void CodeGenModule::SetFunctionAttributes(GlobalDecl GD, llvm::Function *F,      if (MD->isVirtual())        F->setUnnamedAddr(llvm::GlobalValue::UnnamedAddr::Global); -  CreateFunctionTypeMetadata(FD, F); +  // Don't emit entries for function declarations in the cross-DSO mode. This +  // is handled with better precision by the receiving DSO. +  if (!CodeGenOpts.SanitizeCfiCrossDso) +    CreateFunctionTypeMetadata(FD, F);  }  void CodeGenModule::addUsedGlobal(llvm::GlobalValue *GV) { | 

