1 //===-- ArchSpec.h ----------------------------------------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 #ifndef LLDB_UTILITY_ARCHSPEC_H
10 #define LLDB_UTILITY_ARCHSPEC_H
12 #include "lldb/Utility/CompletionRequest.h"
13 #include "lldb/Utility/ConstString.h"
14 #include "lldb/lldb-enumerations.h"
15 #include "lldb/lldb-forward.h"
16 #include "lldb/lldb-private-enumerations.h"
17 #include "llvm/ADT/StringRef.h"
18 #include "llvm/ADT/Triple.h"
23 namespace lldb_private {
25 /// \class ArchSpec ArchSpec.h "lldb/Utility/ArchSpec.h" An architecture
26 /// specification class.
28 /// A class designed to be created from a cpu type and subtype, a
29 /// string representation, or an llvm::Triple. Keeping all of the conversions
30 /// of strings to architecture enumeration values confined to this class
31 /// allows new architecture support to be added easily.
37 eMIPSSubType_mips32r2,
38 eMIPSSubType_mips32r6,
39 eMIPSSubType_mips32el,
40 eMIPSSubType_mips32r2el,
41 eMIPSSubType_mips32r6el,
43 eMIPSSubType_mips64r2,
44 eMIPSSubType_mips64r6,
45 eMIPSSubType_mips64el,
46 eMIPSSubType_mips64r2el,
47 eMIPSSubType_mips64r6el,
50 // Masks for the ases word of an ABI flags structure.
52 eMIPSAse_dsp = 0x00000001, // DSP ASE
53 eMIPSAse_dspr2 = 0x00000002, // DSP R2 ASE
54 eMIPSAse_eva = 0x00000004, // Enhanced VA Scheme
55 eMIPSAse_mcu = 0x00000008, // MCU (MicroController) ASE
56 eMIPSAse_mdmx = 0x00000010, // MDMX ASE
57 eMIPSAse_mips3d = 0x00000020, // MIPS-3D ASE
58 eMIPSAse_mt = 0x00000040, // MT ASE
59 eMIPSAse_smartmips = 0x00000080, // SmartMIPS ASE
60 eMIPSAse_virt = 0x00000100, // VZ ASE
61 eMIPSAse_msa = 0x00000200, // MSA ASE
62 eMIPSAse_mips16 = 0x00000400, // MIPS16 ASE
63 eMIPSAse_micromips = 0x00000800, // MICROMIPS ASE
64 eMIPSAse_xpa = 0x00001000, // XPA ASE
65 eMIPSAse_mask = 0x00001fff,
66 eMIPSABI_O32 = 0x00002000,
67 eMIPSABI_N32 = 0x00004000,
68 eMIPSABI_N64 = 0x00008000,
69 eMIPSABI_O64 = 0x00020000,
70 eMIPSABI_EABI32 = 0x00040000,
71 eMIPSABI_EABI64 = 0x00080000,
72 eMIPSABI_mask = 0x000ff000
75 // MIPS Floating point ABI Values
77 eMIPS_ABI_FP_ANY = 0x00000000,
78 eMIPS_ABI_FP_DOUBLE = 0x00100000, // hard float / -mdouble-float
79 eMIPS_ABI_FP_SINGLE = 0x00200000, // hard float / -msingle-float
80 eMIPS_ABI_FP_SOFT = 0x00300000, // soft float
81 eMIPS_ABI_FP_OLD_64 = 0x00400000, // -mips32r2 -mfp64
82 eMIPS_ABI_FP_XX = 0x00500000, // -mfpxx
83 eMIPS_ABI_FP_64 = 0x00600000, // -mips32r2 -mfp64
84 eMIPS_ABI_FP_64A = 0x00700000, // -mips32r2 -mfp64 -mno-odd-spreg
85 eMIPS_ABI_FP_mask = 0x00700000
88 // ARM specific e_flags
90 eARM_abi_soft_float = 0x00000200,
91 eARM_abi_hard_float = 0x00000400
162 eCore_ppc64le_generic,
164 eCore_ppc64_ppc970_64,
170 eCore_sparc9_generic,
178 eCore_x86_64_x86_64h, // Haswell enabled x86_64
179 eCore_hexagon_generic,
180 eCore_hexagon_hexagonv4,
181 eCore_hexagon_hexagonv5,
189 // The following constants are used for wildcard matching only
198 kCore_arm_first = eCore_arm_generic,
199 kCore_arm_last = eCore_arm_xscale,
201 kCore_thumb_first = eCore_thumb,
202 kCore_thumb_last = eCore_thumbv7em,
204 kCore_ppc_first = eCore_ppc_generic,
205 kCore_ppc_last = eCore_ppc_ppc970,
207 kCore_ppc64_first = eCore_ppc64_generic,
208 kCore_ppc64_last = eCore_ppc64_ppc970_64,
210 kCore_x86_32_first = eCore_x86_32_i386,
211 kCore_x86_32_last = eCore_x86_32_i686,
213 kCore_x86_64_first = eCore_x86_64_x86_64,
214 kCore_x86_64_last = eCore_x86_64_x86_64h,
216 kCore_hexagon_first = eCore_hexagon_generic,
217 kCore_hexagon_last = eCore_hexagon_hexagonv5,
219 kCore_mips32_first = eCore_mips32,
220 kCore_mips32_last = eCore_mips32r6,
222 kCore_mips32el_first = eCore_mips32el,
223 kCore_mips32el_last = eCore_mips32r6el,
225 kCore_mips64_first = eCore_mips64,
226 kCore_mips64_last = eCore_mips64r6,
228 kCore_mips64el_first = eCore_mips64el,
229 kCore_mips64el_last = eCore_mips64r6el,
231 kCore_mips_first = eCore_mips32,
232 kCore_mips_last = eCore_mips64r6el
236 /// Default constructor.
238 /// Default constructor that initializes the object with invalid cpu type
239 /// and subtype values.
242 /// Constructor over triple.
244 /// Constructs an ArchSpec with properties consistent with the given Triple.
245 explicit ArchSpec(const llvm::Triple &triple);
246 explicit ArchSpec(const char *triple_cstr);
247 explicit ArchSpec(llvm::StringRef triple_str);
248 /// Constructor over architecture name.
250 /// Constructs an ArchSpec with properties consistent with the given object
251 /// type and architecture name.
252 explicit ArchSpec(ArchitectureType arch_type, uint32_t cpu_type,
253 uint32_t cpu_subtype);
258 /// Assignment operator.
260 /// \param[in] rhs another ArchSpec object to copy.
262 /// \return A const reference to this object.
263 const ArchSpec &operator=(const ArchSpec &rhs);
265 /// Returns true if the OS, vendor and environment fields of the triple are
266 /// unset. The triple is expected to be normalized
267 /// (llvm::Triple::normalize).
268 static bool ContainsOnlyArch(const llvm::Triple &normalized_triple);
270 static void ListSupportedArchNames(StringList &list);
271 static size_t AutoComplete(CompletionRequest &request);
273 /// Returns a static string representing the current architecture.
275 /// \return A static string corresponding to the current
277 const char *GetArchitectureName() const;
279 /// if MIPS architecture return true.
281 /// \return a boolean value.
284 /// Returns a string representing current architecture as a target CPU for
285 /// tools like compiler, disassembler etc.
287 /// \return A string representing target CPU for the current
289 std::string GetClangTargetCPU() const;
291 /// Return a string representing target application ABI.
293 /// \return A string representing target application ABI.
294 std::string GetTargetABI() const;
296 /// Clears the object state.
298 /// Clears the object state back to a default invalid state.
301 /// Returns the size in bytes of an address of the current architecture.
303 /// \return The byte size of an address of the current architecture.
304 uint32_t GetAddressByteSize() const;
306 /// Returns a machine family for the current architecture.
308 /// \return An LLVM arch type.
309 llvm::Triple::ArchType GetMachine() const;
311 /// Returns the distribution id of the architecture.
313 /// This will be something like "ubuntu", "fedora", etc. on Linux.
315 /// \return A ConstString ref containing the distribution id,
316 /// potentially empty.
317 ConstString GetDistributionId() const;
319 /// Set the distribution id of the architecture.
321 /// This will be something like "ubuntu", "fedora", etc. on Linux. This
322 /// should be the same value returned by HostInfo::GetDistributionId ().
323 void SetDistributionId(const char *distribution_id);
325 /// Tests if this ArchSpec is valid.
327 /// \return True if the current architecture is valid, false
329 bool IsValid() const {
330 return m_core >= eCore_arm_generic && m_core < kNumCores;
332 explicit operator bool() const { return IsValid(); }
334 bool TripleVendorWasSpecified() const {
335 return !m_triple.getVendorName().empty();
338 bool TripleOSWasSpecified() const { return !m_triple.getOSName().empty(); }
340 bool TripleEnvironmentWasSpecified() const {
341 return m_triple.hasEnvironment();
344 /// Merges fields from another ArchSpec into this ArchSpec.
346 /// This will use the supplied ArchSpec to fill in any fields of the triple
347 /// in this ArchSpec which were unspecified. This can be used to refine a
348 /// generic ArchSpec with a more specific one. For example, if this
349 /// ArchSpec's triple is something like i386-unknown-unknown-unknown, and we
350 /// have a triple which is x64-pc-windows-msvc, then merging that triple
351 /// into this one will result in the triple i386-pc-windows-msvc.
353 void MergeFrom(const ArchSpec &other);
355 /// Change the architecture object type, CPU type and OS type.
357 /// \param[in] arch_type The object type of this ArchSpec.
359 /// \param[in] cpu The required CPU type.
361 /// \param[in] os The optional OS type
362 /// The default value of 0 was chosen to from the ELF spec value
363 /// ELFOSABI_NONE. ELF is the only one using this parameter. If another
364 /// format uses this parameter and 0 does not work, use a value over
365 /// 255 because in the ELF header this is value is only a byte.
367 /// \return True if the object, and CPU were successfully set.
369 /// As a side effect, the vendor value is usually set to unknown. The
371 /// aarch64-apple-ios
377 /// As a side effect, the os value is usually set to unknown The exceptions
380 /// aarch64-apple-ios
383 /// powerpc-apple-darwin
389 bool SetArchitecture(ArchitectureType arch_type, uint32_t cpu, uint32_t sub,
392 /// Returns the byte order for the architecture specification.
394 /// \return The endian enumeration for the current endianness of
395 /// the architecture specification
396 lldb::ByteOrder GetByteOrder() const;
398 /// Sets this ArchSpec's byte order.
400 /// In the common case there is no need to call this method as the byte
401 /// order can almost always be determined by the architecture. However, many
402 /// CPU's are bi-endian (ARM, Alpha, PowerPC, etc) and the default/assumed
403 /// byte order may be incorrect.
404 void SetByteOrder(lldb::ByteOrder byte_order) { m_byte_order = byte_order; }
406 uint32_t GetMinimumOpcodeByteSize() const;
408 uint32_t GetMaximumOpcodeByteSize() const;
410 Core GetCore() const { return m_core; }
412 uint32_t GetMachOCPUType() const;
414 uint32_t GetMachOCPUSubType() const;
416 /// Architecture data byte width accessor
418 /// \return the size in 8-bit (host) bytes of a minimum addressable unit
419 /// from the Architecture's data bus
420 uint32_t GetDataByteSize() const;
422 /// Architecture code byte width accessor
424 /// \return the size in 8-bit (host) bytes of a minimum addressable unit
425 /// from the Architecture's code bus
426 uint32_t GetCodeByteSize() const;
428 /// Architecture triple accessor.
430 /// \return A triple describing this ArchSpec.
431 llvm::Triple &GetTriple() { return m_triple; }
433 /// Architecture triple accessor.
435 /// \return A triple describing this ArchSpec.
436 const llvm::Triple &GetTriple() const { return m_triple; }
438 void DumpTriple(Stream &s) const;
440 /// Architecture triple setter.
442 /// Configures this ArchSpec according to the given triple. If the triple
443 /// has unknown components in all of the vendor, OS, and the optional
444 /// environment field (i.e. "i386-unknown-unknown") then default values are
445 /// taken from the host. Architecture and environment components are used
446 /// to further resolve the CPU type and subtype, endian characteristics,
449 /// \return A triple describing this ArchSpec.
450 bool SetTriple(const llvm::Triple &triple);
452 bool SetTriple(llvm::StringRef triple_str);
454 /// Returns the default endianness of the architecture.
456 /// \return The endian enumeration for the default endianness of
457 /// the architecture.
458 lldb::ByteOrder GetDefaultEndian() const;
460 /// Returns true if 'char' is a signed type by default in the architecture
463 /// \return True if 'char' is a signed type by default on the
464 /// architecture and false otherwise.
465 bool CharIsSignedByDefault() const;
467 /// Compare an ArchSpec to another ArchSpec, requiring an exact cpu type
468 /// match between them. e.g. armv7s is not an exact match with armv7 - this
469 /// would return false
471 /// \return true if the two ArchSpecs match.
472 bool IsExactMatch(const ArchSpec &rhs) const;
474 /// Compare an ArchSpec to another ArchSpec, requiring a compatible cpu type
475 /// match between them. e.g. armv7s is compatible with armv7 - this method
476 /// would return true
478 /// \return true if the two ArchSpecs are compatible
479 bool IsCompatibleMatch(const ArchSpec &rhs) const;
481 bool IsFullySpecifiedTriple() const;
483 void PiecewiseTripleCompare(const ArchSpec &other, bool &arch_different,
484 bool &vendor_different, bool &os_different,
485 bool &os_version_different,
486 bool &env_different) const;
488 /// Detect whether this architecture uses thumb code exclusively
490 /// Some embedded ARM chips (e.g. the ARM Cortex M0-7 line) can only execute
491 /// the Thumb instructions, never Arm. We should normally pick up
492 /// arm/thumbness from their the processor status bits (cpsr/xpsr) or hints
493 /// on each function - but when doing bare-boards low level debugging
494 /// (especially common with these embedded processors), we may not have
495 /// those things easily accessible.
497 /// \return true if this is an arm ArchSpec which can only execute Thumb
499 bool IsAlwaysThumbInstructions() const;
501 uint32_t GetFlags() const { return m_flags; }
503 void SetFlags(uint32_t flags) { m_flags = flags; }
505 void SetFlags(std::string elf_abi);
508 bool IsEqualTo(const ArchSpec &rhs, bool exact_match) const;
511 llvm::Triple m_triple;
512 Core m_core = kCore_invalid;
513 lldb::ByteOrder m_byte_order = lldb::eByteOrderInvalid;
515 // Additional arch flags which we cannot get from triple and core For MIPS
516 // these are application specific extensions like micromips, mips16 etc.
517 uint32_t m_flags = 0;
519 ConstString m_distribution_id;
521 // Called when m_def or m_entry are changed. Fills in all remaining members
522 // with default values.
523 void CoreUpdated(bool update_triple);
526 /// \fn bool operator< (const ArchSpec& lhs, const ArchSpec& rhs) Less than
529 /// Tests two ArchSpec objects to see if \a lhs is less than \a rhs.
531 /// \param[in] lhs The Left Hand Side ArchSpec object to compare. \param[in]
532 /// rhs The Left Hand Side ArchSpec object to compare.
534 /// \return true if \a lhs is less than \a rhs
535 bool operator<(const ArchSpec &lhs, const ArchSpec &rhs);
536 bool operator==(const ArchSpec &lhs, const ArchSpec &rhs);
538 bool ParseMachCPUDashSubtypeTriple(llvm::StringRef triple_str, ArchSpec &arch);
540 } // namespace lldb_private
542 #endif // #ifndef LLDB_UTILITY_ARCHSPEC_H