diff options
| author | Amy Huang <akhuang@google.com> | 2019-04-08 17:58:29 +0000 | 
|---|---|---|
| committer | Amy Huang <akhuang@google.com> | 2019-04-08 17:58:29 +0000 | 
| commit | e7bd735bb03a7b8141e32f7d6cb98e8914d8799e (patch) | |
| tree | 6a170781af883dedd0ba142c83af6fcc576c2aff /clang | |
| parent | feac33ebb01ae71cd45e410954510f1dfa21c06a (diff) | |
| download | bcm5719-llvm-e7bd735bb03a7b8141e32f7d6cb98e8914d8799e.tar.gz bcm5719-llvm-e7bd735bb03a7b8141e32f7d6cb98e8914d8799e.zip | |
[MS] Add metadata for __declspec(allocator)
Summary:
Emit !heapallocsite in the metadata for calls to functions marked with
__declspec(allocator). Eventually this will be emitted as S_HEAPALLOCSITE debug
info in codeview.
Reviewers: rnk
Subscribers: jfb, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D60237
llvm-svn: 357928
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/CodeGen/CGCall.cpp | 16 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGDebugInfo.cpp | 14 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGDebugInfo.h | 4 | ||||
| -rw-r--r-- | clang/test/CodeGen/debug-info-codeview-heapallocsite.c | 27 | 
4 files changed, 54 insertions, 7 deletions
| diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp index aa52e1e7c51..ba273d7bbea 100644 --- a/clang/lib/CodeGen/CGCall.cpp +++ b/clang/lib/CodeGen/CGCall.cpp @@ -3800,6 +3800,8 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,    llvm::FunctionType *IRFuncTy = getTypes().GetFunctionType(CallInfo); +  const Decl *TargetDecl = Callee.getAbstractInfo().getCalleeDecl().getDecl(); +  #ifndef NDEBUG    if (!(CallInfo.isVariadic() && CallInfo.getArgStruct())) {      // For an inalloca varargs function, we don't expect CallInfo to match the @@ -4288,11 +4290,7 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,    // Apply always_inline to all calls within flatten functions.    // FIXME: should this really take priority over __try, below?    if (CurCodeDecl && CurCodeDecl->hasAttr<FlattenAttr>() && -      !(Callee.getAbstractInfo().getCalleeDecl().getDecl() && -        Callee.getAbstractInfo() -            .getCalleeDecl() -            .getDecl() -            ->hasAttr<NoInlineAttr>())) { +      !(TargetDecl && TargetDecl->hasAttr<NoInlineAttr>())) {      Attrs =          Attrs.addAttribute(getLLVMContext(), llvm::AttributeList::FunctionIndex,                             llvm::Attribute::AlwaysInline); @@ -4376,11 +4374,16 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,    // Suppress tail calls if requested.    if (llvm::CallInst *Call = dyn_cast<llvm::CallInst>(CI)) { -    const Decl *TargetDecl = Callee.getAbstractInfo().getCalleeDecl().getDecl();      if (TargetDecl && TargetDecl->hasAttr<NotTailCalledAttr>())        Call->setTailCallKind(llvm::CallInst::TCK_NoTail);    } +  // Add metadata for calls to MSAllocator functions +  // FIXME: Get the type that the return value is cast to. +  if (!DisableDebugInfo && TargetDecl && +      TargetDecl->hasAttr<MSAllocatorAttr>()) +    getDebugInfo()->addHeapAllocSiteMetadata(CI, RetTy, Loc); +    // 4. Finish the call.    // If the call doesn't return, finish the basic block and clear the @@ -4537,7 +4540,6 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,    } ();    // Emit the assume_aligned check on the return value. -  const Decl *TargetDecl = Callee.getAbstractInfo().getCalleeDecl().getDecl();    if (Ret.isScalar() && TargetDecl) {      if (const auto *AA = TargetDecl->getAttr<AssumeAlignedAttr>()) {        llvm::Value *OffsetValue = nullptr; diff --git a/clang/lib/CodeGen/CGDebugInfo.cpp b/clang/lib/CodeGen/CGDebugInfo.cpp index a982ef89396..da37da91a04 100644 --- a/clang/lib/CodeGen/CGDebugInfo.cpp +++ b/clang/lib/CodeGen/CGDebugInfo.cpp @@ -1959,6 +1959,20 @@ llvm::DIType *CGDebugInfo::getOrCreateStandaloneType(QualType D,    return T;  } +void CGDebugInfo::addHeapAllocSiteMetadata(llvm::Instruction *CI, +                                           QualType D, +                                           SourceLocation Loc) { +  llvm::MDNode *node; +  if (D.getTypePtr()->isVoidPointerType()) { +    node = llvm::MDNode::get(CGM.getLLVMContext(), None); +  } else { +    QualType PointeeTy = D.getTypePtr()->getPointeeType(); +    node = getOrCreateType(PointeeTy, getOrCreateFile(Loc)); +  } + +  CI->setMetadata("heapallocsite", node); +} +  void CGDebugInfo::completeType(const EnumDecl *ED) {    if (DebugKind <= codegenoptions::DebugLineTablesOnly)      return; diff --git a/clang/lib/CodeGen/CGDebugInfo.h b/clang/lib/CodeGen/CGDebugInfo.h index 67331b65d3b..fd7df089190 100644 --- a/clang/lib/CodeGen/CGDebugInfo.h +++ b/clang/lib/CodeGen/CGDebugInfo.h @@ -476,6 +476,10 @@ public:    /// Emit standalone debug info for a type.    llvm::DIType *getOrCreateStandaloneType(QualType Ty, SourceLocation Loc); +  /// Add heapallocsite metadata for MSAllocator calls. +  void addHeapAllocSiteMetadata(llvm::Instruction *CallSite, QualType Ty, +                                SourceLocation Loc); +    void completeType(const EnumDecl *ED);    void completeType(const RecordDecl *RD);    void completeRequiredType(const RecordDecl *RD); diff --git a/clang/test/CodeGen/debug-info-codeview-heapallocsite.c b/clang/test/CodeGen/debug-info-codeview-heapallocsite.c new file mode 100644 index 00000000000..a0a7e3b71c3 --- /dev/null +++ b/clang/test/CodeGen/debug-info-codeview-heapallocsite.c @@ -0,0 +1,27 @@ +// RUN: %clang_cc1 -triple x86_64-windows-msvc -debug-info-kind=limited -gcodeview -fdeclspec -S -emit-llvm < %s | FileCheck %s + +struct Foo { +  int x; +}; + +__declspec(allocator) void *alloc_void(); +__declspec(allocator) struct Foo *alloc_foo(); + +void call_alloc_void() { +  struct Foo *p = (struct Foo*)alloc_void(); +} + +void call_alloc_foo() { +  struct Foo *p = alloc_foo(); +} + +// CHECK-LABEL: define {{.*}}void @call_alloc_void +// CHECK: call i8* {{.*}}@alloc_void{{.*}} !heapallocsite [[DBG1:!.*]] + +// CHECK-LABEL: define {{.*}}void @call_alloc_foo +// CHECK: call %struct.Foo* {{.*}}@alloc_foo{{.*}} !heapallocsite [[DBG2:!.*]] + +// CHECK: [[DBG1]] = !{} +// CHECK: [[DBG2]] = distinct !DICompositeType(tag: DW_TAG_structure_type, +// CHECK-SAME:                                 name: "Foo" + | 

