//===-- Trace.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_TARGET_TRACE_H #define LLDB_TARGET_TRACE_H #include <optional> #include <unordered_map> #include "llvm/Support/JSON.h" #include "lldb/Core/PluginInterface.h" #include "lldb/Target/Thread.h" #include "lldb/Target/TraceCursor.h" #include "lldb/Utility/ArchSpec.h" #include "lldb/Utility/TraceGDBRemotePackets.h" #include "lldb/Utility/UnimplementedError.h" #include "lldb/lldb-private.h" #include "lldb/lldb-types.h" namespace lldb_private { /// \class Trace Trace.h "lldb/Target/Trace.h" /// A plug-in interface definition class for trace information. /// /// Trace plug-ins allow processor trace information to be loaded into LLDB so /// that the data can be dumped, used for reverse and forward stepping to allow /// introspection into the reason your process crashed or found its way to its /// current state. /// /// Trace information can be loaded into a target without a process to allow /// introspection of the trace information during post mortem analysis, such as /// when loading core files. /// /// Processor trace information can also be fetched through the process /// interfaces during a live debug session if your process supports gathering /// this information. /// /// In order to support live tracing, the name of the plug-in should match the /// name of the tracing type returned by the gdb-remote packet /// \a jLLDBTraceSupported. class Trace : public PluginInterface, public std::enable_shared_from_this<Trace> { … }; } // namespace lldb_private #endif // LLDB_TARGET_TRACE_H