2020-11-10 05:36:26 +08:00
|
|
|
//===-- TraceGDBRemotePackets.cpp -------------------------------*- 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/Utility/TraceGDBRemotePackets.h"
|
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
using namespace llvm::json;
|
|
|
|
|
|
|
|
namespace lldb_private {
|
|
|
|
/// jLLDBTraceSupported
|
|
|
|
/// \{
|
|
|
|
bool fromJSON(const json::Value &value, TraceSupportedResponse &packet,
|
|
|
|
Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("description", packet.description) &&
|
|
|
|
o.map("name", packet.name);
|
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceSupportedResponse &packet) {
|
|
|
|
return json::Value(
|
|
|
|
Object{{"description", packet.description}, {"name", packet.name}});
|
|
|
|
}
|
|
|
|
/// \}
|
|
|
|
|
|
|
|
/// jLLDBTraceStart
|
|
|
|
/// \{
|
|
|
|
bool TraceStartRequest::IsProcessTracing() const { return !(bool)tids; }
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceStartRequest &packet, Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("type", packet.type) && o.map("tids", packet.tids);
|
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceStartRequest &packet) {
|
|
|
|
return json::Value(Object{{"tids", packet.tids}, {"type", packet.type}});
|
|
|
|
}
|
|
|
|
/// \}
|
|
|
|
|
|
|
|
/// jLLDBTraceStop
|
|
|
|
/// \{
|
|
|
|
TraceStopRequest::TraceStopRequest(llvm::StringRef type,
|
|
|
|
const std::vector<lldb::tid_t> &tids_)
|
|
|
|
: type(type) {
|
|
|
|
tids.emplace();
|
|
|
|
for (lldb::tid_t tid : tids_)
|
2022-05-10 12:44:09 +08:00
|
|
|
tids->push_back(tid);
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool TraceStopRequest::IsProcessTracing() const { return !(bool)tids; }
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceStopRequest &packet, Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("type", packet.type) && o.map("tids", packet.tids);
|
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceStopRequest &packet) {
|
|
|
|
return json::Value(Object{{"type", packet.type}, {"tids", packet.tids}});
|
|
|
|
}
|
|
|
|
/// \}
|
|
|
|
|
|
|
|
/// jLLDBTraceGetState
|
|
|
|
/// \{
|
|
|
|
bool fromJSON(const json::Value &value, TraceGetStateRequest &packet,
|
|
|
|
Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("type", packet.type);
|
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceGetStateRequest &packet) {
|
|
|
|
return json::Value(Object{{"type", packet.type}});
|
|
|
|
}
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceBinaryData &packet, Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("kind", packet.kind) && o.map("size", packet.size);
|
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceBinaryData &packet) {
|
|
|
|
return json::Value(Object{{"kind", packet.kind}, {"size", packet.size}});
|
|
|
|
}
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceThreadState &packet, Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
|
|
|
return o && o.map("tid", packet.tid) &&
|
2022-05-03 10:10:39 +08:00
|
|
|
o.map("binaryData", packet.binary_data);
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceThreadState &packet) {
|
|
|
|
return json::Value(
|
2022-05-03 10:10:39 +08:00
|
|
|
Object{{"tid", packet.tid}, {"binaryData", packet.binary_data}});
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceGetStateResponse &packet,
|
|
|
|
Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
2022-05-03 10:10:39 +08:00
|
|
|
return o && o.map("tracedThreads", packet.traced_threads) &&
|
|
|
|
o.map("processBinaryData", packet.process_binary_data) &&
|
2022-06-15 06:53:59 +08:00
|
|
|
o.map("cpus", packet.cpus) && o.map("warnings", packet.warnings);
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
json::Value toJSON(const TraceGetStateResponse &packet) {
|
2022-05-03 10:10:39 +08:00
|
|
|
return json::Value(Object{{"tracedThreads", packet.traced_threads},
|
|
|
|
{"processBinaryData", packet.process_binary_data},
|
2022-06-15 06:53:59 +08:00
|
|
|
{"cpus", packet.cpus},
|
2022-05-19 05:32:35 +08:00
|
|
|
{"warnings", packet.warnings}});
|
2022-05-03 10:10:39 +08:00
|
|
|
}
|
|
|
|
|
2022-05-19 12:36:34 +08:00
|
|
|
void TraceGetStateResponse::AddWarning(StringRef warning) {
|
|
|
|
if (!warnings)
|
|
|
|
warnings.emplace();
|
|
|
|
warnings->push_back(warning.data());
|
|
|
|
}
|
|
|
|
|
2022-06-15 06:53:59 +08:00
|
|
|
bool fromJSON(const json::Value &value, TraceCpuState &packet,
|
2022-05-03 10:10:39 +08:00
|
|
|
json::Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
2022-06-15 06:53:59 +08:00
|
|
|
uint64_t cpu_id;
|
|
|
|
if (!(o && o.map("id", cpu_id) && o.map("binaryData", packet.binary_data)))
|
2022-05-03 10:10:39 +08:00
|
|
|
return false;
|
2022-06-15 06:53:59 +08:00
|
|
|
packet.id = static_cast<lldb::cpu_id_t>(cpu_id);
|
2022-05-03 10:10:39 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2022-06-15 06:53:59 +08:00
|
|
|
json::Value toJSON(const TraceCpuState &packet) {
|
2022-05-03 10:10:39 +08:00
|
|
|
return json::Value(
|
2022-06-15 06:53:59 +08:00
|
|
|
Object{{"id", packet.id}, {"binaryData", packet.binary_data}});
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
/// \}
|
|
|
|
|
|
|
|
/// jLLDBTraceGetBinaryData
|
|
|
|
/// \{
|
|
|
|
json::Value toJSON(const TraceGetBinaryDataRequest &packet) {
|
|
|
|
return json::Value(Object{{"type", packet.type},
|
|
|
|
{"kind", packet.kind},
|
|
|
|
{"tid", packet.tid},
|
2022-06-15 06:53:59 +08:00
|
|
|
{"cpuId", packet.cpu_id}});
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool fromJSON(const json::Value &value, TraceGetBinaryDataRequest &packet,
|
|
|
|
Path path) {
|
|
|
|
ObjectMapper o(value, path);
|
2022-06-15 06:53:59 +08:00
|
|
|
Optional<uint64_t> cpu_id;
|
2022-06-13 14:36:52 +08:00
|
|
|
if (!(o && o.map("type", packet.type) && o.map("kind", packet.kind) &&
|
2022-06-15 06:53:59 +08:00
|
|
|
o.map("tid", packet.tid) && o.map("cpuId", cpu_id)))
|
2022-05-20 07:39:20 +08:00
|
|
|
return false;
|
|
|
|
|
2022-06-15 06:53:59 +08:00
|
|
|
if (cpu_id)
|
|
|
|
packet.cpu_id = static_cast<lldb::cpu_id_t>(*cpu_id);
|
2022-05-20 07:39:20 +08:00
|
|
|
return true;
|
2020-11-10 05:36:26 +08:00
|
|
|
}
|
|
|
|
/// \}
|
|
|
|
|
|
|
|
} // namespace lldb_private
|