Revert "Add methods to enable configuration of ResourceConstraints based on limits derived at runtime." and "Fix Windows build of defaults.cc."
This reverts commit r16964 and r16968 due to performance regressions in octane. TBR=hpayer@chromium.org Review URL: https://codereview.chromium.org/24996003 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@16979 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
42d7071422
commit
936802ae21
@ -1,54 +0,0 @@
|
||||
// Copyright 2013 the V8 project authors. All rights reserved.
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright
|
||||
// notice, this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above
|
||||
// copyright notice, this list of conditions and the following
|
||||
// disclaimer in the documentation and/or other materials provided
|
||||
// with the distribution.
|
||||
// * Neither the name of Google Inc. nor the names of its
|
||||
// contributors may be used to endorse or promote products derived
|
||||
// from this software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
#ifndef V8_V8_DEFAULTS_H_
|
||||
#define V8_V8_DEFAULTS_H_
|
||||
|
||||
#include "v8.h"
|
||||
|
||||
/**
|
||||
* Default configuration support for the V8 JavaScript engine.
|
||||
*/
|
||||
namespace v8 {
|
||||
|
||||
/**
|
||||
* Configures the constraints with reasonable default values based on the
|
||||
* capabilities of the current device the VM is running on.
|
||||
*/
|
||||
bool V8_EXPORT ConfigureResourceConstraintsForCurrentPlatform(
|
||||
ResourceConstraints* constraints);
|
||||
|
||||
|
||||
/**
|
||||
* Convience function which performs SetResourceConstraints with the settings
|
||||
* returned by ConfigureResourceConstraintsForCurrentPlatform.
|
||||
*/
|
||||
bool V8_EXPORT SetDefaultResourceConstraintsForCurrentPlatform();
|
||||
|
||||
} // namespace v8
|
||||
|
||||
#endif // V8_V8_DEFAULTS_H_
|
@ -68,4 +68,8 @@ class V8_EXPORT Testing {
|
||||
|
||||
} // namespace v8
|
||||
|
||||
|
||||
#undef V8_EXPORT
|
||||
|
||||
|
||||
#endif // V8_V8_TEST_H_
|
||||
|
@ -3804,9 +3804,6 @@ class V8_EXPORT ResourceConstraints {
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Sets the given ResourceConstraints on the current isolate.
|
||||
*/
|
||||
bool V8_EXPORT SetResourceConstraints(ResourceConstraints* constraints);
|
||||
|
||||
|
||||
|
@ -49,7 +49,6 @@
|
||||
#endif // !V8_SHARED
|
||||
|
||||
#ifdef V8_SHARED
|
||||
#include "../include/v8-defaults.h"
|
||||
#include "../include/v8-testing.h"
|
||||
#endif // V8_SHARED
|
||||
|
||||
@ -67,7 +66,6 @@
|
||||
#include "natives.h"
|
||||
#include "platform.h"
|
||||
#include "v8.h"
|
||||
#include "v8-defaults.h"
|
||||
#endif // V8_SHARED
|
||||
|
||||
#if !defined(_WIN32) && !defined(_WIN64)
|
||||
@ -1651,7 +1649,6 @@ int Shell::Main(int argc, char* argv[]) {
|
||||
#else
|
||||
SetStandaloneFlagsViaCommandLine();
|
||||
#endif
|
||||
v8::SetDefaultResourceConstraintsForCurrentPlatform();
|
||||
ShellArrayBufferAllocator array_buffer_allocator;
|
||||
v8::V8::SetArrayBufferAllocator(&array_buffer_allocator);
|
||||
int result = 0;
|
||||
|
@ -1,71 +0,0 @@
|
||||
// Copyright 2013 the V8 project authors. All rights reserved.
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright
|
||||
// notice, this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above
|
||||
// copyright notice, this list of conditions and the following
|
||||
// disclaimer in the documentation and/or other materials provided
|
||||
// with the distribution.
|
||||
// * Neither the name of Google Inc. nor the names of its
|
||||
// contributors may be used to endorse or promote products derived
|
||||
// from this software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
#include "../include/v8-defaults.h"
|
||||
|
||||
#include "platform.h"
|
||||
#include "globals.h"
|
||||
#include "v8.h"
|
||||
|
||||
namespace v8 {
|
||||
|
||||
bool ConfigureResourceConstraintsForCurrentPlatform(
|
||||
ResourceConstraints* constraints) {
|
||||
if (constraints == NULL) {
|
||||
return false;
|
||||
}
|
||||
|
||||
uint64_t physical_memory = i::OS::TotalPhysicalMemory();
|
||||
int lump_of_memory = (i::kPointerSize / 4) * i::MB;
|
||||
|
||||
// The young_space_size should be a power of 2 and old_generation_size should
|
||||
// be a multiple of Page::kPageSize.
|
||||
if (physical_memory > 2ul * i::GB) {
|
||||
constraints->set_max_young_space_size(8 * lump_of_memory);
|
||||
constraints->set_max_old_space_size(700 * lump_of_memory);
|
||||
constraints->set_max_executable_size(256 * lump_of_memory);
|
||||
} else if (physical_memory > 512ul * i::MB) {
|
||||
constraints->set_max_young_space_size(4 * lump_of_memory);
|
||||
constraints->set_max_old_space_size(192 * lump_of_memory);
|
||||
constraints->set_max_executable_size(192 * lump_of_memory);
|
||||
} else /* (physical_memory <= 512GB) */ {
|
||||
constraints->set_max_young_space_size(1 * lump_of_memory);
|
||||
constraints->set_max_old_space_size(96 * lump_of_memory);
|
||||
constraints->set_max_executable_size(96 * lump_of_memory);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
bool SetDefaultResourceConstraintsForCurrentPlatform() {
|
||||
ResourceConstraints constraints;
|
||||
if (!ConfigureResourceConstraintsForCurrentPlatform(&constraints))
|
||||
return false;
|
||||
return SetResourceConstraints(&constraints);
|
||||
}
|
||||
|
||||
} // namespace v8::internal
|
@ -248,12 +248,10 @@ const int kRandomStateSize = 2 * kIntSize;
|
||||
const int kPointerSizeLog2 = 3;
|
||||
const intptr_t kIntptrSignBit = V8_INT64_C(0x8000000000000000);
|
||||
const uintptr_t kUintptrAllBitsSet = V8_UINT64_C(0xFFFFFFFFFFFFFFFF);
|
||||
const bool kIs64BitArch = true;
|
||||
#else
|
||||
const int kPointerSizeLog2 = 2;
|
||||
const intptr_t kIntptrSignBit = 0x80000000;
|
||||
const uintptr_t kUintptrAllBitsSet = 0xFFFFFFFFu;
|
||||
const bool kIs64BitArch = false;
|
||||
#endif
|
||||
|
||||
const int kBitsPerByte = 8;
|
||||
|
28
src/heap.cc
28
src/heap.cc
@ -67,14 +67,29 @@ namespace internal {
|
||||
|
||||
Heap::Heap()
|
||||
: isolate_(NULL),
|
||||
code_range_size_(kIs64BitArch ? 512 * MB : 0),
|
||||
// semispace_size_ should be a power of 2 and old_generation_size_ should be
|
||||
// a multiple of Page::kPageSize.
|
||||
reserved_semispace_size_(8 * (kPointerSize / 4) * MB),
|
||||
max_semispace_size_(8 * (kPointerSize / 4) * MB),
|
||||
#if V8_TARGET_ARCH_X64
|
||||
#define LUMP_OF_MEMORY (2 * MB)
|
||||
code_range_size_(512*MB),
|
||||
#else
|
||||
#define LUMP_OF_MEMORY MB
|
||||
code_range_size_(0),
|
||||
#endif
|
||||
#if defined(ANDROID) || V8_TARGET_ARCH_MIPS
|
||||
reserved_semispace_size_(4 * Max(LUMP_OF_MEMORY, Page::kPageSize)),
|
||||
max_semispace_size_(4 * Max(LUMP_OF_MEMORY, Page::kPageSize)),
|
||||
initial_semispace_size_(Page::kPageSize),
|
||||
max_old_generation_size_(700ul * (kPointerSize / 4) * MB),
|
||||
max_executable_size_(256ul * (kPointerSize / 4) * MB),
|
||||
max_old_generation_size_(192*MB),
|
||||
max_executable_size_(max_old_generation_size_),
|
||||
#else
|
||||
reserved_semispace_size_(8 * Max(LUMP_OF_MEMORY, Page::kPageSize)),
|
||||
max_semispace_size_(8 * Max(LUMP_OF_MEMORY, Page::kPageSize)),
|
||||
initial_semispace_size_(Page::kPageSize),
|
||||
max_old_generation_size_(700ul * LUMP_OF_MEMORY),
|
||||
max_executable_size_(256l * LUMP_OF_MEMORY),
|
||||
#endif
|
||||
|
||||
// Variables set based on semispace_size_ and old_generation_size_ in
|
||||
// ConfigureHeap (survived_since_last_expansion_, external_allocation_limit_)
|
||||
// Will be 4 * reserved_semispace_size_ to ensure that young
|
||||
@ -155,9 +170,6 @@ Heap::Heap()
|
||||
max_semispace_size_ = reserved_semispace_size_ = V8_MAX_SEMISPACE_SIZE;
|
||||
#endif
|
||||
|
||||
// Ensure old_generation_size_ is a multiple of kPageSize.
|
||||
ASSERT(MB >= Page::kPageSize);
|
||||
|
||||
intptr_t max_virtual = OS::MaxVirtualMemory();
|
||||
|
||||
if (max_virtual > 0) {
|
||||
|
@ -100,48 +100,6 @@ intptr_t OS::MaxVirtualMemory() {
|
||||
}
|
||||
|
||||
|
||||
uint64_t OS::TotalPhysicalMemory() {
|
||||
#if V8_OS_MACOSX
|
||||
int mib[2];
|
||||
mib[0] = CTL_HW;
|
||||
mib[1] = HW_MEMSIZE;
|
||||
int64_t size = 0;
|
||||
size_t len = sizeof(size);
|
||||
if (sysctl(mib, 2, &size, &len, NULL, 0) != 0) {
|
||||
UNREACHABLE();
|
||||
return 0;
|
||||
}
|
||||
return static_cast<uint64_t>(size);
|
||||
#elif V8_OS_FREEBSD
|
||||
int pages, page_size;
|
||||
size_t size = sizeof(pages);
|
||||
sysctlbyname("vm.stats.vm.v_page_count", &pages, &size, NULL, 0);
|
||||
sysctlbyname("vm.stats.vm.v_page_size", &page_size, &size, NULL, 0);
|
||||
if (pages == -1 || page_size == -1) {
|
||||
UNREACHABLE();
|
||||
return 0;
|
||||
}
|
||||
return static_cast<uint64_t>(pages) * page_size;
|
||||
#elif V8_OS_CYGWIN
|
||||
MEMORYSTATUS memory_info;
|
||||
memory_info.dwLength = sizeof(memory_info);
|
||||
if (!GlobalMemoryStatus(&memory_info)) {
|
||||
UNREACHABLE();
|
||||
return 0;
|
||||
}
|
||||
return static_cast<uint64_t>(memory_info.dwTotalPhys);
|
||||
#else
|
||||
intptr_t pages = sysconf(_SC_PHYS_PAGES);
|
||||
intptr_t page_size = sysconf(_SC_PAGESIZE);
|
||||
if (pages == -1 || page_size == -1) {
|
||||
UNREACHABLE();
|
||||
return 0;
|
||||
}
|
||||
return static_cast<uint64_t>(pages) * page_size;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
int OS::ActivationFrameAlignment() {
|
||||
#if V8_TARGET_ARCH_ARM
|
||||
// On EABI ARM targets this is required for fp correctness in the
|
||||
|
@ -1271,18 +1271,6 @@ void OS::SignalCodeMovingGC() {
|
||||
}
|
||||
|
||||
|
||||
uint64_t OS::TotalPhysicalMemory() {
|
||||
MEMORYSTATUSEX memory_info;
|
||||
memory_info.dwLength = sizeof(memory_info);
|
||||
if (!GlobalMemoryStatusEx(&memory_info)) {
|
||||
UNREACHABLE();
|
||||
return 0;
|
||||
}
|
||||
|
||||
return static_cast<uint64_t>(memory_info.ullTotalPhys);
|
||||
}
|
||||
|
||||
|
||||
#else // __MINGW32__
|
||||
void OS::LogSharedLibraryAddresses(Isolate* isolate) { }
|
||||
void OS::SignalCodeMovingGC() { }
|
||||
|
@ -302,9 +302,6 @@ class OS {
|
||||
// positions indicated by the members of the CpuFeature enum from globals.h
|
||||
static uint64_t CpuFeaturesImpliedByPlatform();
|
||||
|
||||
// The total amount of physical memory available on the current system.
|
||||
static uint64_t TotalPhysicalMemory();
|
||||
|
||||
// Maximum size of the virtual memory. 0 means there is no artificial
|
||||
// limit.
|
||||
static intptr_t MaxVirtualMemory();
|
||||
|
@ -270,7 +270,6 @@
|
||||
'../../src/debug-agent.h',
|
||||
'../../src/debug.cc',
|
||||
'../../src/debug.h',
|
||||
'../../src/defaults.cc',
|
||||
'../../src/deoptimizer.cc',
|
||||
'../../src/deoptimizer.h',
|
||||
'../../src/disasm.h',
|
||||
|
Loading…
Reference in New Issue
Block a user