1 //===-- lldb-private-enumerations.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_ENUMERATIONS_H 10 #define LLDB_LLDB_PRIVATE_ENUMERATIONS_H 11 12 #include "lldb/lldb-enumerations.h" 13 #include "llvm/ADT/BitmaskEnum.h" 14 #include "llvm/ADT/StringRef.h" 15 #include "llvm/Support/FormatProviders.h" 16 #include "llvm/Support/raw_ostream.h" 17 18 namespace lldb_private { 19 20 // Thread Step Types 21 enum StepType { 22 eStepTypeNone, 23 eStepTypeTrace, ///< Single step one instruction. 24 eStepTypeTraceOver, ///< Single step one instruction, stepping over. 25 eStepTypeInto, ///< Single step into a specified context. 26 eStepTypeOver, ///< Single step over a specified context. 27 eStepTypeOut, ///< Single step out a specified context. 28 eStepTypeScripted ///< A step type implemented by the script interpreter. 29 }; 30 31 // Address Types 32 enum AddressType { 33 eAddressTypeInvalid = 0, 34 eAddressTypeFile, ///< Address is an address as found in an object or symbol 35 /// file 36 eAddressTypeLoad, ///< Address is an address as in the current target inferior 37 /// process 38 eAddressTypeHost ///< Address is an address in the process that is running 39 /// this code 40 }; 41 42 // Address Class 43 // 44 // A way of classifying an address used for disassembling and setting 45 // breakpoints. Many object files can track exactly what parts of their object 46 // files are code, data and other information. This is of course above and 47 // beyond just looking at the section types. For example, code might contain PC 48 // relative data and the object file might be able to tell us that an address 49 // in code is data. 50 enum class AddressClass { 51 eInvalid, 52 eUnknown, 53 eCode, 54 eCodeAlternateISA, 55 eData, 56 eDebug, 57 eRuntime 58 }; 59 60 // Votes - Need a tri-state, yes, no, no opinion... 61 enum Vote { eVoteNo = -1, eVoteNoOpinion = 0, eVoteYes = 1 }; 62 63 enum ArchitectureType { 64 eArchTypeInvalid, 65 eArchTypeMachO, 66 eArchTypeELF, 67 eArchTypeCOFF, 68 kNumArchTypes 69 }; 70 71 /// Settable state variable types. 72 /// 73 74 // typedef enum SettableVariableType 75 //{ 76 // eSetVarTypeInt, 77 // eSetVarTypeBoolean, 78 // eSetVarTypeString, 79 // eSetVarTypeArray, 80 // eSetVarTypeDictionary, 81 // eSetVarTypeEnum, 82 // eSetVarTypeNone 83 //} SettableVariableType; 84 85 enum VarSetOperationType { 86 eVarSetOperationReplace, 87 eVarSetOperationInsertBefore, 88 eVarSetOperationInsertAfter, 89 eVarSetOperationRemove, 90 eVarSetOperationAppend, 91 eVarSetOperationClear, 92 eVarSetOperationAssign, 93 eVarSetOperationInvalid 94 }; 95 96 enum ArgumentRepetitionType { 97 eArgRepeatPlain, // Exactly one occurrence 98 eArgRepeatOptional, // At most one occurrence, but it's optional 99 eArgRepeatPlus, // One or more occurrences 100 eArgRepeatStar, // Zero or more occurrences 101 eArgRepeatRange, // Repetition of same argument, from 1 to n 102 eArgRepeatPairPlain, // A pair of arguments that must always go together 103 // ([arg-type arg-value]), occurs exactly once 104 eArgRepeatPairOptional, // A pair that occurs at most once (optional) 105 eArgRepeatPairPlus, // One or more occurrences of a pair 106 eArgRepeatPairStar, // Zero or more occurrences of a pair 107 eArgRepeatPairRange, // A pair that repeats from 1 to n 108 eArgRepeatPairRangeOptional // A pair that repeats from 1 to n, but is 109 // optional 110 }; 111 112 enum SortOrder { 113 eSortOrderNone, 114 eSortOrderByAddress, 115 eSortOrderByName, 116 eSortOrderBySize 117 }; 118 119 // LazyBool is for boolean values that need to be calculated lazily. Values 120 // start off set to eLazyBoolCalculate, and then they can be calculated once 121 // and set to eLazyBoolNo or eLazyBoolYes. 122 enum LazyBool { eLazyBoolCalculate = -1, eLazyBoolNo = 0, eLazyBoolYes = 1 }; 123 124 /// Instruction types 125 enum InstructionType { 126 eInstructionTypeAny, // Support for any instructions at all (at least one) 127 eInstructionTypePrologueEpilogue, // All prologue and epilogue instructions 128 // that push and pop register values and 129 // modify sp/fp 130 eInstructionTypePCModifying, // Any instruction that modifies the program 131 // counter/instruction pointer 132 eInstructionTypeAll // All instructions of any kind 133 134 }; 135 136 /// Format category entry types 137 enum FormatCategoryItem { 138 eFormatCategoryItemSummary = 1, 139 eFormatCategoryItemFilter = 1 << 1, 140 eFormatCategoryItemSynth = 1 << 2, 141 eFormatCategoryItemFormat = 1 << 3, 142 }; 143 144 /// Expression execution policies 145 enum ExecutionPolicy { 146 eExecutionPolicyOnlyWhenNeeded, 147 eExecutionPolicyNever, 148 eExecutionPolicyAlways, 149 eExecutionPolicyTopLevel // used for top-level code 150 }; 151 152 // Synchronicity behavior of scripted commands 153 enum ScriptedCommandSynchronicity { 154 eScriptedCommandSynchronicitySynchronous, 155 eScriptedCommandSynchronicityAsynchronous, 156 eScriptedCommandSynchronicityCurrentValue // use whatever the current 157 // synchronicity is 158 }; 159 160 // Verbosity mode of "po" output 161 enum LanguageRuntimeDescriptionDisplayVerbosity { 162 eLanguageRuntimeDescriptionDisplayVerbosityCompact, // only print the 163 // description string, if 164 // any 165 eLanguageRuntimeDescriptionDisplayVerbosityFull, // print the full-blown 166 // output 167 }; 168 169 // Loading modules from memory 170 enum MemoryModuleLoadLevel { 171 eMemoryModuleLoadLevelMinimal, // Load sections only 172 eMemoryModuleLoadLevelPartial, // Load function bounds but no symbols 173 eMemoryModuleLoadLevelComplete, // Load sections and all symbols 174 }; 175 176 // Behavior on fork/vfork 177 enum FollowForkMode { 178 eFollowParent, // Follow parent process 179 eFollowChild, // Follow child process 180 }; 181 182 // Result enums for when reading multiple lines from IOHandlers 183 enum class LineStatus { 184 Success, // The line that was just edited if good and should be added to the 185 // lines 186 Status, // There is an error with the current line and it needs to be 187 // re-edited 188 // before it can be accepted 189 Done // Lines are complete 190 }; 191 192 // Boolean result of running a Type Validator 193 enum class TypeValidatorResult : bool { Success = true, Failure = false }; 194 195 // Enumerations that can be used to specify scopes types when looking up types. 196 enum class CompilerContextKind : uint16_t { 197 Invalid = 0, 198 TranslationUnit = 1, 199 Module = 1 << 1, 200 Namespace = 1 << 2, 201 ClassOrStruct = 1 << 3, 202 Union = 1 << 5, 203 Function = 1 << 6, 204 Variable = 1 << 7, 205 Enum = 1 << 8, 206 Typedef = 1 << 9, 207 Builtin = 1 << 10, 208 209 Any = 1 << 15, 210 /// Match 0..n nested modules. 211 AnyModule = Any | Module, 212 /// Match any type. 213 AnyType = Any | ClassOrStruct | Union | Enum | Typedef | Builtin, 214 /// Math any declaration context. 215 AnyDeclContext = Any | Namespace | ClassOrStruct | Union | Enum | Function, 216 LLVM_MARK_AS_BITMASK_ENUM(/*LargestValue=*/AnyDeclContext), 217 }; 218 LLVM_ENABLE_BITMASK_ENUMS_IN_NAMESPACE(); 219 220 // Enumerations that can be used to specify the kind of metric we're looking at 221 // when collecting stats. 222 enum StatisticKind { 223 ExpressionSuccessful = 0, 224 ExpressionFailure = 1, 225 FrameVarSuccess = 2, 226 FrameVarFailure = 3, 227 StatisticMax = 4 228 }; 229 230 // Enumeration that can be used to specify a log handler. 231 enum LogHandlerKind { 232 eLogHandlerStream, 233 eLogHandlerCallback, 234 eLogHandlerCircular, 235 eLogHandlerSystem, 236 eLogHandlerDefault = eLogHandlerStream, 237 }; 238 239 enum LoadDependentFiles { 240 eLoadDependentsDefault, 241 eLoadDependentsYes, 242 eLoadDependentsNo, 243 }; 244 245 /// Useful for callbacks whose return type indicates 246 /// whether to continue iteration or short-circuit. 247 enum class IterationAction { 248 Continue = 0, 249 Stop, 250 }; 251 GetStatDescription(lldb_private::StatisticKind K)252 inline std::string GetStatDescription(lldb_private::StatisticKind K) { 253 switch (K) { 254 case StatisticKind::ExpressionSuccessful: 255 return "Number of expr evaluation successes"; 256 case StatisticKind::ExpressionFailure: 257 return "Number of expr evaluation failures"; 258 case StatisticKind::FrameVarSuccess: 259 return "Number of frame var successes"; 260 case StatisticKind::FrameVarFailure: 261 return "Number of frame var failures"; 262 case StatisticKind::StatisticMax: 263 return ""; 264 } 265 llvm_unreachable("Statistic not registered!"); 266 } 267 268 } // namespace lldb_private 269 270 namespace llvm { 271 template <> struct format_provider<lldb_private::Vote> { 272 static void format(const lldb_private::Vote &V, llvm::raw_ostream &Stream, 273 StringRef Style) { 274 switch (V) { 275 case lldb_private::eVoteNo: 276 Stream << "no"; 277 return; 278 case lldb_private::eVoteNoOpinion: 279 Stream << "no opinion"; 280 return; 281 case lldb_private::eVoteYes: 282 Stream << "yes"; 283 return; 284 } 285 Stream << "invalid"; 286 } 287 }; 288 } 289 290 enum SelectMostRelevant : bool { 291 SelectMostRelevantFrame = true, 292 DoNoSelectMostRelevantFrame = false, 293 }; 294 295 enum InterruptionControl : bool { 296 AllowInterruption = true, 297 DoNotAllowInterruption = false, 298 }; 299 300 /// The hardware and native stub capabilities for a given target, 301 /// for translating a user's watchpoint request into hardware 302 /// capable watchpoint resources. 303 FLAGS_ENUM(WatchpointHardwareFeature){ 304 /// lldb will fall back to a default that assumes the target 305 /// can watch up to pointer-size power-of-2 regions, aligned to 306 /// power-of-2. 307 eWatchpointHardwareFeatureUnknown = (1u << 0), 308 309 /// Intel systems can watch 1, 2, 4, or 8 bytes (in 64-bit targets), 310 /// aligned naturally. 311 eWatchpointHardwareX86 = (1u << 1), 312 313 /// ARM systems with Byte Address Select watchpoints 314 /// can watch any consecutive series of bytes up to the 315 /// size of a pointer (4 or 8 bytes), at a pointer-size 316 /// alignment. 317 eWatchpointHardwareArmBAS = (1u << 2), 318 319 /// ARM systems with MASK watchpoints can watch any power-of-2 320 /// sized region from 8 bytes to 2 gigabytes, aligned to that 321 /// same power-of-2 alignment. 322 eWatchpointHardwareArmMASK = (1u << 3), 323 }; 324 LLDB_MARK_AS_BITMASK_ENUM(WatchpointHardwareFeature) 325 326 #endif // LLDB_LLDB_PRIVATE_ENUMERATIONS_H 327