| Index: src/register-configuration.cc
|
| diff --git a/src/register-configuration.cc b/src/register-configuration.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d3dc4f08d70f3e42f40aa7e4a16bab9413176983
|
| --- /dev/null
|
| +++ b/src/register-configuration.cc
|
| @@ -0,0 +1,138 @@
|
| +// 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/register-configuration.h"
|
| +#include "src/globals.h"
|
| +#include "src/macro-assembler.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +
|
| +namespace {
|
| +
|
| +#define REGISTER_COUNT(R) 1 +
|
| +static const int kMaxAllocatableGeneralRegisterCount =
|
| + ALLOCATABLE_GENERAL_REGISTERS(REGISTER_COUNT)0;
|
| +static const int kMaxAllocatableDoubleRegisterCount =
|
| + ALLOCATABLE_DOUBLE_REGISTERS(REGISTER_COUNT)0;
|
| +
|
| +static const char* const kGeneralRegisterNames[] = {
|
| +#define REGISTER_NAME(R) #R,
|
| + GENERAL_REGISTERS(REGISTER_NAME)
|
| +#undef REGISTER_NAME
|
| +};
|
| +
|
| +static const char* const kDoubleRegisterNames[] = {
|
| +#define REGISTER_NAME(R) #R,
|
| + DOUBLE_REGISTERS(REGISTER_NAME)
|
| +#undef REGISTER_NAME
|
| +};
|
| +
|
| +STATIC_ASSERT(RegisterConfiguration::kMaxGeneralRegisters >=
|
| + Register::kNumRegisters);
|
| +STATIC_ASSERT(RegisterConfiguration::kMaxDoubleRegisters >=
|
| + DoubleRegister::kMaxNumRegisters);
|
| +
|
| +class ArchDefaultRegisterConfiguration : public RegisterConfiguration {
|
| + public:
|
| + ArchDefaultRegisterConfiguration()
|
| + : RegisterConfiguration(
|
| + Register::kNumRegisters, DoubleRegister::kMaxNumRegisters,
|
| +#if V8_TARGET_ARCH_IA32
|
| + kMaxAllocatableGeneralRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| +#elif V8_TARGET_ARCH_X87
|
| + kMaxAllocatableGeneralRegisterCount, 1, 1,
|
| +#elif V8_TARGET_ARCH_X64
|
| + kMaxAllocatableGeneralRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| +#elif V8_TARGET_ARCH_ARM
|
| + FLAG_enable_embedded_constant_pool
|
| + ? (kMaxAllocatableGeneralRegisterCount - 1)
|
| + : kMaxAllocatableGeneralRegisterCount,
|
| + CpuFeatures::IsSupported(VFP32DREGS)
|
| + ? kMaxAllocatableDoubleRegisterCount
|
| + : (ALLOCATABLE_NO_VFP32_DOUBLE_REGISTERS(REGISTER_COUNT)0),
|
| + ALLOCATABLE_NO_VFP32_DOUBLE_REGISTERS(REGISTER_COUNT)0,
|
| +#elif V8_TARGET_ARCH_ARM64
|
| + kMaxAllocatableGeneralRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| + kMaxAllocatableDoubleRegisterCount,
|
| +#else
|
| + GetAllocatableGeneralRegisterCount(),
|
| + GetAllocatableDoubleRegisterCount(),
|
| + GetAllocatableAliasedDoubleRegisterCount(),
|
| +#endif
|
| + GetAllocatableGeneralCodes(), GetAllocatableDoubleCodes(),
|
| + kGeneralRegisterNames, kDoubleRegisterNames) {
|
| + }
|
| +
|
| + const char* general_register_name_table_[Register::kNumRegisters];
|
| + const char* double_register_name_table_[DoubleRegister::kMaxNumRegisters];
|
| +
|
| + private:
|
| + friend struct Register;
|
| + friend struct DoubleRegister;
|
| +
|
| + static const int* GetAllocatableGeneralCodes() {
|
| +#define REGISTER_CODE(R) Register::kCode_##R,
|
| + static const int general_codes[] = {
|
| + ALLOCATABLE_GENERAL_REGISTERS(REGISTER_CODE)};
|
| +#undef REGISTER_CODE
|
| + return general_codes;
|
| + }
|
| +
|
| + static const int* GetAllocatableDoubleCodes() {
|
| +#define REGISTER_CODE(R) DoubleRegister::kCode_##R,
|
| + static const int double_codes[] = {
|
| + ALLOCATABLE_DOUBLE_REGISTERS(REGISTER_CODE)};
|
| +#undef REGISTER_CODE
|
| + return double_codes;
|
| + }
|
| +};
|
| +
|
| +
|
| +static base::LazyInstance<ArchDefaultRegisterConfiguration>::type
|
| + kDefaultRegisterConfiguration = LAZY_INSTANCE_INITIALIZER;
|
| +
|
| +} // namespace
|
| +
|
| +
|
| +const RegisterConfiguration* RegisterConfiguration::ArchDefault() {
|
| + return &kDefaultRegisterConfiguration.Get();
|
| +}
|
| +
|
| +RegisterConfiguration::RegisterConfiguration(
|
| + int num_general_registers, int num_double_registers,
|
| + int num_allocatable_general_registers, int num_allocatable_double_registers,
|
| + int num_allocatable_aliased_double_registers,
|
| + const int* allocatable_general_codes, const int* allocatable_double_codes,
|
| + const char* const* general_register_names,
|
| + const char* const* double_register_names)
|
| + : num_general_registers_(num_general_registers),
|
| + num_double_registers_(num_double_registers),
|
| + num_allocatable_general_registers_(num_allocatable_general_registers),
|
| + num_allocatable_double_registers_(num_allocatable_double_registers),
|
| + num_allocatable_aliased_double_registers_(
|
| + num_allocatable_aliased_double_registers),
|
| + allocatable_general_codes_mask_(0),
|
| + allocatable_double_codes_mask_(0),
|
| + allocatable_general_codes_(allocatable_general_codes),
|
| + allocatable_double_codes_(allocatable_double_codes),
|
| + general_register_names_(general_register_names),
|
| + double_register_names_(double_register_names) {
|
| + for (int i = 0; i < num_allocatable_general_registers_; ++i) {
|
| + allocatable_general_codes_mask_ |= (1 << allocatable_general_codes_[i]);
|
| + }
|
| + for (int i = 0; i < num_allocatable_double_registers_; ++i) {
|
| + allocatable_double_codes_mask_ |= (1 << allocatable_double_codes_[i]);
|
| + }
|
| +}
|
| +
|
| +#undef REGISTER_COUNT
|
| +
|
| +} // namespace internal
|
| +} // namespace v8
|
|
|