LLDB mainline
ArchSpec.h
Go to the documentation of this file.
1//===-- ArchSpec.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_UTILITY_ARCHSPEC_H
10#define LLDB_UTILITY_ARCHSPEC_H
11
14#include "lldb/lldb-forward.h"
16#include "llvm/ADT/StringRef.h"
17#include "llvm/TargetParser/Triple.h"
18#include <cstddef>
19#include <cstdint>
20#include <string>
21
22namespace lldb_private {
23
24/// \class ArchSpec ArchSpec.h "lldb/Utility/ArchSpec.h" An architecture
25/// specification class.
26///
27/// A class designed to be created from a cpu type and subtype, a
28/// string representation, or an llvm::Triple. Keeping all of the conversions
29/// of strings to architecture enumeration values confined to this class
30/// allows new architecture support to be added easily.
31class ArchSpec {
32public:
47 };
48
49 // Masks for the ases word of an ABI flags structure.
50 enum MIPSASE {
51 eMIPSAse_dsp = 0x00000001, // DSP ASE
52 eMIPSAse_dspr2 = 0x00000002, // DSP R2 ASE
53 eMIPSAse_eva = 0x00000004, // Enhanced VA Scheme
54 eMIPSAse_mcu = 0x00000008, // MCU (MicroController) ASE
55 eMIPSAse_mdmx = 0x00000010, // MDMX ASE
56 eMIPSAse_mips3d = 0x00000020, // MIPS-3D ASE
57 eMIPSAse_mt = 0x00000040, // MT ASE
58 eMIPSAse_smartmips = 0x00000080, // SmartMIPS ASE
59 eMIPSAse_virt = 0x00000100, // VZ ASE
60 eMIPSAse_msa = 0x00000200, // MSA ASE
61 eMIPSAse_mips16 = 0x00000400, // MIPS16 ASE
62 eMIPSAse_micromips = 0x00000800, // MICROMIPS ASE
63 eMIPSAse_xpa = 0x00001000, // XPA ASE
64 eMIPSAse_mask = 0x00001fff,
65 eMIPSABI_O32 = 0x00002000,
66 eMIPSABI_N32 = 0x00004000,
67 eMIPSABI_N64 = 0x00008000,
68 eMIPSABI_O64 = 0x00020000,
69 eMIPSABI_EABI32 = 0x00040000,
70 eMIPSABI_EABI64 = 0x00080000,
71 eMIPSABI_mask = 0x000ff000
72 };
73
74 // MIPS Floating point ABI Values
76 eMIPS_ABI_FP_ANY = 0x00000000,
77 eMIPS_ABI_FP_DOUBLE = 0x00100000, // hard float / -mdouble-float
78 eMIPS_ABI_FP_SINGLE = 0x00200000, // hard float / -msingle-float
79 eMIPS_ABI_FP_SOFT = 0x00300000, // soft float
80 eMIPS_ABI_FP_OLD_64 = 0x00400000, // -mips32r2 -mfp64
81 eMIPS_ABI_FP_XX = 0x00500000, // -mfpxx
82 eMIPS_ABI_FP_64 = 0x00600000, // -mips32r2 -mfp64
83 eMIPS_ABI_FP_64A = 0x00700000, // -mips32r2 -mfp64 -mno-odd-spreg
84 eMIPS_ABI_FP_mask = 0x00700000
85 };
86
87 // ARM specific e_flags
88 enum ARMeflags {
89 eARM_abi_soft_float = 0x00000200,
90 eARM_abi_hard_float = 0x00000400
91 };
92
94 eRISCV_rvc = 0x00000001, /// RVC, +c
95 eRISCV_float_abi_soft = 0x00000000, /// soft float
96 eRISCV_float_abi_single = 0x00000002, /// single precision floating point, +f
97 eRISCV_float_abi_double = 0x00000004, /// double precision floating point, +d
98 eRISCV_float_abi_quad = 0x00000006, /// quad precision floating point, +q
100 eRISCV_rve = 0x00000008, /// RVE, +e
101 eRISCV_tso = 0x00000010, /// RVTSO (total store ordering)
102 };
103
108 };
109
111 eLoongArch_abi_soft_float = 0x00000000, /// soft float
113 0x00000001, /// single precision floating point, +f
115 0x00000002, /// double precision floating point, +d
117 };
118
123 };
124
125 enum Core {
143
163
184
186
200
204
206
208
210
215
217 eCore_x86_64_x86_64h, // Haswell enabled x86_64
221
224
227
230
231 eCore_arc, // little endian ARC
232
234
236
238
240 // The following constants are used for wildcard matching only
248
251
254
257
260
263
266
269
272
275
278
281
284
285 };
286
287 /// Default constructor.
288 ///
289 /// Default constructor that initializes the object with invalid cpu type
290 /// and subtype values.
292
293 /// Constructor over triple.
294 ///
295 /// Constructs an ArchSpec with properties consistent with the given Triple.
296 explicit ArchSpec(const llvm::Triple &triple);
297 explicit ArchSpec(const char *triple_cstr);
298 explicit ArchSpec(llvm::StringRef triple_str);
299 /// Constructor over architecture name.
300 ///
301 /// Constructs an ArchSpec with properties consistent with the given object
302 /// type and architecture name.
303 explicit ArchSpec(ArchitectureType arch_type, uint32_t cpu_type,
304 uint32_t cpu_subtype);
305
306 /// Destructor.
308
309 /// Returns true if the OS, vendor and environment fields of the triple are
310 /// unset. The triple is expected to be normalized
311 /// (llvm::Triple::normalize).
312 static bool ContainsOnlyArch(const llvm::Triple &normalized_triple);
313
314 static void ListSupportedArchNames(StringList &list);
315 static void AutoComplete(CompletionRequest &request);
316
317 /// Returns a static string representing the current architecture.
318 ///
319 /// \return A static string corresponding to the current
320 /// architecture.
321 const char *GetArchitectureName() const;
322
323 /// if MIPS architecture return true.
324 ///
325 /// \return a boolean value.
326 bool IsMIPS() const;
327
328 /// Returns a string representing current architecture as a target CPU for
329 /// tools like compiler, disassembler etc.
330 ///
331 /// \return A string representing target CPU for the current
332 /// architecture.
333 std::string GetClangTargetCPU() const;
334
335 /// Return a string representing target application ABI.
336 ///
337 /// \return A string representing target application ABI.
338 std::string GetTargetABI() const;
339
340 /// Clears the object state.
341 ///
342 /// Clears the object state back to a default invalid state.
343 void Clear();
344
345 /// Returns the size in bytes of an address of the current architecture.
346 ///
347 /// \return The byte size of an address of the current architecture.
348 uint32_t GetAddressByteSize() const;
349
350 /// Returns a machine family for the current architecture.
351 ///
352 /// \return An LLVM arch type.
353 llvm::Triple::ArchType GetMachine() const;
354
355 /// Tests if this ArchSpec is valid.
356 ///
357 /// \return True if the current architecture is valid, false
358 /// otherwise.
359 bool IsValid() const {
361 }
362 explicit operator bool() const { return IsValid(); }
363
365 return !m_triple.getVendorName().empty();
366 }
367
368 bool TripleOSWasSpecified() const { return !m_triple.getOSName().empty(); }
369
371 return m_triple.hasEnvironment();
372 }
373
374 /// Merges fields from another ArchSpec into this ArchSpec.
375 ///
376 /// This will use the supplied ArchSpec to fill in any fields of the triple
377 /// in this ArchSpec which were unspecified. This can be used to refine a
378 /// generic ArchSpec with a more specific one. For example, if this
379 /// ArchSpec's triple is something like i386-unknown-unknown-unknown, and we
380 /// have a triple which is x64-pc-windows-msvc, then merging that triple
381 /// into this one will result in the triple i386-pc-windows-msvc.
382 ///
383 void MergeFrom(const ArchSpec &other);
384
385 /// Change the architecture object type, CPU type and OS type.
386 ///
387 /// \param[in] arch_type The object type of this ArchSpec.
388 ///
389 /// \param[in] cpu The required CPU type.
390 ///
391 /// \param[in] os The optional OS type
392 /// The default value of 0 was chosen to from the ELF spec value
393 /// ELFOSABI_NONE. ELF is the only one using this parameter. If another
394 /// format uses this parameter and 0 does not work, use a value over
395 /// 255 because in the ELF header this is value is only a byte.
396 ///
397 /// \return True if the object, and CPU were successfully set.
398 ///
399 /// As a side effect, the vendor value is usually set to unknown. The
400 /// exceptions are
401 /// aarch64-apple-ios
402 /// arm-apple-ios
403 /// thumb-apple-ios
404 /// x86-apple-
405 /// x86_64-apple-
406 ///
407 /// As a side effect, the os value is usually set to unknown The exceptions
408 /// are
409 /// *-*-aix
410 /// aarch64-apple-ios
411 /// arm-apple-ios
412 /// thumb-apple-ios
413 /// powerpc-apple-darwin
414 /// *-*-freebsd
415 /// *-*-linux
416 /// *-*-netbsd
417 /// *-*-openbsd
418 /// *-*-solaris
419 bool SetArchitecture(ArchitectureType arch_type, uint32_t cpu, uint32_t sub,
420 uint32_t os = 0);
421
422 /// Returns the byte order for the architecture specification.
423 ///
424 /// \return The endian enumeration for the current endianness of
425 /// the architecture specification
427
428 /// Sets this ArchSpec's byte order.
429 ///
430 /// In the common case there is no need to call this method as the byte
431 /// order can almost always be determined by the architecture. However, many
432 /// CPU's are bi-endian (ARM, Alpha, PowerPC, etc) and the default/assumed
433 /// byte order may be incorrect.
434 void SetByteOrder(lldb::ByteOrder byte_order) { m_byte_order = byte_order; }
435
436 uint32_t GetMinimumOpcodeByteSize() const;
437
438 uint32_t GetMaximumOpcodeByteSize() const;
439
440 Core GetCore() const { return m_core; }
441
442 uint32_t GetMachOCPUType() const;
443
444 uint32_t GetMachOCPUSubType() const;
445
446 /// Architecture data byte width accessor
447 ///
448 /// \return the size in 8-bit (host) bytes of a minimum addressable unit
449 /// from the Architecture's data bus
450 uint32_t GetDataByteSize() const;
451
452 /// Architecture code byte width accessor
453 ///
454 /// \return the size in 8-bit (host) bytes of a minimum addressable unit
455 /// from the Architecture's code bus
456 uint32_t GetCodeByteSize() const;
457
458 /// Architecture triple accessor.
459 ///
460 /// \return A triple describing this ArchSpec.
461 llvm::Triple &GetTriple() { return m_triple; }
462
463 /// Architecture triple accessor.
464 ///
465 /// \return A triple describing this ArchSpec.
466 const llvm::Triple &GetTriple() const { return m_triple; }
467
468 void DumpTriple(llvm::raw_ostream &s) const;
469
470 /// Architecture triple setter.
471 ///
472 /// Configures this ArchSpec according to the given triple. If the triple
473 /// has unknown components in all of the vendor, OS, and the optional
474 /// environment field (i.e. "i386-unknown-unknown") then default values are
475 /// taken from the host. Architecture and environment components are used
476 /// to further resolve the CPU type and subtype, endian characteristics,
477 /// etc.
478 ///
479 /// \return A triple describing this ArchSpec.
480 bool SetTriple(const llvm::Triple &triple);
481
482 bool SetTriple(llvm::StringRef triple_str);
483
484 /// Returns the default endianness of the architecture.
485 ///
486 /// \return The endian enumeration for the default endianness of
487 /// the architecture.
489
490 /// Returns true if 'char' is a signed type by default in the architecture
491 /// false otherwise
492 ///
493 /// \return True if 'char' is a signed type by default on the
494 /// architecture and false otherwise.
495 bool CharIsSignedByDefault() const;
496
498
499 /// Compare this ArchSpec to another ArchSpec. \a match specifies the kind of
500 /// matching that is to be done. CompatibleMatch requires only a compatible
501 /// cpu type (e.g., armv7s is compatible with armv7). ExactMatch requires an
502 /// exact match (armv7s is not an exact match with armv7).
503 ///
504 /// \return true if the two ArchSpecs match.
505 bool IsMatch(const ArchSpec &rhs, MatchType match) const;
506
507 /// Shorthand for IsMatch(rhs, ExactMatch).
508 bool IsExactMatch(const ArchSpec &rhs) const {
509 return IsMatch(rhs, ExactMatch);
510 }
511
512 /// Shorthand for IsMatch(rhs, CompatibleMatch).
513 bool IsCompatibleMatch(const ArchSpec &rhs) const {
514 return IsMatch(rhs, CompatibleMatch);
515 }
516
517 bool IsFullySpecifiedTriple() const;
518
519 /// Detect whether this architecture uses thumb code exclusively
520 ///
521 /// Some embedded ARM chips (e.g. the ARM Cortex M0-7 line) can only execute
522 /// the Thumb instructions, never Arm. We should normally pick up
523 /// arm/thumbness from their the processor status bits (cpsr/xpsr) or hints
524 /// on each function - but when doing bare-boards low level debugging
525 /// (especially common with these embedded processors), we may not have
526 /// those things easily accessible.
527 ///
528 /// \return true if this is an arm ArchSpec which can only execute Thumb
529 /// instructions
530 bool IsAlwaysThumbInstructions() const;
531
532 uint32_t GetFlags() const { return m_flags; }
533
534 void SetFlags(uint32_t flags) { m_flags = flags; }
535
536 void SetFlags(const std::string &elf_abi);
537
538protected:
539 void UpdateCore();
540
541 llvm::Triple m_triple;
544
545 // Additional arch flags which we cannot get from triple and core For MIPS
546 // these are application specific extensions like micromips, mips16 etc.
547 uint32_t m_flags = 0;
548
549 // Called when m_def or m_entry are changed. Fills in all remaining members
550 // with default values.
551 void CoreUpdated(bool update_triple);
552};
553
554/// \fn bool operator< (const ArchSpec& lhs, const ArchSpec& rhs) Less than
555/// operator.
556///
557/// Tests two ArchSpec objects to see if \a lhs is less than \a rhs.
558///
559/// \param[in] lhs The Left Hand Side ArchSpec object to compare. \param[in]
560/// rhs The Left Hand Side ArchSpec object to compare.
561///
562/// \return true if \a lhs is less than \a rhs
563bool operator<(const ArchSpec &lhs, const ArchSpec &rhs);
564bool operator==(const ArchSpec &lhs, const ArchSpec &rhs);
565
566bool ParseMachCPUDashSubtypeTriple(llvm::StringRef triple_str, ArchSpec &arch);
567
568} // namespace lldb_private
569
570#endif // LLDB_UTILITY_ARCHSPEC_H
An architecture specification class.
Definition: ArchSpec.h:31
static void ListSupportedArchNames(StringList &list)
Definition: ArchSpec.cpp:272
bool IsFullySpecifiedTriple() const
Definition: ArchSpec.cpp:1430
void SetByteOrder(lldb::ByteOrder byte_order)
Sets this ArchSpec's byte order.
Definition: ArchSpec.h:434
static void AutoComplete(CompletionRequest &request)
Definition: ArchSpec.cpp:277
uint32_t GetAddressByteSize() const
Returns the size in bytes of an address of the current architecture.
Definition: ArchSpec.cpp:709
uint32_t GetCodeByteSize() const
Architecture code byte width accessor.
Definition: ArchSpec.cpp:697
bool IsValid() const
Tests if this ArchSpec is valid.
Definition: ArchSpec.h:359
void Clear()
Clears the object state.
Definition: ArchSpec.cpp:560
llvm::Triple & GetTriple()
Architecture triple accessor.
Definition: ArchSpec.h:461
void SetFlags(uint32_t flags)
Definition: ArchSpec.h:534
bool IsAlwaysThumbInstructions() const
Detect whether this architecture uses thumb code exclusively.
Definition: ArchSpec.cpp:1445
bool TripleEnvironmentWasSpecified() const
Definition: ArchSpec.h:370
bool IsMatch(const ArchSpec &rhs, MatchType match) const
Compare this ArchSpec to another ArchSpec.
Definition: ArchSpec.cpp:993
bool SetTriple(const llvm::Triple &triple)
Architecture triple setter.
Definition: ArchSpec.cpp:765
llvm::Triple m_triple
Definition: ArchSpec.h:541
lldb::ByteOrder GetDefaultEndian() const
Returns the default endianness of the architecture.
Definition: ArchSpec.cpp:723
lldb::ByteOrder m_byte_order
Definition: ArchSpec.h:543
~ArchSpec()
Destructor.
bool SetArchitecture(ArchitectureType arch_type, uint32_t cpu, uint32_t sub, uint32_t os=0)
Change the architecture object type, CPU type and OS type.
Definition: ArchSpec.cpp:869
void MergeFrom(const ArchSpec &other)
Merges fields from another ArchSpec into this ArchSpec.
Definition: ArchSpec.cpp:827
void DumpTriple(llvm::raw_ostream &s) const
Definition: ArchSpec.cpp:1472
uint32_t GetMachOCPUSubType() const
Definition: ArchSpec.cpp:681
void CoreUpdated(bool update_triple)
Definition: ArchSpec.cpp:1087
@ eLoongArch_abi_single_float
soft float
Definition: ArchSpec.h:112
@ eLoongArch_abi_mask
double precision floating point, +d
Definition: ArchSpec.h:116
@ eLoongArch_abi_double_float
single precision floating point, +f
Definition: ArchSpec.h:114
bool IsMIPS() const
if MIPS architecture return true.
Definition: ArchSpec.cpp:577
uint32_t GetDataByteSize() const
Architecture data byte width accessor.
Definition: ArchSpec.cpp:693
bool IsCompatibleMatch(const ArchSpec &rhs) const
Shorthand for IsMatch(rhs, CompatibleMatch).
Definition: ArchSpec.h:513
bool CharIsSignedByDefault() const
Returns true if 'char' is a signed type by default in the architecture false otherwise.
Definition: ArchSpec.cpp:730
bool IsExactMatch(const ArchSpec &rhs) const
Shorthand for IsMatch(rhs, ExactMatch).
Definition: ArchSpec.h:508
ArchSpec()
Default constructor.
uint32_t GetMachOCPUType() const
Definition: ArchSpec.cpp:669
std::string GetTargetABI() const
Return a string representing target application ABI.
Definition: ArchSpec.cpp:579
uint32_t GetMinimumOpcodeByteSize() const
Definition: ArchSpec.cpp:948
uint32_t GetFlags() const
Definition: ArchSpec.h:532
lldb::ByteOrder GetByteOrder() const
Returns the byte order for the architecture specification.
Definition: ArchSpec.cpp:756
llvm::Triple::ArchType GetMachine() const
Returns a machine family for the current architecture.
Definition: ArchSpec.cpp:701
@ eRISCV_tso
RVE, +e.
Definition: ArchSpec.h:101
@ eRISCV_float_abi_double
single precision floating point, +f
Definition: ArchSpec.h:97
@ eRISCV_float_abi_soft
RVC, +c.
Definition: ArchSpec.h:95
@ eRISCV_float_abi_quad
double precision floating point, +d
Definition: ArchSpec.h:98
@ eRISCV_float_abi_mask
quad precision floating point, +q
Definition: ArchSpec.h:99
@ eRISCV_float_abi_single
soft float
Definition: ArchSpec.h:96
std::string GetClangTargetCPU() const
Returns a string representing current architecture as a target CPU for tools like compiler,...
Definition: ArchSpec.cpp:615
uint32_t GetMaximumOpcodeByteSize() const
Definition: ArchSpec.cpp:955
bool TripleVendorWasSpecified() const
Definition: ArchSpec.h:364
Core GetCore() const
Definition: ArchSpec.h:440
bool TripleOSWasSpecified() const
Definition: ArchSpec.h:368
static bool ContainsOnlyArch(const llvm::Triple &normalized_triple)
Returns true if the OS, vendor and environment fields of the triple are unset.
Definition: ArchSpec.cpp:820
const llvm::Triple & GetTriple() const
Architecture triple accessor.
Definition: ArchSpec.h:466
const char * GetArchitectureName() const
Returns a static string representing the current architecture.
Definition: ArchSpec.cpp:570
"lldb/Utility/ArgCompletionRequest.h"
A class that represents a running process on the host machine.
bool ParseMachCPUDashSubtypeTriple(llvm::StringRef triple_str, ArchSpec &arch)
Definition: ArchSpec.cpp:771
bool operator==(const Address &lhs, const Address &rhs)
Definition: Address.cpp:1023
bool operator<(const Address &lhs, const Address &rhs)
Definition: Address.cpp:992
ByteOrder
Byte ordering definitions.
@ eByteOrderInvalid