OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef V8_HEAP_HEAP_H_ | 5 #ifndef V8_HEAP_HEAP_H_ |
6 #define V8_HEAP_HEAP_H_ | 6 #define V8_HEAP_HEAP_H_ |
7 | 7 |
8 #include <cmath> | 8 #include <cmath> |
9 #include <map> | 9 #include <map> |
10 | 10 |
11 // Clients of this interface shouldn't depend on lots of heap internals. | 11 // Clients of this interface shouldn't depend on lots of heap internals. |
12 // Do not include anything from src/heap here! | 12 // Do not include anything from src/heap here! |
13 #include "include/v8.h" | 13 #include "include/v8.h" |
14 #include "src/allocation.h" | 14 #include "src/allocation.h" |
15 #include "src/assert-scope.h" | 15 #include "src/assert-scope.h" |
16 #include "src/base/atomic-utils.h" | 16 #include "src/base/atomic-utils.h" |
17 #include "src/globals.h" | 17 #include "src/globals.h" |
18 #include "src/heap-symbols.h" | 18 #include "src/heap-symbols.h" |
19 // TODO(mstarzinger): One more include to kill! | 19 // TODO(mstarzinger): One more include to kill! |
20 #include "src/heap/spaces.h" | 20 #include "src/heap/spaces.h" |
21 #include "src/list.h" | 21 #include "src/list.h" |
22 | 22 |
23 namespace v8 { | 23 namespace v8 { |
24 namespace internal { | 24 namespace internal { |
25 | 25 |
26 class Heap; | |
27 AllocationResult TestCopyCode(Heap* heap, Code* code); | |
28 | |
26 using v8::MemoryPressureLevel; | 29 using v8::MemoryPressureLevel; |
27 | 30 |
28 // Defines all the roots in Heap. | 31 // Defines all the roots in Heap. |
29 #define STRONG_ROOT_LIST(V) \ | 32 #define STRONG_ROOT_LIST(V) \ |
30 /* Cluster the most popular ones in a few cache lines here at the top. */ \ | 33 /* Cluster the most popular ones in a few cache lines here at the top. */ \ |
31 /* The first 32 entries are most often used in the startup snapshot and */ \ | 34 /* The first 32 entries are most often used in the startup snapshot and */ \ |
32 /* can use a shorter representation in the serialization format. */ \ | 35 /* can use a shorter representation in the serialization format. */ \ |
33 V(Map, free_space_map, FreeSpaceMap) \ | 36 V(Map, free_space_map, FreeSpaceMap) \ |
34 V(Map, one_pointer_filler_map, OnePointerFillerMap) \ | 37 V(Map, one_pointer_filler_map, OnePointerFillerMap) \ |
35 V(Map, two_pointer_filler_map, TwoPointerFillerMap) \ | 38 V(Map, two_pointer_filler_map, TwoPointerFillerMap) \ |
(...skipping 1820 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1856 // Allocates a byte array of the specified length | 1859 // Allocates a byte array of the specified length |
1857 MUST_USE_RESULT AllocationResult | 1860 MUST_USE_RESULT AllocationResult |
1858 AllocateByteArray(int length, PretenureFlag pretenure = NOT_TENURED); | 1861 AllocateByteArray(int length, PretenureFlag pretenure = NOT_TENURED); |
1859 | 1862 |
1860 // Allocates a bytecode array with given contents. | 1863 // Allocates a bytecode array with given contents. |
1861 MUST_USE_RESULT AllocationResult | 1864 MUST_USE_RESULT AllocationResult |
1862 AllocateBytecodeArray(int length, const byte* raw_bytecodes, int frame_size, | 1865 AllocateBytecodeArray(int length, const byte* raw_bytecodes, int frame_size, |
1863 int parameter_count, FixedArray* constant_pool); | 1866 int parameter_count, FixedArray* constant_pool); |
1864 | 1867 |
1865 MUST_USE_RESULT AllocationResult CopyCode(Code* code); | 1868 MUST_USE_RESULT AllocationResult CopyCode(Code* code); |
1869 // The test function ofCopyCode in cctest/test-heap.cc. | |
1870 friend AllocationResult TestCopyCode(Heap* heap, Code* code); | |
Michael Lippautz
2016/08/02 19:07:57
No need to do that. Have a look at
test/cctest/h
ahaas
2016/08/03 08:47:42
Done.
| |
1866 | 1871 |
1867 MUST_USE_RESULT AllocationResult | 1872 MUST_USE_RESULT AllocationResult |
1868 CopyBytecodeArray(BytecodeArray* bytecode_array); | 1873 CopyBytecodeArray(BytecodeArray* bytecode_array); |
1869 | 1874 |
1870 // Allocates a fixed array initialized with undefined values | 1875 // Allocates a fixed array initialized with undefined values |
1871 MUST_USE_RESULT AllocationResult | 1876 MUST_USE_RESULT AllocationResult |
1872 AllocateFixedArray(int length, PretenureFlag pretenure = NOT_TENURED); | 1877 AllocateFixedArray(int length, PretenureFlag pretenure = NOT_TENURED); |
1873 | 1878 |
1874 // Allocate an uninitialized object. The memory is non-executable if the | 1879 // Allocate an uninitialized object. The memory is non-executable if the |
1875 // hardware and OS allow. This is the single choke-point for allocations | 1880 // hardware and OS allow. This is the single choke-point for allocations |
(...skipping 821 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2697 friend class LargeObjectSpace; | 2702 friend class LargeObjectSpace; |
2698 friend class NewSpace; | 2703 friend class NewSpace; |
2699 friend class PagedSpace; | 2704 friend class PagedSpace; |
2700 DISALLOW_COPY_AND_ASSIGN(AllocationObserver); | 2705 DISALLOW_COPY_AND_ASSIGN(AllocationObserver); |
2701 }; | 2706 }; |
2702 | 2707 |
2703 } // namespace internal | 2708 } // namespace internal |
2704 } // namespace v8 | 2709 } // namespace v8 |
2705 | 2710 |
2706 #endif // V8_HEAP_HEAP_H_ | 2711 #endif // V8_HEAP_HEAP_H_ |
OLD | NEW |