LLDB  mainline
CommandObjectTraceStartIntelPT.h
Go to the documentation of this file.
1 //===-- CommandObjectTraceStartIntelPT.h ----------------------*- C++ //-*-===//
2 //
3 // 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
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_COMMANDOBJECTTRACESTARTINTELPT_H
10 #define LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_COMMANDOBJECTTRACESTARTINTELPT_H
11 
12 #include "../../../../source/Commands/CommandObjectTrace.h"
13 #include "TraceIntelPT.h"
16 
17 namespace lldb_private {
18 namespace trace_intel_pt {
19 
22 public:
23  class CommandOptions : public Options {
24  public:
26 
27  Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg,
28  ExecutionContext *execution_context) override;
29 
30  void OptionParsingStarting(ExecutionContext *execution_context) override;
31 
32  llvm::ArrayRef<OptionDefinition> GetDefinitions() override;
33 
34  uint64_t m_ipt_trace_size;
36  llvm::Optional<uint64_t> m_psb_period;
37  };
38 
40  CommandInterpreter &interpreter)
42  interpreter, "thread trace start",
43  "Start tracing one or more threads with intel-pt. "
44  "Defaults to the current thread. Thread indices can be "
45  "specified as arguments.\n Use the thread-index \"all\" to trace "
46  "all threads including future threads.",
47  "thread trace start [<thread-index> <thread-index> ...] "
48  "[<intel-pt-options>]",
49  lldb::eCommandRequiresProcess | lldb::eCommandTryTargetAPILock |
50  lldb::eCommandProcessMustBeLaunched |
51  lldb::eCommandProcessMustBePaused),
52  m_trace(trace), m_options() {}
53 
54  Options *GetOptions() override { return &m_options; }
55 
56 protected:
57  bool DoExecuteOnThreads(Args &command, CommandReturnObject &result,
58  llvm::ArrayRef<lldb::tid_t> tids) override;
59 
62 };
63 
65 public:
66  class CommandOptions : public Options {
67  public:
69 
70  Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg,
71  ExecutionContext *execution_context) override;
72 
73  void OptionParsingStarting(ExecutionContext *execution_context) override;
74 
75  llvm::ArrayRef<OptionDefinition> GetDefinitions() override;
76 
77  uint64_t m_ipt_trace_size;
80  llvm::Optional<uint64_t> m_psb_period;
82  };
83 
85  CommandInterpreter &interpreter)
87  interpreter, "process trace start",
88  "Start tracing this process with intel-pt, including future "
89  "threads. If --per-cpu-tracing is not provided, this traces each "
90  "thread independently, thus using a trace buffer per thread. "
91  "Threads traced with the \"thread trace start\" command are left "
92  "unaffected ant not retraced. This is the recommended option "
93  "unless the number of threads is huge. If --per-cpu-tracing is "
94  "passed, each cpu core is traced instead of each thread, which "
95  "uses a fixed number of trace buffers, but might result in less "
96  "data available for less frequent threads.",
97  "process trace start [<intel-pt-options>]",
98  lldb::eCommandRequiresProcess | lldb::eCommandTryTargetAPILock |
99  lldb::eCommandProcessMustBeLaunched |
100  lldb::eCommandProcessMustBePaused),
101  m_trace(trace), m_options() {}
102 
103  Options *GetOptions() override { return &m_options; }
104 
105 protected:
106  bool DoExecute(Args &command, CommandReturnObject &result) override;
107 
110 };
111 
112 } // namespace trace_intel_pt
113 } // namespace lldb_private
114 
115 #endif // LLDB_SOURCE_PLUGINS_TRACE_INTEL_PT_COMMANDOBJECTTRACESTARTINTELPT_H
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::m_enable_tsc
bool m_enable_tsc
Definition: CommandObjectTraceStartIntelPT.h:79
lldb_private::CommandObjectParsed
Definition: CommandObject.h:393
lldb_private::ExecutionContext
Definition: ExecutionContext.h:292
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::DoExecuteOnThreads
bool DoExecuteOnThreads(Args &command, CommandReturnObject &result, llvm::ArrayRef< lldb::tid_t > tids) override
Method that handles the command after the main arguments have been parsed.
Definition: CommandObjectTraceStartIntelPT.cpp:76
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::OptionParsingStarting
void OptionParsingStarting(ExecutionContext *execution_context) override
Definition: CommandObjectTraceStartIntelPT.cpp:146
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandObjectProcessTraceStartIntelPT
CommandObjectProcessTraceStartIntelPT(TraceIntelPT &trace, CommandInterpreter &interpreter)
Definition: CommandObjectTraceStartIntelPT.h:84
lldb_private::trace_intel_pt::TraceIntelPT
Definition: TraceIntelPT.h:24
lldb_private::Args
Definition: Args.h:33
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::GetDefinitions
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
Definition: CommandObjectTraceStartIntelPT.cpp:72
CommandReturnObject.h
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::m_psb_period
llvm::Optional< uint64_t > m_psb_period
Definition: CommandObjectTraceStartIntelPT.h:80
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::CommandOptions
CommandOptions()
Definition: CommandObjectTraceStartIntelPT.h:68
lldb_private::Options
Definition: Options.h:57
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::GetOptions
Options * GetOptions() override
Definition: CommandObjectTraceStartIntelPT.h:54
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT
Definition: CommandObjectTraceStartIntelPT.h:20
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions
Definition: CommandObjectTraceStartIntelPT.h:66
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::CommandOptions
CommandOptions()
Definition: CommandObjectTraceStartIntelPT.h:25
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::DoExecute
bool DoExecute(Args &command, CommandReturnObject &result) override
Definition: CommandObjectTraceStartIntelPT.cpp:159
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions
Definition: CommandObjectTraceStartIntelPT.h:23
lldb_private::CommandInterpreter
Definition: CommandInterpreter.h:214
lldb_private::CommandObjectMultipleThreads
Class similar to CommandObjectIterateOverThreads, but which performs an action on multiple threads at...
Definition: CommandObjectThreadUtil.h:81
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::OptionParsingStarting
void OptionParsingStarting(ExecutionContext *execution_context) override
Definition: CommandObjectTraceStartIntelPT.cpp:65
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::m_enable_tsc
bool m_enable_tsc
Definition: CommandObjectTraceStartIntelPT.h:35
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::GetOptions
Options * GetOptions() override
Definition: CommandObjectTraceStartIntelPT.h:103
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandObjectThreadTraceStartIntelPT
CommandObjectThreadTraceStartIntelPT(TraceIntelPT &trace, CommandInterpreter &interpreter)
Definition: CommandObjectTraceStartIntelPT.h:39
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::m_trace
TraceIntelPT & m_trace
Definition: CommandObjectTraceStartIntelPT.h:108
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::m_ipt_trace_size
uint64_t m_ipt_trace_size
Definition: CommandObjectTraceStartIntelPT.h:34
lldb_private::Status
Definition: Status.h:44
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::m_process_buffer_size_limit
uint64_t m_process_buffer_size_limit
Definition: CommandObjectTraceStartIntelPT.h:78
lldb_private::CommandReturnObject
Definition: CommandReturnObject.h:26
uint32_t
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::m_psb_period
llvm::Optional< uint64_t > m_psb_period
Definition: CommandObjectTraceStartIntelPT.h:36
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::m_options
CommandOptions m_options
Definition: CommandObjectTraceStartIntelPT.h:109
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::m_per_cpu_tracing
bool m_per_cpu_tracing
Definition: CommandObjectTraceStartIntelPT.h:81
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::CommandOptions::SetOptionValue
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
Definition: CommandObjectTraceStartIntelPT.cpp:27
lldb_private
A class that represents a running process on the host machine.
Definition: SBCommandInterpreterRunOptions.h:16
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::GetDefinitions
llvm::ArrayRef< OptionDefinition > GetDefinitions() override
Definition: CommandObjectTraceStartIntelPT.cpp:155
CommandInterpreter.h
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::SetOptionValue
Status SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg, ExecutionContext *execution_context) override
Set the value of an option.
Definition: CommandObjectTraceStartIntelPT.cpp:93
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT::CommandOptions::m_ipt_trace_size
uint64_t m_ipt_trace_size
Definition: CommandObjectTraceStartIntelPT.h:77
lldb
Definition: SBAddress.h:15
TraceIntelPT.h
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::m_trace
TraceIntelPT & m_trace
Definition: CommandObjectTraceStartIntelPT.h:60
lldb_private::trace_intel_pt::CommandObjectProcessTraceStartIntelPT
Definition: CommandObjectTraceStartIntelPT.h:64
lldb_private::trace_intel_pt::CommandObjectThreadTraceStartIntelPT::m_options
CommandOptions m_options
Definition: CommandObjectTraceStartIntelPT.h:61