PNG  IHDR* pHYs+ IDATx]n#; cdLb Ǚ[at¤_:uP}>!Usă cag޿ ֵNu`ݼTâabO7uL&y^wFٝA"l[|ŲHLN밪4*sG3|Dv}?+y߉{OuOAt4Jj.u]Gz*҉sP'VQKbA1u\`& Af;HWj hsO;ogTu uj7S3/QzUr&wS`M$X_L7r2;aE+ώ%vikDA:dR+%KzƉo>eOth$z%: :{WwaQ:wz%4foɹE[9<]#ERINƻv溂E%P1i01 |Jvҗ&{b?9g=^wζXn/lK::90KwrюO\!ջ3uzuGv^;騢wq<Iatv09:tt~hEG`v;3@MNZD.1]L:{ծI3`L(÷ba")Y.iljCɄae#I"1 `3*Bdz>j<fU40⨬%O$3cGt]j%Fߠ_twJ;ABU8vP3uEԑwQ V:h%))LfraqX-ۿX]v-\9I gl8tzX ]ecm)-cgʒ#Uw=Wlێn(0hPP/ӨtQ“&J35 $=]r1{tLuǮ*i0_;NƝ8;-vݏr8+U-kruȕYr0RnC]*ެ(M:]gE;{]tg(#ZJ9y>utRDRMdr9㪩̞zֹb<ģ&wzJM"iI( .ꮅX)Qw:9,i좜\Ԛi7&N0:asϓc];=ΗOӣ APqz93 y $)A*kVHZwBƺnWNaby>XMN*45~ղM6Nvm;A=jֲ.~1}(9`KJ/V F9[=`~[;sRuk]rєT!)iQO)Y$V ی ۤmzWz5IM Zb )ˆC`6 rRa}qNmUfDsWuˤV{ Pݝ'=Kֳbg,UҘVz2ﴻnjNgBb{? ߮tcsͻQuxVCIY۠:(V뺕 ٥2;t`@Fo{Z9`;]wMzU~%UA蛚dI vGq\r82iu +St`cR.6U/M9IENDB`// Copyright 2020 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. #ifndef INCLUDE_CPPGC_HEAP_H_ #define INCLUDE_CPPGC_HEAP_H_ #include #include #include #include #include "cppgc/common.h" #include "cppgc/custom-space.h" #include "cppgc/platform.h" #include "v8config.h" // NOLINT(build/include_directory) /** * cppgc - A C++ garbage collection library. */ namespace cppgc { class AllocationHandle; class HeapHandle; /** * Implementation details of cppgc. Those details are considered internal and * may change at any point in time without notice. Users should never rely on * the contents of this namespace. */ namespace internal { class Heap; } // namespace internal class V8_EXPORT Heap { public: /** * Specifies the stack state the embedder is in. */ using StackState = EmbedderStackState; /** * Specifies whether conservative stack scanning is supported. */ enum class StackSupport : uint8_t { /** * Conservative stack scan is supported. */ kSupportsConservativeStackScan, /** * Conservative stack scan is not supported. Embedders may use this option * when using custom infrastructure that is unsupported by the library. */ kNoConservativeStackScan, }; /** * Specifies supported marking types. */ enum class MarkingType : uint8_t { /** * Atomic stop-the-world marking. This option does not require any write * barriers but is the most intrusive in terms of jank. */ kAtomic, /** * Incremental marking interleaves marking with the rest of the application * workload on the same thread. */ kIncremental, /** * Incremental and concurrent marking. */ kIncrementalAndConcurrent }; /** * Specifies supported sweeping types. */ enum class SweepingType : uint8_t { /** * Atomic stop-the-world sweeping. All of sweeping is performed at once. */ kAtomic, /** * Incremental sweeping interleaves sweeping with the rest of the * application workload on the same thread. */ kIncremental, /** * Incremental and concurrent sweeping. Sweeping is split and interleaved * with the rest of the application. */ kIncrementalAndConcurrent }; /** * Constraints for a Heap setup. */ struct ResourceConstraints { /** * Allows the heap to grow to some initial size in bytes before triggering * garbage collections. This is useful when it is known that applications * need a certain minimum heap to run to avoid repeatedly invoking the * garbage collector when growing the heap. */ size_t initial_heap_size_bytes = 0; }; /** * Options specifying Heap properties (e.g. custom spaces) when initializing a * heap through `Heap::Create()`. */ struct HeapOptions { /** * Creates reasonable defaults for instantiating a Heap. * * \returns the HeapOptions that can be passed to `Heap::Create()`. */ static HeapOptions Default() { return {}; } /** * Custom spaces added to heap are required to have indices forming a * numbered sequence starting at 0, i.e., their `kSpaceIndex` must * correspond to the index they reside in the vector. */ std::vector> custom_spaces; /** * Specifies whether conservative stack scan is supported. When conservative * stack scan is not supported, the collector may try to invoke * garbage collections using non-nestable task, which are guaranteed to have * no interesting stack, through the provided Platform. If such tasks are * not supported by the Platform, the embedder must take care of invoking * the GC through `ForceGarbageCollectionSlow()`. */ StackSupport stack_support = StackSupport::kSupportsConservativeStackScan; /** * Specifies which types of marking are supported by the heap. */ MarkingType marking_support = MarkingType::kIncrementalAndConcurrent; /** * Specifies which types of sweeping are supported by the heap. */ SweepingType sweeping_support = SweepingType::kIncrementalAndConcurrent; /** * Resource constraints specifying various properties that the internal * GC scheduler follows. */ ResourceConstraints resource_constraints; }; /** * Creates a new heap that can be used for object allocation. * * \param platform implemented and provided by the embedder. * \param options HeapOptions specifying various properties for the Heap. * \returns a new Heap instance. */ static std::unique_ptr Create( std::shared_ptr platform, HeapOptions options = HeapOptions::Default()); virtual ~Heap() = default; /** * Forces garbage collection. * * \param source String specifying the source (or caller) triggering a * forced garbage collection. * \param reason String specifying the reason for the forced garbage * collection. * \param stack_state The embedder stack state, see StackState. */ void ForceGarbageCollectionSlow( const char* source, const char* reason, StackState stack_state = StackState::kMayContainHeapPointers); /** * \returns the opaque handle for allocating objects using * `MakeGarbageCollected()`. */ AllocationHandle& GetAllocationHandle(); /** * \returns the opaque heap handle which may be used to refer to this heap in * other APIs. Valid as long as the underlying `Heap` is alive. */ HeapHandle& GetHeapHandle(); private: Heap() = default; friend class internal::Heap; }; } // namespace cppgc #endif // INCLUDE_CPPGC_HEAP_H_