summaryrefslogtreecommitdiff
path: root/chromium/v8/src/heap/cppgc/gc-invoker.cc
diff options
context:
space:
mode:
authorAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-12 14:27:29 +0200
committerAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-13 09:35:20 +0000
commitc30a6232df03e1efbd9f3b226777b07e087a1122 (patch)
treee992f45784689f373bcc38d1b79a239ebe17ee23 /chromium/v8/src/heap/cppgc/gc-invoker.cc
parent7b5b123ac58f58ffde0f4f6e488bcd09aa4decd3 (diff)
downloadqtwebengine-chromium-85-based.tar.gz
BASELINE: Update Chromium to 85.0.4183.14085-based
Change-Id: Iaa42f4680837c57725b1344f108c0196741f6057 Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
Diffstat (limited to 'chromium/v8/src/heap/cppgc/gc-invoker.cc')
-rw-r--r--chromium/v8/src/heap/cppgc/gc-invoker.cc105
1 files changed, 105 insertions, 0 deletions
diff --git a/chromium/v8/src/heap/cppgc/gc-invoker.cc b/chromium/v8/src/heap/cppgc/gc-invoker.cc
new file mode 100644
index 00000000000..a1212d80523
--- /dev/null
+++ b/chromium/v8/src/heap/cppgc/gc-invoker.cc
@@ -0,0 +1,105 @@
+// 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.
+
+#include "src/heap/cppgc/gc-invoker.h"
+
+#include <memory>
+
+#include "include/cppgc/platform.h"
+#include "src/heap/cppgc/heap.h"
+#include "src/heap/cppgc/task-handle.h"
+
+namespace cppgc {
+namespace internal {
+
+class GCInvoker::GCInvokerImpl final : public GarbageCollector {
+ public:
+ GCInvokerImpl(GarbageCollector*, cppgc::Platform*, cppgc::Heap::StackSupport);
+ ~GCInvokerImpl();
+
+ GCInvokerImpl(const GCInvokerImpl&) = delete;
+ GCInvokerImpl& operator=(const GCInvokerImpl&) = delete;
+
+ void CollectGarbage(GarbageCollector::Config) final;
+ size_t epoch() const final { return collector_->epoch(); }
+
+ private:
+ class GCTask final : public cppgc::Task {
+ public:
+ using Handle = SingleThreadedHandle;
+
+ static Handle Post(GarbageCollector* collector, cppgc::TaskRunner* runner) {
+ auto task = std::make_unique<GCInvoker::GCInvokerImpl::GCTask>(collector);
+ auto handle = task->GetHandle();
+ runner->PostNonNestableTask(std::move(task));
+ return handle;
+ }
+
+ explicit GCTask(GarbageCollector* collector)
+ : collector_(collector), saved_epoch_(collector->epoch()) {}
+
+ private:
+ void Run() final {
+ if (handle_.IsCanceled() || (collector_->epoch() != saved_epoch_)) return;
+
+ collector_->CollectGarbage(
+ GarbageCollector::Config::PreciseAtomicConfig());
+ handle_.Cancel();
+ }
+
+ Handle GetHandle() { return handle_; }
+
+ GarbageCollector* collector_;
+ Handle handle_;
+ size_t saved_epoch_;
+ };
+
+ GarbageCollector* collector_;
+ cppgc::Platform* platform_;
+ cppgc::Heap::StackSupport stack_support_;
+ GCTask::Handle gc_task_handle_;
+};
+
+GCInvoker::GCInvokerImpl::GCInvokerImpl(GarbageCollector* collector,
+ cppgc::Platform* platform,
+ cppgc::Heap::StackSupport stack_support)
+ : collector_(collector),
+ platform_(platform),
+ stack_support_(stack_support) {}
+
+GCInvoker::GCInvokerImpl::~GCInvokerImpl() {
+ if (gc_task_handle_) {
+ gc_task_handle_.Cancel();
+ }
+}
+
+void GCInvoker::GCInvokerImpl::CollectGarbage(GarbageCollector::Config config) {
+ if ((config.stack_state ==
+ GarbageCollector::Config::StackState::kNoHeapPointers) ||
+ (stack_support_ ==
+ cppgc::Heap::StackSupport::kSupportsConservativeStackScan)) {
+ collector_->CollectGarbage(config);
+ } else if (platform_->GetForegroundTaskRunner()->NonNestableTasksEnabled()) {
+ if (!gc_task_handle_) {
+ gc_task_handle_ =
+ GCTask::Post(collector_, platform_->GetForegroundTaskRunner().get());
+ }
+ }
+}
+
+GCInvoker::GCInvoker(GarbageCollector* collector, cppgc::Platform* platform,
+ cppgc::Heap::StackSupport stack_support)
+ : impl_(std::make_unique<GCInvoker::GCInvokerImpl>(collector, platform,
+ stack_support)) {}
+
+GCInvoker::~GCInvoker() = default;
+
+void GCInvoker::CollectGarbage(GarbageCollector::Config config) {
+ impl_->CollectGarbage(config);
+}
+
+size_t GCInvoker::epoch() const { return impl_->epoch(); }
+
+} // namespace internal
+} // namespace cppgc