blob: 1b52a2670b1821fc72bf95a1067bb1d4af71d451 [file] [log] [blame]
Zachary Turner21473f72015-02-08 00:29:29 +00001//===- PDBSymbolFunc.cpp - --------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Zachary Turnera5549172015-02-10 22:43:25 +000010#include "llvm/DebugInfo/PDB/IPDBEnumChildren.h"
Zachary Turner2a5c0a22015-02-13 01:23:51 +000011#include "llvm/DebugInfo/PDB/IPDBSession.h"
Zachary Turner21473f72015-02-08 00:29:29 +000012#include "llvm/DebugInfo/PDB/PDBSymbol.h"
13#include "llvm/DebugInfo/PDB/PDBSymbolFunc.h"
Zachary Turnera5549172015-02-10 22:43:25 +000014#include "llvm/DebugInfo/PDB/PDBSymbolFuncDebugEnd.h"
15#include "llvm/DebugInfo/PDB/PDBSymbolFuncDebugStart.h"
Zachary Turnera952c492015-02-13 07:40:03 +000016#include "llvm/DebugInfo/PDB/PDBSymbolTypeFunctionSig.h"
Zachary Turner2a5c0a22015-02-13 01:23:51 +000017#include "llvm/DebugInfo/PDB/PDBSymbolTypeUDT.h"
Zachary Turnera5549172015-02-10 22:43:25 +000018#include "llvm/Support/Format.h"
Chandler Carruth71f308a2015-02-13 09:09:03 +000019#include <utility>
Zachary Turner21473f72015-02-08 00:29:29 +000020
21using namespace llvm;
Zachary Turner98571ed2015-02-08 22:53:53 +000022PDBSymbolFunc::PDBSymbolFunc(const IPDBSession &PDBSession,
Zachary Turnerbae16b32015-02-08 20:58:09 +000023 std::unique_ptr<IPDBRawSymbol> Symbol)
24 : PDBSymbol(PDBSession, std::move(Symbol)) {}
Zachary Turner21473f72015-02-08 00:29:29 +000025
Zachary Turnera5549172015-02-10 22:43:25 +000026void PDBSymbolFunc::dump(raw_ostream &OS, int Indent,
27 PDB_DumpLevel Level) const {
Zachary Turnera952c492015-02-13 07:40:03 +000028 OS << stream_indent(Indent);
29 if (Level >= PDB_DumpLevel::Normal) {
Zachary Turnera5549172015-02-10 22:43:25 +000030 uint32_t FuncStart = getRelativeVirtualAddress();
31 uint32_t FuncEnd = FuncStart + getLength();
Zachary Turner2a5c0a22015-02-13 01:23:51 +000032 if (FuncStart == 0 && FuncEnd == 0) {
33 OS << "func [???]";
34 } else {
35 OS << "func ";
36 OS << "[" << format_hex(FuncStart, 8);
37 if (auto DebugStart = findOneChild<PDBSymbolFuncDebugStart>())
38 OS << "+" << DebugStart->getRelativeVirtualAddress() - FuncStart;
39 OS << " - " << format_hex(FuncEnd, 8);
40 if (auto DebugEnd = findOneChild<PDBSymbolFuncDebugEnd>())
Zachary Turnera5549172015-02-10 22:43:25 +000041 OS << "-" << FuncEnd - DebugEnd->getRelativeVirtualAddress();
Zachary Turner2a5c0a22015-02-13 01:23:51 +000042 OS << "] ";
43 }
44
Zachary Turnera5549172015-02-10 22:43:25 +000045 PDB_RegisterId Reg = getLocalBasePointerRegisterId();
46 if (Reg == PDB_RegisterId::VFrame)
47 OS << "(VFrame)";
Zachary Turnerc074de02015-02-12 21:09:24 +000048 else if (hasFramePointer())
49 OS << "(" << Reg << ")";
50 else
Zachary Turnera5549172015-02-10 22:43:25 +000051 OS << "(FPO)";
Zachary Turner2a5c0a22015-02-13 01:23:51 +000052
53 OS << " ";
Zachary Turnera952c492015-02-13 07:40:03 +000054 uint32_t FuncSigId = getTypeId();
55 if (auto FuncSig = Session.getConcreteSymbolById<PDBSymbolTypeFunctionSig>(
56 FuncSigId)) {
57 OS << "(" << FuncSig->getCallingConvention() << ") ";
58 }
59
Zachary Turner2a5c0a22015-02-13 01:23:51 +000060 uint32_t ClassId = getClassParentId();
61 if (ClassId != 0) {
62 if (auto Class = Session.getSymbolById(ClassId)) {
63 if (auto UDT = dyn_cast<PDBSymbolTypeUDT>(Class.get()))
64 OS << UDT->getName() << "::";
65 else
66 OS << "{class " << Class->getSymTag() << "}::";
67 }
68 }
69 OS << getName();
Zachary Turnera952c492015-02-13 07:40:03 +000070 } else {
71 OS << getName();
Zachary Turnera5549172015-02-10 22:43:25 +000072 }
Zachary Turnera5549172015-02-10 22:43:25 +000073}