From 0b57cec536236d46e3dba9bd041533462f33dbb7 Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Fri, 20 Dec 2019 19:53:05 +0000 Subject: Move all sources from the llvm project into contrib/llvm-project. This uses the new layout of the upstream repository, which was recently migrated to GitHub, and converted into a "monorepo". That is, most of the earlier separate sub-projects with their own branches and tags were consolidated into one top-level directory, and are now branched and tagged together. Updating the vendor area to match this layout is next. --- .../llvm/lib/TextAPI/MachO/Architecture.cpp | 77 ++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 contrib/llvm-project/llvm/lib/TextAPI/MachO/Architecture.cpp (limited to 'contrib/llvm-project/llvm/lib/TextAPI/MachO/Architecture.cpp') diff --git a/contrib/llvm-project/llvm/lib/TextAPI/MachO/Architecture.cpp b/contrib/llvm-project/llvm/lib/TextAPI/MachO/Architecture.cpp new file mode 100644 index 000000000000..a66a982fa153 --- /dev/null +++ b/contrib/llvm-project/llvm/lib/TextAPI/MachO/Architecture.cpp @@ -0,0 +1,77 @@ +//===- Architecture.cpp ---------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// +// +// Implements the architecture helper functions. +// +//===----------------------------------------------------------------------===// + +#include "llvm/TextAPI/MachO/Architecture.h" +#include "llvm/ADT/StringSwitch.h" +#include "llvm/BinaryFormat/MachO.h" + +namespace llvm { +namespace MachO { + +Architecture getArchitectureFromCpuType(uint32_t CPUType, uint32_t CPUSubType) { +#define ARCHINFO(Arch, Type, Subtype) \ + if (CPUType == (Type) && \ + (CPUSubType & ~MachO::CPU_SUBTYPE_MASK) == (Subtype)) \ + return AK_##Arch; +#include "llvm/TextAPI/MachO/Architecture.def" +#undef ARCHINFO + + return AK_unknown; +} + +Architecture getArchitectureFromName(StringRef Name) { + return StringSwitch(Name) +#define ARCHINFO(Arch, Type, Subtype) .Case(#Arch, AK_##Arch) +#include "llvm/TextAPI/MachO/Architecture.def" +#undef ARCHINFO + .Default(AK_unknown); +} + +StringRef getArchitectureName(Architecture Arch) { + switch (Arch) { +#define ARCHINFO(Arch, Type, Subtype) \ + case AK_##Arch: \ + return #Arch; +#include "llvm/TextAPI/MachO/Architecture.def" +#undef ARCHINFO + case AK_unknown: + return "unknown"; + } + + // Appease some compilers that cannot figure out that this is a fully covered + // switch statement. + return "unknown"; +} + +std::pair getCPUTypeFromArchitecture(Architecture Arch) { + switch (Arch) { +#define ARCHINFO(Arch, Type, Subtype) \ + case AK_##Arch: \ + return std::make_pair(Type, Subtype); +#include "llvm/TextAPI/MachO/Architecture.def" +#undef ARCHINFO + case AK_unknown: + return std::make_pair(0, 0); + } + + // Appease some compilers that cannot figure out that this is a fully covered + // switch statement. + return std::make_pair(0, 0); +} + +raw_ostream &operator<<(raw_ostream &OS, Architecture Arch) { + OS << getArchitectureName(Arch); + return OS; +} + +} // end namespace MachO. +} // end namespace llvm. -- cgit v1.2.3