2016-09-14 04:40:26 +08:00
|
|
|
//===-- ArchSpecTest.cpp ----------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2016-09-14 04:40:26 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2017-11-14 00:16:33 +08:00
|
|
|
#include "lldb/Utility/ArchSpec.h"
|
2017-06-07 11:48:56 +08:00
|
|
|
#include "llvm/BinaryFormat/MachO.h"
|
2016-09-16 05:32:57 +08:00
|
|
|
|
2016-09-14 04:40:26 +08:00
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
|
|
|
TEST(ArchSpecTest, TestParseMachCPUDashSubtypeTripleSimple) {
|
|
|
|
|
|
|
|
// Success conditions. Valid cpu/subtype combinations using both - and .
|
|
|
|
ArchSpec AS;
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-10", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(10u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-15", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(15u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12.15", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(15u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
|
|
|
|
// Failure conditions.
|
|
|
|
|
|
|
|
// Valid string, unknown cpu/subtype.
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("13.11", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(0u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(0u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
|
|
|
|
// Missing / invalid cpu or subtype
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("13", AS));
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("13.A", AS));
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("A.13", AS));
|
|
|
|
|
|
|
|
// Empty string.
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("", AS));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(ArchSpecTest, TestParseMachCPUDashSubtypeTripleExtra) {
|
|
|
|
ArchSpec AS;
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-15-vendor-os", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(15u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
EXPECT_EQ("vendor", AS.GetTriple().getVendorName());
|
|
|
|
EXPECT_EQ("os", AS.GetTriple().getOSName());
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-10-vendor-os-name", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(10u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
EXPECT_EQ("vendor", AS.GetTriple().getVendorName());
|
|
|
|
EXPECT_EQ("os", AS.GetTriple().getOSName());
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-15-vendor.os-name", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(15u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
EXPECT_EQ("vendor.os", AS.GetTriple().getVendorName());
|
|
|
|
EXPECT_EQ("name", AS.GetTriple().getOSName());
|
|
|
|
|
|
|
|
// These there should parse correctly, but the vendor / OS should be defaulted
|
|
|
|
// since they are unrecognized.
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(ParseMachCPUDashSubtypeTriple("12-10-vendor", AS));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(12u, AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(10u, AS.GetMachOCPUSubType());
|
2016-09-14 04:40:26 +08:00
|
|
|
EXPECT_EQ("apple", AS.GetTriple().getVendorName());
|
|
|
|
EXPECT_EQ("", AS.GetTriple().getOSName());
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
2016-09-16 02:41:48 +08:00
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("12.10.10", AS));
|
2016-09-14 04:40:26 +08:00
|
|
|
|
|
|
|
AS = ArchSpec();
|
2016-09-16 02:41:48 +08:00
|
|
|
EXPECT_FALSE(ParseMachCPUDashSubtypeTriple("12-10.10", AS));
|
2016-09-14 04:40:26 +08:00
|
|
|
}
|
|
|
|
|
2016-09-16 05:32:57 +08:00
|
|
|
TEST(ArchSpecTest, TestSetTriple) {
|
|
|
|
ArchSpec AS;
|
|
|
|
|
|
|
|
// Various flavors of valid triples.
|
|
|
|
EXPECT_TRUE(AS.SetTriple("12-10-apple-darwin"));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(uint32_t(llvm::MachO::CPU_TYPE_ARM), AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(10u, AS.GetMachOCPUSubType());
|
2016-09-16 05:32:57 +08:00
|
|
|
EXPECT_TRUE(llvm::StringRef(AS.GetTriple().str())
|
|
|
|
.consume_front("armv7f-apple-darwin"));
|
|
|
|
EXPECT_EQ(ArchSpec::eCore_arm_armv7f, AS.GetCore());
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(AS.SetTriple("18.100-apple-darwin"));
|
2016-10-18 02:22:03 +08:00
|
|
|
EXPECT_EQ(uint32_t(llvm::MachO::CPU_TYPE_POWERPC), AS.GetMachOCPUType());
|
|
|
|
EXPECT_EQ(100u, AS.GetMachOCPUSubType());
|
2016-09-16 05:32:57 +08:00
|
|
|
EXPECT_TRUE(llvm::StringRef(AS.GetTriple().str())
|
|
|
|
.consume_front("powerpc-apple-darwin"));
|
|
|
|
EXPECT_EQ(ArchSpec::eCore_ppc_ppc970, AS.GetCore());
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_TRUE(AS.SetTriple("i686-pc-windows"));
|
|
|
|
EXPECT_EQ(llvm::Triple::x86, AS.GetTriple().getArch());
|
|
|
|
EXPECT_EQ(llvm::Triple::PC, AS.GetTriple().getVendor());
|
|
|
|
EXPECT_EQ(llvm::Triple::Win32, AS.GetTriple().getOS());
|
|
|
|
EXPECT_TRUE(
|
|
|
|
llvm::StringRef(AS.GetTriple().str()).consume_front("i686-pc-windows"));
|
|
|
|
EXPECT_STREQ("i686", AS.GetArchitectureName());
|
|
|
|
EXPECT_EQ(ArchSpec::eCore_x86_32_i686, AS.GetCore());
|
|
|
|
|
|
|
|
// Various flavors of invalid triples.
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(AS.SetTriple("unknown-unknown-unknown"));
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(AS.SetTriple("unknown"));
|
|
|
|
|
|
|
|
AS = ArchSpec();
|
|
|
|
EXPECT_FALSE(AS.SetTriple(""));
|
2016-10-18 02:22:03 +08:00
|
|
|
}
|
2017-04-20 20:30:18 +08:00
|
|
|
|
|
|
|
TEST(ArchSpecTest, MergeFrom) {
|
|
|
|
ArchSpec A;
|
|
|
|
ArchSpec B("x86_64-pc-linux");
|
|
|
|
|
|
|
|
EXPECT_FALSE(A.IsValid());
|
|
|
|
ASSERT_TRUE(B.IsValid());
|
|
|
|
EXPECT_EQ(llvm::Triple::ArchType::x86_64, B.GetTriple().getArch());
|
|
|
|
EXPECT_EQ(llvm::Triple::VendorType::PC, B.GetTriple().getVendor());
|
|
|
|
EXPECT_EQ(llvm::Triple::OSType::Linux, B.GetTriple().getOS());
|
|
|
|
EXPECT_EQ(ArchSpec::eCore_x86_64_x86_64, B.GetCore());
|
|
|
|
|
|
|
|
A.MergeFrom(B);
|
|
|
|
ASSERT_TRUE(A.IsValid());
|
|
|
|
EXPECT_EQ(llvm::Triple::ArchType::x86_64, A.GetTriple().getArch());
|
|
|
|
EXPECT_EQ(llvm::Triple::VendorType::PC, A.GetTriple().getVendor());
|
|
|
|
EXPECT_EQ(llvm::Triple::OSType::Linux, A.GetTriple().getOS());
|
|
|
|
EXPECT_EQ(ArchSpec::eCore_x86_64_x86_64, A.GetCore());
|
|
|
|
}
|
2018-01-06 02:00:44 +08:00
|
|
|
|
|
|
|
TEST(ArchSpecTest, MergeFromMachOUnknown) {
|
|
|
|
class MyArchSpec : public ArchSpec {
|
|
|
|
public:
|
|
|
|
MyArchSpec() {
|
|
|
|
this->SetTriple("unknown-mach-64");
|
|
|
|
this->m_core = ArchSpec::eCore_uknownMach64;
|
|
|
|
this->m_byte_order = eByteOrderLittle;
|
|
|
|
this->m_flags = 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
MyArchSpec A;
|
|
|
|
ASSERT_TRUE(A.IsValid());
|
|
|
|
MyArchSpec B;
|
|
|
|
ASSERT_TRUE(B.IsValid());
|
|
|
|
A.MergeFrom(B);
|
|
|
|
ASSERT_EQ(A.GetCore(), ArchSpec::eCore_uknownMach64);
|
|
|
|
}
|
2018-12-06 08:43:55 +08:00
|
|
|
|
|
|
|
TEST(ArchSpecTest, Compatibility) {
|
|
|
|
{
|
|
|
|
ArchSpec A("x86_64-apple-macosx10.12");
|
|
|
|
ArchSpec B("x86_64-apple-macosx10.12");
|
|
|
|
ASSERT_TRUE(A.IsExactMatch(B));
|
|
|
|
ASSERT_TRUE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
// The version information is auxiliary to support availablity but
|
|
|
|
// doesn't affect compatibility.
|
|
|
|
ArchSpec A("x86_64-apple-macosx10.11");
|
|
|
|
ArchSpec B("x86_64-apple-macosx10.12");
|
|
|
|
ASSERT_TRUE(A.IsExactMatch(B));
|
|
|
|
ASSERT_TRUE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ArchSpec A("x86_64-apple-macosx10.13");
|
|
|
|
ArchSpec B("x86_64h-apple-macosx10.13");
|
|
|
|
ASSERT_FALSE(A.IsExactMatch(B));
|
|
|
|
ASSERT_TRUE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ArchSpec A("x86_64-apple-macosx");
|
|
|
|
ArchSpec B("x86_64-apple-ios-simulator");
|
|
|
|
ASSERT_FALSE(A.IsExactMatch(B));
|
|
|
|
ASSERT_FALSE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ArchSpec A("x86_64-*-*");
|
|
|
|
ArchSpec B("x86_64-apple-ios-simulator");
|
|
|
|
ASSERT_FALSE(A.IsExactMatch(B));
|
|
|
|
ASSERT_FALSE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ArchSpec A("arm64-*-*");
|
|
|
|
ArchSpec B("arm64-apple-ios");
|
|
|
|
ASSERT_FALSE(A.IsExactMatch(B));
|
|
|
|
// FIXME: This looks unintuitive and we should investigate whether
|
2018-12-07 01:11:45 +08:00
|
|
|
// this is the desired behavior.
|
2018-12-06 08:43:55 +08:00
|
|
|
ASSERT_FALSE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ArchSpec A("x86_64-*-*");
|
|
|
|
ArchSpec B("x86_64-apple-ios-simulator");
|
|
|
|
ASSERT_FALSE(A.IsExactMatch(B));
|
|
|
|
// FIXME: See above, though the extra environment complicates things.
|
|
|
|
ASSERT_FALSE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
2018-12-07 01:11:45 +08:00
|
|
|
{
|
|
|
|
ArchSpec A("x86_64");
|
|
|
|
ArchSpec B("x86_64-apple-macosx10.14");
|
|
|
|
// FIXME: The exact match also looks unintuitive.
|
|
|
|
ASSERT_TRUE(A.IsExactMatch(B));
|
|
|
|
ASSERT_TRUE(A.IsCompatibleMatch(B));
|
|
|
|
}
|
2018-12-06 08:43:55 +08:00
|
|
|
}
|
2019-01-03 18:37:19 +08:00
|
|
|
|
|
|
|
TEST(ArchSpecTest, OperatorBool) {
|
|
|
|
EXPECT_FALSE(ArchSpec());
|
|
|
|
EXPECT_TRUE(ArchSpec("x86_64-pc-linux"));
|
|
|
|
}
|