LLDB mainline
lldb-private-types.h
Go to the documentation of this file.
1//===-- lldb-private-types.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_LLDB_PRIVATE_TYPES_H
10#define LLDB_LLDB_PRIVATE_TYPES_H
11
12#include "lldb/lldb-private.h"
13
14#include "llvm/ADT/ArrayRef.h"
15#include "llvm/ADT/SmallString.h"
16
17#include <type_traits>
18
19namespace llvm {
20namespace sys {
21class DynamicLibrary;
22}
23}
24
25namespace lldb_private {
26class Platform;
27class ExecutionContext;
28class RegisterFlags;
29
30typedef llvm::SmallString<256> PathSmallString;
31
32typedef llvm::sys::DynamicLibrary (*LoadPluginCallbackType)(
33 const lldb::DebuggerSP &debugger_sp, const FileSpec &spec, Status &error);
34
35/// Every register is described in detail including its name, alternate name
36/// (optional), encoding, size in bytes and the default display format.
38 /// Name of this register, can't be NULL.
39 const char *name;
40 /// Alternate name of this register, can be NULL.
41 const char *alt_name;
42 /// Size in bytes of the register.
43 uint32_t byte_size;
44 /// The byte offset in the register context data where this register's
45 /// value is found.
46 /// This is optional, and can be 0 if a particular RegisterContext does not
47 /// need to address its registers by byte offset.
48 uint32_t byte_offset;
49 /// Encoding of the register bits.
51 /// Default display format.
53 /// Holds all of the various register numbers for all register kinds.
55 /// List of registers (terminated with LLDB_INVALID_REGNUM). If this value is
56 /// not null, all registers in this list will be read first, at which point
57 /// the value for this register will be valid. For example, the value list
58 /// for ah would be eax (x86) or rax (x64). Register numbers are
59 /// of eRegisterKindLLDB. If multiple registers are listed, the final
60 /// value will be the concatenation of them.
61 uint32_t *value_regs;
62 /// List of registers (terminated with LLDB_INVALID_REGNUM). If this value is
63 /// not null, all registers in this list will be invalidated when the value of
64 /// this register changes. For example, the invalidate list for eax would be
65 /// rax ax, ah, and al.
66 uint32_t *invalidate_regs;
67 /// If not nullptr, a type defined by XML descriptions.
68 /// Register info tables are constructed as const, but this field may need to
69 /// be updated if a specific target OS has a different layout. To enable that,
70 /// this is mutable. The data pointed to is still const, so you must swap a
71 /// whole set of flags for another.
72 mutable const RegisterFlags *flags_type;
73
74 llvm::ArrayRef<uint8_t> data(const uint8_t *context_base) const {
75 return llvm::ArrayRef<uint8_t>(context_base + byte_offset, byte_size);
76 }
77
78 llvm::MutableArrayRef<uint8_t> mutable_data(uint8_t *context_base) const {
79 return llvm::MutableArrayRef<uint8_t>(context_base + byte_offset,
80 byte_size);
81 }
82};
83static_assert(std::is_trivial<RegisterInfo>::value,
84 "RegisterInfo must be trivial.");
85
86/// Registers are grouped into register sets
88 /// Name of this register set.
89 const char *name;
90 /// A short name for this register set.
91 const char *short_name;
92 /// The number of registers in REGISTERS array below.
94 /// An array of register indices in this set. The values in this array are
95 /// *indices* (not register numbers) into a particular RegisterContext's
96 /// register array. For example, if eax is defined at index 4 for a
97 /// particular RegisterContext, eax would be included in this RegisterSet by
98 /// adding the value 4. Not by adding the value lldb_eax_i386.
99 const uint32_t *registers;
100};
101
102/// A type-erased pair of llvm::dwarf::SourceLanguageName and version.
104 SourceLanguage() = default;
105 SourceLanguage(lldb::LanguageType language_type);
106 SourceLanguage(uint16_t name, uint32_t version)
107 : name(name), version(version) {}
108 SourceLanguage(std::optional<std::pair<uint16_t, uint32_t>> name_vers)
109 : name(name_vers ? name_vers->first : 0),
110 version(name_vers ? name_vers->second : 0) {}
111 operator bool() const { return name > 0; }
113 llvm::StringRef GetDescription() const;
114 bool IsC() const;
115 bool IsObjC() const;
116 bool IsCPlusPlus() const;
117 uint16_t name = 0;
118 uint32_t version = 0;
119};
120
122 int64_t value;
123 const char *string_value;
124 const char *usage;
125};
126
127using OptionEnumValues = llvm::ArrayRef<OptionEnumValueElement>;
128
130 virtual ~OptionValidator() = default;
131 virtual bool IsValid(Platform &platform,
132 const ExecutionContext &target) const = 0;
133 virtual const char *ShortConditionString() const = 0;
134 virtual const char *LongConditionString() const = 0;
135};
136
137typedef struct type128 { uint64_t x[2]; } type128;
138typedef struct type256 { uint64_t x[4]; } type256;
139
140/// Functor that returns a ValueObjectSP for a variable given its name
141/// and the StackFrame of interest. Used primarily in the Materializer
142/// to refetch a ValueObject when the ExecutionContextScope changes.
144 std::function<lldb::ValueObjectSP(ConstString, StackFrame *)>;
145
146typedef void (*DebuggerDestroyCallback)(lldb::user_id_t debugger_id,
147 void *baton);
149 void *baton, const char **argv, lldb_private::CommandReturnObject &result);
150} // namespace lldb_private
151
152#endif // LLDB_LLDB_PRIVATE_TYPES_H
static llvm::raw_ostream & error(Stream &strm)
A uniqued constant string class.
Definition: ConstString.h:40
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
A file utility class.
Definition: FileSpec.h:56
A plug-in interface definition class for debug platform that includes many platform abilities such as...
Definition: Platform.h:76
This base class provides an interface to stack frames.
Definition: StackFrame.h:44
An error handling class.
Definition: Status.h:115
A class that represents a running process on the host machine.
llvm::SmallString< 256 > PathSmallString
void(* DebuggerDestroyCallback)(lldb::user_id_t debugger_id, void *baton)
std::function< lldb::ValueObjectSP(ConstString, StackFrame *)> ValueObjectProviderTy
Functor that returns a ValueObjectSP for a variable given its name and the StackFrame of interest.
bool(* CommandOverrideCallbackWithResult)(void *baton, const char **argv, lldb_private::CommandReturnObject &result)
llvm::sys::DynamicLibrary(* LoadPluginCallbackType)(const lldb::DebuggerSP &debugger_sp, const FileSpec &spec, Status &error)
llvm::ArrayRef< OptionEnumValueElement > OptionEnumValues
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
Definition: lldb-forward.h:484
Format
Display format definitions.
LanguageType
Programming language type.
std::shared_ptr< lldb_private::Debugger > DebuggerSP
Definition: lldb-forward.h:339
Encoding
Register encoding definitions.
uint64_t user_id_t
Definition: lldb-types.h:82
@ kNumRegisterKinds
Definition: Debugger.h:54
virtual ~OptionValidator()=default
virtual const char * LongConditionString() const =0
virtual const char * ShortConditionString() const =0
virtual bool IsValid(Platform &platform, const ExecutionContext &target) const =0
Every register is described in detail including its name, alternate name (optional),...
llvm::MutableArrayRef< uint8_t > mutable_data(uint8_t *context_base) const
lldb::Encoding encoding
Encoding of the register bits.
const char * alt_name
Alternate name of this register, can be NULL.
uint32_t * value_regs
List of registers (terminated with LLDB_INVALID_REGNUM).
uint32_t byte_offset
The byte offset in the register context data where this register's value is found.
uint32_t byte_size
Size in bytes of the register.
uint32_t kinds[lldb::kNumRegisterKinds]
Holds all of the various register numbers for all register kinds.
const RegisterFlags * flags_type
If not nullptr, a type defined by XML descriptions.
llvm::ArrayRef< uint8_t > data(const uint8_t *context_base) const
const char * name
Name of this register, can't be NULL.
lldb::Format format
Default display format.
uint32_t * invalidate_regs
List of registers (terminated with LLDB_INVALID_REGNUM).
Registers are grouped into register sets.
size_t num_registers
The number of registers in REGISTERS array below.
const uint32_t * registers
An array of register indices in this set.
const char * name
Name of this register set.
const char * short_name
A short name for this register set.
A type-erased pair of llvm::dwarf::SourceLanguageName and version.
lldb::LanguageType AsLanguageType() const
Definition: Language.cpp:554
SourceLanguage(std::optional< std::pair< uint16_t, uint32_t > > name_vers)
SourceLanguage(uint16_t name, uint32_t version)
llvm::StringRef GetDescription() const
Definition: Language.cpp:561