blob: afc912a6398ee250e1e88923f26b91be399cca97 [file] [log] [blame]
Dean Michael Berrisa0e3ae42018-05-02 00:43:17 +00001//===- xray-fc-account.cpp: XRay Function Call Accounting Tool ------------===//
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +00002//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +00006//
7//===----------------------------------------------------------------------===//
8//
9// Implementation of the helper tools dealing with XRay-generated function ids.
10//
11//===----------------------------------------------------------------------===//
12
13#include "func-id-helper.h"
14#include "llvm/Support/Path.h"
15#include <sstream>
16
17using namespace llvm;
18using namespace xray;
19
20std::string FuncIdConversionHelper::SymbolOrNumber(int32_t FuncId) const {
Martin Pelikan86ed8e52018-03-01 01:59:24 +000021 auto CacheIt = CachedNames.find(FuncId);
22 if (CacheIt != CachedNames.end())
23 return CacheIt->second;
24
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +000025 std::ostringstream F;
26 auto It = FunctionAddresses.find(FuncId);
27 if (It == FunctionAddresses.end()) {
28 F << "#" << FuncId;
29 return F.str();
30 }
31
Alexey Lapshin77fc1f62019-02-27 13:17:36 +000032 object::SectionedAddress ModuleAddress;
33 ModuleAddress.Address = It->second;
34 // TODO: set proper section index here.
35 // object::SectionedAddress::UndefSection works for only absolute addresses.
36 ModuleAddress.SectionIndex = object::SectionedAddress::UndefSection;
37 if (auto ResOrErr = Symbolizer.symbolizeCode(BinaryInstrMap, ModuleAddress)) {
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +000038 auto &DI = *ResOrErr;
Michael Pozulp9abf6682019-08-15 05:15:22 +000039 if (DI.FunctionName == DILineInfo::BadString)
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +000040 F << "@(" << std::hex << It->second << ")";
41 else
42 F << DI.FunctionName;
43 } else
44 handleAllErrors(ResOrErr.takeError(), [&](const ErrorInfoBase &) {
45 F << "@(" << std::hex << It->second << ")";
46 });
47
Martin Pelikan86ed8e52018-03-01 01:59:24 +000048 auto S = F.str();
49 CachedNames[FuncId] = S;
50 return S;
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +000051}
52
53std::string FuncIdConversionHelper::FileLineAndColumn(int32_t FuncId) const {
54 auto It = FunctionAddresses.find(FuncId);
55 if (It == FunctionAddresses.end())
56 return "(unknown)";
57
58 std::ostringstream F;
Alexey Lapshin77fc1f62019-02-27 13:17:36 +000059 object::SectionedAddress ModuleAddress;
60 ModuleAddress.Address = It->second;
61 // TODO: set proper section index here.
62 // object::SectionedAddress::UndefSection works for only absolute addresses.
63 ModuleAddress.SectionIndex = object::SectionedAddress::UndefSection;
64 auto ResOrErr = Symbolizer.symbolizeCode(BinaryInstrMap, ModuleAddress);
Dean Michael Berrisf8f909f2017-01-10 02:38:11 +000065 if (!ResOrErr) {
66 consumeError(ResOrErr.takeError());
67 return "(unknown)";
68 }
69
70 auto &DI = *ResOrErr;
71 F << sys::path::filename(DI.FileName).str() << ":" << DI.Line << ":"
72 << DI.Column;
73
74 return F.str();
75}