Files
clang-p2996/lldb/source/Plugins/Trace/intel-pt/TraceIntelPTJSONStructs.h
Walter Erquinigo 602497d672 [trace] [intel pt] Create a "process trace save" command
added new command "process trace save -d <directory>".
-it saves a JSON file as <directory>/trace.json, with the main properties of the trace session.
-it saves binary Intel-pt trace as <directory>/thread_id.trace; each file saves each thread.
-it saves modules to the directory <directory>/modules .
-it only works for live process and it only support Intel-pt right now.

Example:
```
b main
run
process trace start
n
process trace save -d /tmp/mytrace
```
A file named trace.json and xxx.trace should be generated in /tmp/mytrace. To load the trace that was just saved:
```
trace load /tmp/mytrace
thread trace dump instructions
```
You should see the instructions of the trace got printed.

To run a test:
```
cd ~/llvm-sand/build/Release/fbcode-x86_64/toolchain
ninja lldb-dotest
./bin/lldb-dotest -p TestTraceSave
```

Reviewed By: wallace

Differential Revision: https://reviews.llvm.org/D107669
2021-08-27 09:34:01 -07:00

76 lines
2.1 KiB
C++

//===-- TraceIntelPTJSONStructs.h -----------------------------*- C++ //-*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_TRACEINTELPTJSONSTRUCTS_H
#define LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_TRACEINTELPTJSONSTRUCTS_H
#include "../common/TraceJSONStructs.h"
#include <intel-pt.h>
namespace lldb_private {
namespace trace_intel_pt {
struct JSONTraceIntelPTCPUInfo {
JSONTraceIntelPTCPUInfo() = default;
JSONTraceIntelPTCPUInfo(pt_cpu cpu_info) {
family = static_cast<int64_t>(cpu_info.family);
model = static_cast<int64_t>(cpu_info.model);
stepping = static_cast<int64_t>(cpu_info.stepping);
vendor = cpu_info.vendor == pcv_intel ? "intel" : "Unknown";
}
int64_t family;
int64_t model;
int64_t stepping;
std::string vendor;
};
struct JSONTraceIntelPTTrace {
std::string type;
JSONTraceIntelPTCPUInfo cpuInfo;
};
struct JSONTraceIntelPTSession {
JSONTraceIntelPTTrace ipt_trace;
JSONTraceSessionBase session_base;
};
struct JSONTraceIntelPTSettings : JSONTracePluginSettings {
JSONTraceIntelPTCPUInfo cpuInfo;
};
} // namespace trace_intel_pt
} // namespace lldb_private
namespace llvm {
namespace json {
bool fromJSON(
const Value &value,
lldb_private::trace_intel_pt::JSONTraceIntelPTSettings &plugin_settings,
Path path);
bool fromJSON(const llvm::json::Value &value,
lldb_private::trace_intel_pt::JSONTraceIntelPTCPUInfo &packet,
llvm::json::Path path);
llvm::json::Value
toJSON(const lldb_private::trace_intel_pt::JSONTraceIntelPTCPUInfo &cpu_info);
llvm::json::Value
toJSON(const lldb_private::trace_intel_pt::JSONTraceIntelPTTrace &trace);
llvm::json::Value
toJSON(const lldb_private::trace_intel_pt::JSONTraceIntelPTSession &session);
} // namespace json
} // namespace llvm
#endif // LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_TRACEINTELPTJSONSTRUCTS_H