Skip to content

Commit 7b0a568

Browse files
committed
[MachO] Add cpu(sub)type tests and improve error handling
Add checks for triples that don't use mach-o, and unit tests for everything.
1 parent 00570c2 commit 7b0a568

File tree

2 files changed

+88
-4
lines changed

2 files changed

+88
-4
lines changed

llvm/lib/BinaryFormat/MachO.cpp

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -68,7 +68,15 @@ static MachO::CPUSubTypePowerPC getPowerPCSubType(const Triple &T) {
6868
return MachO::CPU_SUBTYPE_POWERPC_ALL;
6969
}
7070

71+
static Error unsupported(const char *Str, const Triple &T) {
72+
return createStringError(std::errc::invalid_argument,
73+
"Unsupported triple for mach-o cpu %s: %s", Str,
74+
T.str().c_str());
75+
}
76+
7177
Expected<uint32_t> MachO::getCPUType(const Triple &T) {
78+
if (!T.isOSBinFormatMachO())
79+
return unsupported("type", T);
7280
if (T.isX86() && T.isArch32Bit())
7381
return MachO::CPU_TYPE_X86;
7482
if (T.isX86() && T.isArch64Bit())
@@ -83,11 +91,12 @@ Expected<uint32_t> MachO::getCPUType(const Triple &T) {
8391
return MachO::CPU_TYPE_POWERPC;
8492
if (T.getArch() == Triple::ppc64)
8593
return MachO::CPU_TYPE_POWERPC64;
86-
return createStringError(std::errc::invalid_argument,
87-
"Unsupported triple for mach-o cpu type.");
94+
return unsupported("type", T);
8895
}
8996

9097
Expected<uint32_t> MachO::getCPUSubType(const Triple &T) {
98+
if (!T.isOSBinFormatMachO())
99+
return unsupported("subtype", T);
91100
if (T.isX86())
92101
return getX86SubType(T);
93102
if (T.isARM() || T.isThumb())
@@ -96,6 +105,5 @@ Expected<uint32_t> MachO::getCPUSubType(const Triple &T) {
96105
return getARM64SubType(T);
97106
if (T.getArch() == Triple::ppc || T.getArch() == Triple::ppc64)
98107
return getPowerPCSubType(T);
99-
return createStringError(std::errc::invalid_argument,
100-
"Unsupported triple for mach-o cpu subtype.");
108+
return unsupported("subtype", T);
101109
}

llvm/unittests/BinaryFormat/MachOTest.cpp

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
//===----------------------------------------------------------------------===//
88

99
#include "llvm/BinaryFormat/MachO.h"
10+
#include "llvm/ADT/Triple.h"
1011
#include "gtest/gtest.h"
1112

1213
using namespace llvm;
@@ -44,3 +45,78 @@ TEST(MachOTest, UnalignedLC) {
4445
Current += LC->load_command_data.cmdsize;
4546
}
4647
}
48+
49+
TEST(MachOTest, CPUType) {
50+
#define CHECK_CPUTYPE(StrTriple, ExpectedCPUType) \
51+
ASSERT_EQ((MachO::CPUType)cantFail(MachO::getCPUType(Triple(StrTriple))), \
52+
(ExpectedCPUType))
53+
CHECK_CPUTYPE("x86_64-apple-darwin", MachO::CPU_TYPE_X86_64);
54+
CHECK_CPUTYPE("x86_64h-apple-darwin", MachO::CPU_TYPE_X86_64);
55+
CHECK_CPUTYPE("i386-apple-darwin", MachO::CPU_TYPE_X86);
56+
CHECK_CPUTYPE("armv7-apple-darwin", MachO::CPU_TYPE_ARM);
57+
CHECK_CPUTYPE("thumbv7-apple-darwin", MachO::CPU_TYPE_ARM);
58+
CHECK_CPUTYPE("arm64-apple-darwin", MachO::CPU_TYPE_ARM64);
59+
CHECK_CPUTYPE("arm64e-apple-darwin", MachO::CPU_TYPE_ARM64);
60+
CHECK_CPUTYPE("arm64_32-apple-darwin", MachO::CPU_TYPE_ARM64_32);
61+
CHECK_CPUTYPE("powerpc-apple-darwin", MachO::CPU_TYPE_POWERPC);
62+
CHECK_CPUTYPE("powerpc64-apple-darwin", MachO::CPU_TYPE_POWERPC64);
63+
64+
{
65+
// Not a mach-o.
66+
Expected<uint32_t> Type = MachO::getCPUType(Triple("x86_64-linux-unknown"));
67+
ASSERT_EQ(toString(Type.takeError()),
68+
"Unsupported triple for mach-o cpu type: x86_64-linux-unknown");
69+
}
70+
{
71+
// Not a valid mach-o architecture.
72+
Expected<uint32_t> Type = MachO::getCPUType(Triple("mips-apple-darwin"));
73+
ASSERT_EQ(toString(Type.takeError()),
74+
"Unsupported triple for mach-o cpu type: mips-apple-darwin");
75+
}
76+
#undef CHECK_CPUTYPE
77+
}
78+
79+
TEST(MachOTest, CPUSubType) {
80+
#define CHECK_CPUSUBTYPE(StrTriple, ExpectedCPUSubType) \
81+
ASSERT_EQ(cantFail(MachO::getCPUSubType(Triple(StrTriple))), \
82+
((uint32_t)ExpectedCPUSubType))
83+
CHECK_CPUSUBTYPE("x86_64-apple-darwin", MachO::CPU_SUBTYPE_X86_64_ALL);
84+
CHECK_CPUSUBTYPE("x86_64h-apple-darwin", MachO::CPU_SUBTYPE_X86_64_H);
85+
CHECK_CPUSUBTYPE("i386-apple-darwin", MachO::CPU_SUBTYPE_I386_ALL);
86+
CHECK_CPUSUBTYPE("arm-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7); // Default
87+
CHECK_CPUSUBTYPE("armv4t-apple-darwin", MachO::CPU_SUBTYPE_ARM_V4T);
88+
CHECK_CPUSUBTYPE("armv5t-apple-darwin", MachO::CPU_SUBTYPE_ARM_V5);
89+
CHECK_CPUSUBTYPE("armv5te-apple-darwin", MachO::CPU_SUBTYPE_ARM_V5);
90+
CHECK_CPUSUBTYPE("armv5tej-apple-darwin", MachO::CPU_SUBTYPE_ARM_V5);
91+
CHECK_CPUSUBTYPE("armv6-apple-darwin", MachO::CPU_SUBTYPE_ARM_V6);
92+
CHECK_CPUSUBTYPE("armv6k-apple-darwin", MachO::CPU_SUBTYPE_ARM_V6);
93+
CHECK_CPUSUBTYPE("armv7a-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7);
94+
CHECK_CPUSUBTYPE("armv7s-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7S);
95+
CHECK_CPUSUBTYPE("armv7k-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7K);
96+
CHECK_CPUSUBTYPE("armv6m-apple-darwin", MachO::CPU_SUBTYPE_ARM_V6M);
97+
CHECK_CPUSUBTYPE("armv7m-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7M);
98+
CHECK_CPUSUBTYPE("armv7em-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7EM);
99+
CHECK_CPUSUBTYPE("thumbv7-apple-darwin", MachO::CPU_SUBTYPE_ARM_V7);
100+
CHECK_CPUSUBTYPE("thumbv6-apple-darwin", MachO::CPU_SUBTYPE_ARM_V6);
101+
CHECK_CPUSUBTYPE("arm64-apple-darwin", MachO::CPU_SUBTYPE_ARM64_ALL);
102+
CHECK_CPUSUBTYPE("arm64e-apple-darwin", MachO::CPU_SUBTYPE_ARM64E);
103+
CHECK_CPUSUBTYPE("arm64_32-apple-darwin", MachO::CPU_SUBTYPE_ARM64_32_V8);
104+
CHECK_CPUSUBTYPE("powerpc-apple-darwin", MachO::CPU_SUBTYPE_POWERPC_ALL);
105+
CHECK_CPUSUBTYPE("powerpc64-apple-darwin", MachO::CPU_SUBTYPE_POWERPC_ALL);
106+
107+
{
108+
// Not a mach-o.
109+
Expected<uint32_t> Type =
110+
MachO::getCPUSubType(Triple("x86_64-linux-unknown"));
111+
ASSERT_EQ(
112+
toString(Type.takeError()),
113+
"Unsupported triple for mach-o cpu subtype: x86_64-linux-unknown");
114+
}
115+
{
116+
// Not a valid mach-o architecture.
117+
Expected<uint32_t> Type = MachO::getCPUSubType(Triple("mips-apple-darwin"));
118+
ASSERT_EQ(toString(Type.takeError()),
119+
"Unsupported triple for mach-o cpu subtype: mips-apple-darwin");
120+
}
121+
#undef CHECK_CPUSUBTYPE
122+
}

0 commit comments

Comments
 (0)