mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
d0be6f7653
Summary: This is the third of a multi-part change to implement subcommands for the `llvm-xray` tool. Here we define the `account` subcommand which does simple function call accounting, generating basic statistics on function calls we find in an XRay log/trace. We support text output and csv output for this subcommand. This change also supports sorting, summing, and filtering the top N results. Part of this tool will later be turned into a library that could be used for basic function call accounting. Depends on D24376. Reviewers: dblaikie, echristo Subscribers: mehdi_amini, dberris, beanz, llvm-commits Differential Revision: https://reviews.llvm.org/D24377 llvm-svn: 291749
103 lines
2.8 KiB
C++
103 lines
2.8 KiB
C++
//===- xray-record-yaml.h - XRay Record YAML Support Definitions ----------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Types and traits specialisations for YAML I/O of XRay log entries.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
#ifndef LLVM_TOOLS_LLVM_XRAY_XRAY_RECORD_YAML_H
|
|
#define LLVM_TOOLS_LLVM_XRAY_XRAY_RECORD_YAML_H
|
|
|
|
#include <type_traits>
|
|
|
|
#include "xray-record.h"
|
|
#include "llvm/Support/YAMLTraits.h"
|
|
|
|
namespace llvm {
|
|
namespace xray {
|
|
|
|
struct YAMLXRayFileHeader {
|
|
uint16_t Version;
|
|
uint16_t Type;
|
|
bool ConstantTSC;
|
|
bool NonstopTSC;
|
|
uint64_t CycleFrequency;
|
|
};
|
|
|
|
struct YAMLXRayRecord {
|
|
uint16_t RecordType;
|
|
uint8_t CPU;
|
|
RecordTypes Type;
|
|
int32_t FuncId;
|
|
std::string Function;
|
|
uint64_t TSC;
|
|
uint32_t TId;
|
|
};
|
|
|
|
struct YAMLXRayTrace {
|
|
YAMLXRayFileHeader Header;
|
|
std::vector<YAMLXRayRecord> Records;
|
|
};
|
|
|
|
using XRayRecordStorage =
|
|
std::aligned_storage<sizeof(XRayRecord), alignof(XRayRecord)>::type;
|
|
|
|
} // namespace xray
|
|
|
|
namespace yaml {
|
|
|
|
// YAML Traits
|
|
// -----------
|
|
template <> struct ScalarEnumerationTraits<xray::RecordTypes> {
|
|
static void enumeration(IO &IO, xray::RecordTypes &Type) {
|
|
IO.enumCase(Type, "function-enter", xray::RecordTypes::ENTER);
|
|
IO.enumCase(Type, "function-exit", xray::RecordTypes::EXIT);
|
|
}
|
|
};
|
|
|
|
template <> struct MappingTraits<xray::YAMLXRayFileHeader> {
|
|
static void mapping(IO &IO, xray::YAMLXRayFileHeader &Header) {
|
|
IO.mapRequired("version", Header.Version);
|
|
IO.mapRequired("type", Header.Type);
|
|
IO.mapRequired("constant-tsc", Header.ConstantTSC);
|
|
IO.mapRequired("nonstop-tsc", Header.NonstopTSC);
|
|
IO.mapRequired("cycle-frequency", Header.CycleFrequency);
|
|
}
|
|
};
|
|
|
|
template <> struct MappingTraits<xray::YAMLXRayRecord> {
|
|
static void mapping(IO &IO, xray::YAMLXRayRecord &Record) {
|
|
// FIXME: Make this type actually be descriptive
|
|
IO.mapRequired("type", Record.RecordType);
|
|
IO.mapRequired("func-id", Record.FuncId);
|
|
IO.mapOptional("function", Record.Function);
|
|
IO.mapRequired("cpu", Record.CPU);
|
|
IO.mapRequired("thread", Record.TId);
|
|
IO.mapRequired("kind", Record.Type);
|
|
IO.mapRequired("tsc", Record.TSC);
|
|
}
|
|
|
|
static constexpr bool flow = true;
|
|
};
|
|
|
|
template <> struct MappingTraits<xray::YAMLXRayTrace> {
|
|
static void mapping(IO &IO, xray::YAMLXRayTrace &Trace) {
|
|
// A trace file contains two parts, the header and the list of all the
|
|
// trace records.
|
|
IO.mapRequired("header", Trace.Header);
|
|
IO.mapRequired("records", Trace.Records);
|
|
}
|
|
};
|
|
|
|
} // namespace yaml
|
|
} // namespace llvm
|
|
|
|
LLVM_YAML_IS_SEQUENCE_VECTOR(xray::YAMLXRayRecord)
|
|
|
|
#endif // LLVM_TOOLS_LLVM_XRAY_XRAY_RECORD_YAML_H
|