diff options
| author | 2014-10-17 02:29:32 +0000 | |
|---|---|---|
| committer | 2014-10-17 02:29:32 +0000 | |
| commit | b3f18cf7466f85e15c6b7f005f544867a4d6847a (patch) | |
| tree | 62035f08dc38038b74c9796118ae0bab0e7608fb /runtime/instruction_set_test.cc | |
| parent | cb142101f29a4f1e097f03a220db3da6d4bd679f (diff) | |
| parent | 6f3dbbadf4ce66982eb3d400e0a74cb73eb034f3 (diff) | |
Merge "Make ART compile with GCC -O0 again."
Diffstat (limited to 'runtime/instruction_set_test.cc')
| -rw-r--r-- | runtime/instruction_set_test.cc | 211 | 
1 files changed, 211 insertions, 0 deletions
diff --git a/runtime/instruction_set_test.cc b/runtime/instruction_set_test.cc index 80191b1387..948063d452 100644 --- a/runtime/instruction_set_test.cc +++ b/runtime/instruction_set_test.cc @@ -16,6 +16,7 @@  #include "instruction_set.h" +#include "base/stringprintf.h"  #include "common_runtime_test.h"  namespace art { @@ -50,4 +51,214 @@ TEST_F(InstructionSetTest, PointerSize) {    EXPECT_EQ(sizeof(void*), GetInstructionSetPointerSize(kRuntimeISA));  } +TEST_F(InstructionSetTest, X86Features) { +  // Build features for a 32-bit x86 atom processor. +  std::string error_msg; +  std::unique_ptr<const InstructionSetFeatures> x86_features( +      InstructionSetFeatures::FromVariant(kX86, "atom", &error_msg)); +  ASSERT_TRUE(x86_features.get() != nullptr) << error_msg; +  EXPECT_EQ(x86_features->GetInstructionSet(), kX86); +  EXPECT_TRUE(x86_features->Equals(x86_features.get())); +  EXPECT_STREQ("none", x86_features->GetFeatureString().c_str()); +  EXPECT_EQ(x86_features->AsBitmap(), 0U); + +  // Build features for a 32-bit x86 default processor. +  std::unique_ptr<const InstructionSetFeatures> x86_default_features( +      InstructionSetFeatures::FromFeatureString(kX86, "default", &error_msg)); +  ASSERT_TRUE(x86_default_features.get() != nullptr) << error_msg; +  EXPECT_EQ(x86_default_features->GetInstructionSet(), kX86); +  EXPECT_TRUE(x86_default_features->Equals(x86_default_features.get())); +  EXPECT_STREQ("none", x86_default_features->GetFeatureString().c_str()); +  EXPECT_EQ(x86_default_features->AsBitmap(), 0U); + +  // Build features for a 64-bit x86-64 atom processor. +  std::unique_ptr<const InstructionSetFeatures> x86_64_features( +      InstructionSetFeatures::FromVariant(kX86_64, "atom", &error_msg)); +  ASSERT_TRUE(x86_64_features.get() != nullptr) << error_msg; +  EXPECT_EQ(x86_64_features->GetInstructionSet(), kX86_64); +  EXPECT_TRUE(x86_64_features->Equals(x86_64_features.get())); +  EXPECT_STREQ("none", x86_64_features->GetFeatureString().c_str()); +  EXPECT_EQ(x86_64_features->AsBitmap(), 0U); + +  EXPECT_FALSE(x86_64_features->Equals(x86_features.get())); +  EXPECT_FALSE(x86_64_features->Equals(x86_default_features.get())); +  EXPECT_TRUE(x86_features->Equals(x86_default_features.get())); +} + +TEST_F(InstructionSetTest, ArmFeaturesFromVariant) { +  // Build features for a 32-bit ARM krait processor. +  std::string error_msg; +  std::unique_ptr<const InstructionSetFeatures> krait_features( +      InstructionSetFeatures::FromVariant(kArm, "krait", &error_msg)); +  ASSERT_TRUE(krait_features.get() != nullptr) << error_msg; + +  ASSERT_EQ(krait_features->GetInstructionSet(), kArm); +  EXPECT_TRUE(krait_features->Equals(krait_features.get())); +  EXPECT_TRUE(krait_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_TRUE(krait_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("div,lpae", krait_features->GetFeatureString().c_str()); +  EXPECT_EQ(krait_features->AsBitmap(), 3U); + +  // Build features for a 32-bit ARM denver processor. +  std::unique_ptr<const InstructionSetFeatures> denver_features( +      InstructionSetFeatures::FromVariant(kArm, "denver", &error_msg)); +  ASSERT_TRUE(denver_features.get() != nullptr) << error_msg; + +  EXPECT_TRUE(denver_features->Equals(denver_features.get())); +  EXPECT_TRUE(denver_features->Equals(krait_features.get())); +  EXPECT_TRUE(krait_features->Equals(denver_features.get())); +  EXPECT_TRUE(denver_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_TRUE(denver_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("div,lpae", denver_features->GetFeatureString().c_str()); +  EXPECT_EQ(denver_features->AsBitmap(), 3U); + +  // Build features for a 32-bit ARMv7 processor. +  std::unique_ptr<const InstructionSetFeatures> arm7_features( +      InstructionSetFeatures::FromVariant(kArm, "arm7", &error_msg)); +  ASSERT_TRUE(arm7_features.get() != nullptr) << error_msg; + +  EXPECT_TRUE(arm7_features->Equals(arm7_features.get())); +  EXPECT_FALSE(arm7_features->Equals(krait_features.get())); +  EXPECT_FALSE(krait_features->Equals(arm7_features.get())); +  EXPECT_FALSE(arm7_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_FALSE(arm7_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("none", arm7_features->GetFeatureString().c_str()); +  EXPECT_EQ(arm7_features->AsBitmap(), 0U); + +  // ARM6 is not a supported architecture variant. +  std::unique_ptr<const InstructionSetFeatures> arm6_features( +      InstructionSetFeatures::FromVariant(kArm, "arm6", &error_msg)); +  EXPECT_TRUE(arm6_features.get() == nullptr); +  EXPECT_NE(error_msg.size(), 0U); +} + +TEST_F(InstructionSetTest, ArmFeaturesFromString) { +  // Build features for a 32-bit ARM with LPAE and div processor. +  std::string error_msg; +  std::unique_ptr<const InstructionSetFeatures> krait_features( +      InstructionSetFeatures::FromFeatureString(kArm, "lpae,div", &error_msg)); +  ASSERT_TRUE(krait_features.get() != nullptr) << error_msg; + +  ASSERT_EQ(krait_features->GetInstructionSet(), kArm); +  EXPECT_TRUE(krait_features->Equals(krait_features.get())); +  EXPECT_TRUE(krait_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_TRUE(krait_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("div,lpae", krait_features->GetFeatureString().c_str()); +  EXPECT_EQ(krait_features->AsBitmap(), 3U); + +  // Build features for a 32-bit ARM processor with LPAE and div flipped. +  std::unique_ptr<const InstructionSetFeatures> denver_features( +      InstructionSetFeatures::FromFeatureString(kArm, "div,lpae", &error_msg)); +  ASSERT_TRUE(denver_features.get() != nullptr) << error_msg; + +  EXPECT_TRUE(denver_features->Equals(denver_features.get())); +  EXPECT_TRUE(denver_features->Equals(krait_features.get())); +  EXPECT_TRUE(krait_features->Equals(denver_features.get())); +  EXPECT_TRUE(denver_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_TRUE(denver_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("div,lpae", denver_features->GetFeatureString().c_str()); +  EXPECT_EQ(denver_features->AsBitmap(), 3U); + +  // Build features for a 32-bit default ARM processor. +  std::unique_ptr<const InstructionSetFeatures> arm7_features( +      InstructionSetFeatures::FromFeatureString(kArm, "default", &error_msg)); +  ASSERT_TRUE(arm7_features.get() != nullptr) << error_msg; + +  EXPECT_TRUE(arm7_features->Equals(arm7_features.get())); +  EXPECT_FALSE(arm7_features->Equals(krait_features.get())); +  EXPECT_FALSE(krait_features->Equals(arm7_features.get())); +  EXPECT_FALSE(arm7_features->AsArmInstructionSetFeatures()->HasDivideInstruction()); +  EXPECT_FALSE(arm7_features->AsArmInstructionSetFeatures()->HasLpae()); +  EXPECT_STREQ("none", arm7_features->GetFeatureString().c_str()); +  EXPECT_EQ(arm7_features->AsBitmap(), 0U); +} + +#ifdef HAVE_ANDROID_OS +#include "cutils/properties.h" + +TEST_F(InstructionSetTest, FeaturesFromSystemPropertyVariant) { +  // Take the default set of instruction features from the build. +  std::unique_ptr<const InstructionSetFeatures> instruction_set_features( +      InstructionSetFeatures::FromCppDefines()); + +  // Read the features property. +  std::string key = StringPrintf("dalvik.vm.isa.%s.variant", GetInstructionSetString(kRuntimeISA)); +  char dex2oat_isa_variant[PROPERTY_VALUE_MAX]; +  if (property_get(key.c_str(), dex2oat_isa_variant, nullptr) > 0) { +    // Use features from property to build InstructionSetFeatures and check against build's +    // features. +    std::string error_msg; +    std::unique_ptr<const InstructionSetFeatures> property_features( +        InstructionSetFeatures::FromVariant(kRuntimeISA, dex2oat_isa_variant, &error_msg)); +    ASSERT_TRUE(property_features.get() != nullptr) << error_msg; + +    EXPECT_TRUE(property_features->Equals(instruction_set_features.get())) +      << "System property features: " << *property_features.get() +      << "\nFeatures from build: " << *instruction_set_features.get(); +  } +} + +TEST_F(InstructionSetTest, FeaturesFromSystemPropertyString) { +  // Take the default set of instruction features from the build. +  std::unique_ptr<const InstructionSetFeatures> instruction_set_features( +      InstructionSetFeatures::FromCppDefines()); + +  // Read the features property. +  std::string key = StringPrintf("dalvik.vm.isa.%s.features", GetInstructionSetString(kRuntimeISA)); +  char dex2oat_isa_features[PROPERTY_VALUE_MAX]; +  if (property_get(key.c_str(), dex2oat_isa_features, nullptr) > 0) { +    // Use features from property to build InstructionSetFeatures and check against build's +    // features. +    std::string error_msg; +    std::unique_ptr<const InstructionSetFeatures> property_features( +        InstructionSetFeatures::FromFeatureString(kRuntimeISA, dex2oat_isa_features, &error_msg)); +    ASSERT_TRUE(property_features.get() != nullptr) << error_msg; + +    EXPECT_TRUE(property_features->Equals(instruction_set_features.get())) +      << "System property features: " << *property_features.get() +      << "\nFeatures from build: " << *instruction_set_features.get(); +  } +} +#endif + +TEST_F(InstructionSetTest, FeaturesFromCpuInfo) { +  // Take the default set of instruction features from the build. +  std::unique_ptr<const InstructionSetFeatures> instruction_set_features( +      InstructionSetFeatures::FromCppDefines()); + +  // Check we get the same instruction set features using /proc/cpuinfo. +  std::unique_ptr<const InstructionSetFeatures> cpuinfo_features( +      InstructionSetFeatures::FromCpuInfo()); +  EXPECT_TRUE(cpuinfo_features->Equals(instruction_set_features.get())) +      << "CPU Info features: " << *cpuinfo_features.get() +      << "\nFeatures from build: " << *instruction_set_features.get(); +} + +TEST_F(InstructionSetTest, FeaturesFromHwcap) { +  // Take the default set of instruction features from the build. +  std::unique_ptr<const InstructionSetFeatures> instruction_set_features( +      InstructionSetFeatures::FromCppDefines()); + +  // Check we get the same instruction set features using AT_HWCAP. +  std::unique_ptr<const InstructionSetFeatures> hwcap_features( +      InstructionSetFeatures::FromHwcap()); +  EXPECT_TRUE(hwcap_features->Equals(instruction_set_features.get())) +      << "Hwcap features: " << *hwcap_features.get() +      << "\nFeatures from build: " << *instruction_set_features.get(); +} + + +TEST_F(InstructionSetTest, FeaturesFromAssembly) { +  // Take the default set of instruction features from the build. +  std::unique_ptr<const InstructionSetFeatures> instruction_set_features( +      InstructionSetFeatures::FromCppDefines()); + +  // Check we get the same instruction set features using assembly tests. +  std::unique_ptr<const InstructionSetFeatures> assembly_features( +      InstructionSetFeatures::FromAssembly()); +  EXPECT_TRUE(assembly_features->Equals(instruction_set_features.get())) +      << "Assembly features: " << *assembly_features.get() +      << "\nFeatures from build: " << *instruction_set_features.get(); +} +  }  // namespace art  |