Chromium Code Reviews| Index: test/base-unittests/cpu-unittest.cc |
| diff --git a/test/base-unittests/cpu-unittest.cc b/test/base-unittests/cpu-unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..5c58f862381f8e585ddaafd4b5b7627977990cbd |
| --- /dev/null |
| +++ b/test/base-unittests/cpu-unittest.cc |
| @@ -0,0 +1,49 @@ |
| +// Copyright 2014 the V8 project authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "src/base/cpu.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace v8 { |
| +namespace base { |
| + |
| +TEST(CPUTest, FeatureImplications) { |
| + CPU cpu; |
| + |
| + // ia32 and x64 features |
| + EXPECT_TRUE(!cpu.has_sse() || cpu.has_mmx()); |
| + EXPECT_TRUE(!cpu.has_sse2() || cpu.has_sse()); |
| + EXPECT_TRUE(!cpu.has_sse3() || cpu.has_sse2()); |
| + EXPECT_TRUE(!cpu.has_ssse3() || cpu.has_sse3()); |
| + EXPECT_TRUE(!cpu.has_sse41() || cpu.has_sse3()); |
| + EXPECT_TRUE(!cpu.has_sse42() || cpu.has_sse41()); |
| + |
| + // arm features |
| + EXPECT_TRUE(!cpu.has_vfp3_d32() || cpu.has_vfp3()); |
| +} |
| + |
| + |
| +TEST(CPUTest, RequiredFeatures) { |
| + CPU cpu; |
| + |
| +#if V8_HOST_ARCH_ARM |
| + EXPECT_TRUE(cpu.has_fpu()); |
| +#endif |
| + |
| +#if V8_HOST_ARCH_IA32 |
|
Sven Panne
2014/08/06 09:33:28
Using #elif is a bit nicer IMHO, but that's mostly
Benedikt Meurer
2014/08/06 09:35:05
I prefer this style.
|
| + EXPECT_TRUE(cpu.has_fpu()); |
| + EXPECT_TRUE(cpu.has_sahf()); |
| +#endif |
| + |
| +#if V8_HOST_ARCH_X64 |
| + EXPECT_TRUE(cpu.has_fpu()); |
| + EXPECT_TRUE(cpu.has_cmov()); |
| + EXPECT_TRUE(cpu.has_mmx()); |
| + EXPECT_TRUE(cpu.has_sse()); |
| + EXPECT_TRUE(cpu.has_sse2()); |
| +#endif |
| +} |
| + |
| +} // namespace base |
| +} // namespace v8 |