• kaznacheev@chromium.org's avatar
    Dynamically determine optimal instance size. · 06c86740
    kaznacheev@chromium.org authored
    The number of inobject properties used to be derived from the number
    of this property assignments in the constructor (and increased by 2 to
    allow for properties added later). This very often leads to wasted inobject 
    slots.
    
    This patch reclaims some of the unused inobject space by the following method:
     - for each constructor function the first several objects are allocated using the initial 
       ("generous) instance size estimation (this is called 'tracking phase').
     - during the tracking phase map transitions are tracked and actual property counts are collected.
     - at the end of the tracking phase instance sizes in the maps are decreased if necessary
       (starting with the function's initial map and traversing the transition tree).
     - all further allocation use more realistic instance size estimation.
    
    Shrinking generously allocated objects without costly heap traversal is made possible 
    by initializing their inobject properties with one_pointer_filler_map (instead of undefined). 
    
    The initial slack for the generous allocation is increased from 2 to 6 which really helps some tests.
    
    Review URL: http://codereview.chromium.org/3329019
    
    git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@5510 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
    06c86740
Name
Last commit
Last update
..
SConscript Loading commit data...
cctest.cc Loading commit data...
cctest.h Loading commit data...
cctest.status Loading commit data...
gay-fixed.cc Loading commit data...
gay-fixed.h Loading commit data...
gay-precision.cc Loading commit data...
gay-precision.h Loading commit data...
gay-shortest.cc Loading commit data...
gay-shortest.h Loading commit data...
test-accessors.cc Loading commit data...
test-alloc.cc Loading commit data...
test-api.cc Loading commit data...
test-assembler-arm.cc Loading commit data...
test-assembler-ia32.cc Loading commit data...
test-assembler-mips.cc Loading commit data...
test-assembler-x64.cc Loading commit data...
test-ast.cc Loading commit data...
test-circular-queue.cc Loading commit data...
test-compiler.cc Loading commit data...
test-conversions.cc Loading commit data...
test-cpu-profiler.cc Loading commit data...
test-dataflow.cc Loading commit data...
test-debug.cc Loading commit data...
test-decls.cc Loading commit data...
test-disasm-arm.cc Loading commit data...
test-disasm-ia32.cc Loading commit data...
test-diy-fp.cc Loading commit data...
test-double.cc Loading commit data...
test-fast-dtoa.cc Loading commit data...
test-fixed-dtoa.cc Loading commit data...
test-flags.cc Loading commit data...
test-func-name-inference.cc Loading commit data...
test-hashmap.cc Loading commit data...
test-heap-profiler.cc Loading commit data...
test-heap.cc Loading commit data...
test-list.cc Loading commit data...
test-liveedit.cc Loading commit data...
test-lock.cc Loading commit data...
test-log-stack-tracer.cc Loading commit data...
test-log-utils.cc Loading commit data...
test-log.cc Loading commit data...
test-macro-assembler-x64.cc Loading commit data...
test-mark-compact.cc Loading commit data...
test-mips.cc Loading commit data...
test-parsing.cc Loading commit data...
test-platform-linux.cc Loading commit data...
test-platform-macos.cc Loading commit data...
test-platform-nullos.cc Loading commit data...
test-platform-win32.cc Loading commit data...
test-profile-generator.cc Loading commit data...
test-regexp.cc Loading commit data...
test-serialize.cc Loading commit data...
test-sockets.cc Loading commit data...
test-spaces.cc Loading commit data...
test-strings.cc Loading commit data...
test-thread-termination.cc Loading commit data...
test-threads.cc Loading commit data...
test-type-info.cc Loading commit data...
test-unbound-queue.cc Loading commit data...
test-utils.cc Loading commit data...
test-version.cc Loading commit data...
testcfg.py Loading commit data...