1 | //===- Architecture.cpp ---------------------------------------------------===// |
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 | // Implements the architecture helper functions. |
10 | // |
11 | //===----------------------------------------------------------------------===// |
12 | |
13 | #include "llvm/TextAPI/Architecture.h" |
14 | #include "llvm/ADT/StringSwitch.h" |
15 | #include "llvm/BinaryFormat/MachO.h" |
16 | #include "llvm/Support/ErrorHandling.h" |
17 | #include "llvm/Support/raw_ostream.h" |
18 | #include "llvm/TargetParser/Triple.h" |
19 | |
20 | namespace llvm { |
21 | namespace MachO { |
22 | |
23 | Architecture getArchitectureFromCpuType(uint32_t CPUType, uint32_t CPUSubType) { |
24 | #define ARCHINFO(Arch, Type, Subtype, NumBits) \ |
25 | if (CPUType == (Type) && \ |
26 | (CPUSubType & ~MachO::CPU_SUBTYPE_MASK) == (Subtype)) \ |
27 | return AK_##Arch; |
28 | #include "llvm/TextAPI/Architecture.def" |
29 | #undef ARCHINFO |
30 | |
31 | return AK_unknown; |
32 | } |
33 | |
34 | Architecture getArchitectureFromName(StringRef Name) { |
35 | return StringSwitch<Architecture>(Name) |
36 | #define ARCHINFO(Arch, Type, Subtype, NumBits) .Case(#Arch, AK_##Arch) |
37 | #include "llvm/TextAPI/Architecture.def" |
38 | #undef ARCHINFO |
39 | .Default(Value: AK_unknown); |
40 | } |
41 | |
42 | StringRef getArchitectureName(Architecture Arch) { |
43 | switch (Arch) { |
44 | #define ARCHINFO(Arch, Type, Subtype, NumBits) \ |
45 | case AK_##Arch: \ |
46 | return #Arch; |
47 | #include "llvm/TextAPI/Architecture.def" |
48 | #undef ARCHINFO |
49 | case AK_unknown: |
50 | return "unknown" ; |
51 | } |
52 | |
53 | // Appease some compilers that cannot figure out that this is a fully covered |
54 | // switch statement. |
55 | return "unknown" ; |
56 | } |
57 | |
58 | std::pair<uint32_t, uint32_t> getCPUTypeFromArchitecture(Architecture Arch) { |
59 | switch (Arch) { |
60 | #define ARCHINFO(Arch, Type, Subtype, NumBits) \ |
61 | case AK_##Arch: \ |
62 | return std::make_pair(Type, Subtype); |
63 | #include "llvm/TextAPI/Architecture.def" |
64 | #undef ARCHINFO |
65 | case AK_unknown: |
66 | return std::make_pair(x: 0, y: 0); |
67 | } |
68 | |
69 | // Appease some compilers that cannot figure out that this is a fully covered |
70 | // switch statement. |
71 | return std::make_pair(x: 0, y: 0); |
72 | } |
73 | |
74 | Architecture mapToArchitecture(const Triple &Target) { |
75 | return getArchitectureFromName(Name: Target.getArchName()); |
76 | } |
77 | |
78 | bool is64Bit(Architecture Arch) { |
79 | switch (Arch) { |
80 | #define ARCHINFO(Arch, Type, Subtype, NumBits) \ |
81 | case AK_##Arch: \ |
82 | return NumBits == 64; |
83 | #include "llvm/TextAPI/Architecture.def" |
84 | #undef ARCHINFO |
85 | case AK_unknown: |
86 | return false; |
87 | } |
88 | |
89 | llvm_unreachable("Fully handled switch case above." ); |
90 | } |
91 | |
92 | raw_ostream &operator<<(raw_ostream &OS, Architecture Arch) { |
93 | OS << getArchitectureName(Arch); |
94 | return OS; |
95 | } |
96 | |
97 | } // end namespace MachO. |
98 | } // end namespace llvm. |
99 | |