2020-03-27 10:02:58 +00:00
|
|
|
// 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_
|
|
|
|
|
2021-05-20 09:36:52 +00:00
|
|
|
#include <cstddef>
|
|
|
|
#include <cstdint>
|
2020-03-27 10:02:58 +00:00
|
|
|
#include <memory>
|
2020-05-07 20:36:03 +00:00
|
|
|
#include <vector>
|
2020-03-27 10:02:58 +00:00
|
|
|
|
2020-05-12 11:09:49 +00:00
|
|
|
#include "cppgc/common.h"
|
2020-05-07 20:36:03 +00:00
|
|
|
#include "cppgc/custom-space.h"
|
2020-05-28 19:04:43 +00:00
|
|
|
#include "cppgc/platform.h"
|
2020-04-27 16:29:03 +00:00
|
|
|
#include "v8config.h" // NOLINT(build/include_directory)
|
2020-03-27 10:02:58 +00:00
|
|
|
|
2020-05-27 13:32:18 +00:00
|
|
|
/**
|
|
|
|
* cppgc - A C++ garbage collection library.
|
|
|
|
*/
|
2020-03-27 10:02:58 +00:00
|
|
|
namespace cppgc {
|
2020-05-27 13:32:18 +00:00
|
|
|
|
2020-06-10 22:28:41 +00:00
|
|
|
class AllocationHandle;
|
|
|
|
|
2020-06-15 17:23:19 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2020-03-27 10:02:58 +00:00
|
|
|
namespace internal {
|
|
|
|
class Heap;
|
|
|
|
} // namespace internal
|
|
|
|
|
2020-11-24 11:52:42 +00:00
|
|
|
/**
|
|
|
|
* Used for additional heap APIs.
|
|
|
|
*/
|
|
|
|
class HeapHandle;
|
|
|
|
|
2020-03-27 10:02:58 +00:00
|
|
|
class V8_EXPORT Heap {
|
|
|
|
public:
|
2020-05-06 16:02:01 +00:00
|
|
|
/**
|
|
|
|
* Specifies the stack state the embedder is in.
|
|
|
|
*/
|
2020-05-12 11:09:49 +00:00
|
|
|
using StackState = EmbedderStackState;
|
2020-05-06 16:02:01 +00:00
|
|
|
|
2020-06-08 09:53:26 +00:00
|
|
|
/**
|
|
|
|
* 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,
|
|
|
|
};
|
|
|
|
|
2020-12-10 15:03:54 +00:00
|
|
|
/**
|
|
|
|
* 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,
|
|
|
|
/**
|
2022-03-01 16:24:57 +00:00
|
|
|
* Incremental marking interleaves marking with the rest of the application
|
|
|
|
* workload on the same thread.
|
2020-12-10 15:03:54 +00:00
|
|
|
*/
|
|
|
|
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,
|
2022-03-01 16:24:57 +00:00
|
|
|
/**
|
|
|
|
* Incremental sweeping interleaves sweeping with the rest of the
|
|
|
|
* application workload on the same thread.
|
|
|
|
*/
|
|
|
|
kIncremental,
|
2020-12-10 15:03:54 +00:00
|
|
|
/**
|
|
|
|
* Incremental and concurrent sweeping. Sweeping is split and interleaved
|
|
|
|
* with the rest of the application.
|
|
|
|
*/
|
|
|
|
kIncrementalAndConcurrent
|
|
|
|
};
|
|
|
|
|
2020-06-08 09:53:26 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
};
|
|
|
|
|
2020-05-27 13:32:18 +00:00
|
|
|
/**
|
|
|
|
* Options specifying Heap properties (e.g. custom spaces) when initializing a
|
2020-10-19 08:12:55 +00:00
|
|
|
* heap through `Heap::Create()`.
|
2020-05-27 13:32:18 +00:00
|
|
|
*/
|
2020-05-07 20:36:03 +00:00
|
|
|
struct HeapOptions {
|
2020-05-27 13:32:18 +00:00
|
|
|
/**
|
|
|
|
* Creates reasonable defaults for instantiating a Heap.
|
|
|
|
*
|
2020-10-19 08:12:55 +00:00
|
|
|
* \returns the HeapOptions that can be passed to `Heap::Create()`.
|
2020-05-27 13:32:18 +00:00
|
|
|
*/
|
2020-05-07 20:36:03 +00:00
|
|
|
static HeapOptions Default() { return {}; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Custom spaces added to heap are required to have indices forming a
|
2020-10-19 08:12:55 +00:00
|
|
|
* numbered sequence starting at 0, i.e., their `kSpaceIndex` must
|
|
|
|
* correspond to the index they reside in the vector.
|
2020-05-07 20:36:03 +00:00
|
|
|
*/
|
|
|
|
std::vector<std::unique_ptr<CustomSpaceBase>> custom_spaces;
|
2020-06-08 09:53:26 +00:00
|
|
|
|
|
|
|
/**
|
2020-09-01 22:17:30 +00:00
|
|
|
* Specifies whether conservative stack scan is supported. When conservative
|
2020-06-08 09:53:26 +00:00
|
|
|
* 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
|
2020-10-19 08:12:55 +00:00
|
|
|
* the GC through `ForceGarbageCollectionSlow()`.
|
2020-06-08 09:53:26 +00:00
|
|
|
*/
|
|
|
|
StackSupport stack_support = StackSupport::kSupportsConservativeStackScan;
|
|
|
|
|
2020-12-10 15:03:54 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2020-06-08 09:53:26 +00:00
|
|
|
/**
|
|
|
|
* Resource constraints specifying various properties that the internal
|
|
|
|
* GC scheduler follows.
|
|
|
|
*/
|
|
|
|
ResourceConstraints resource_constraints;
|
2020-05-07 20:36:03 +00:00
|
|
|
};
|
|
|
|
|
2020-05-27 13:32:18 +00:00
|
|
|
/**
|
|
|
|
* Creates a new heap that can be used for object allocation.
|
|
|
|
*
|
2020-05-28 19:04:43 +00:00
|
|
|
* \param platform implemented and provided by the embedder.
|
2020-05-27 13:32:18 +00:00
|
|
|
* \param options HeapOptions specifying various properties for the Heap.
|
|
|
|
* \returns a new Heap instance.
|
|
|
|
*/
|
|
|
|
static std::unique_ptr<Heap> Create(
|
2020-05-28 19:04:43 +00:00
|
|
|
std::shared_ptr<Platform> platform,
|
2020-05-27 13:32:18 +00:00
|
|
|
HeapOptions options = HeapOptions::Default());
|
2020-03-27 10:02:58 +00:00
|
|
|
|
|
|
|
virtual ~Heap() = default;
|
|
|
|
|
2020-05-06 16:02:01 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2020-05-07 12:16:20 +00:00
|
|
|
void ForceGarbageCollectionSlow(
|
|
|
|
const char* source, const char* reason,
|
2020-05-12 11:09:49 +00:00
|
|
|
StackState stack_state = StackState::kMayContainHeapPointers);
|
2020-05-06 16:02:01 +00:00
|
|
|
|
2020-10-19 08:12:55 +00:00
|
|
|
/**
|
|
|
|
* \returns the opaque handle for allocating objects using
|
|
|
|
* `MakeGarbageCollected()`.
|
|
|
|
*/
|
2020-06-10 22:28:41 +00:00
|
|
|
AllocationHandle& GetAllocationHandle();
|
|
|
|
|
2020-11-24 11:52:42 +00:00
|
|
|
/**
|
|
|
|
* \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();
|
|
|
|
|
2020-03-27 10:02:58 +00:00
|
|
|
private:
|
|
|
|
Heap() = default;
|
|
|
|
|
|
|
|
friend class internal::Heap;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace cppgc
|
|
|
|
|
|
|
|
#endif // INCLUDE_CPPGC_HEAP_H_
|