Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(119)

Unified Diff: src/compiler/zone-pool.h

Issue 2348303002: Replaced different means of zone pooling/reusing by one zone segment pool (Closed)
Patch Set: Added most recent changes from master Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/compiler/wasm-compiler.cc ('k') | src/compiler/zone-pool.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/compiler/zone-pool.h
diff --git a/src/compiler/zone-pool.h b/src/compiler/zone-pool.h
deleted file mode 100644
index 7a3fe75468046285d9647bf2ba538bcbaa5a0dc4..0000000000000000000000000000000000000000
--- a/src/compiler/zone-pool.h
+++ /dev/null
@@ -1,94 +0,0 @@
-// Copyright 2014 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 V8_COMPILER_ZONE_POOL_H_
-#define V8_COMPILER_ZONE_POOL_H_
-
-#include <map>
-#include <set>
-#include <vector>
-
-#include "src/zone/zone.h"
-
-namespace v8 {
-namespace internal {
-namespace compiler {
-
-class ZonePool final {
- public:
- class Scope final {
- public:
- explicit Scope(ZonePool* zone_pool)
- : zone_pool_(zone_pool), zone_(nullptr) {}
- ~Scope() { Destroy(); }
-
- Zone* zone() {
- if (zone_ == nullptr) zone_ = zone_pool_->NewEmptyZone();
- return zone_;
- }
- void Destroy() {
- if (zone_ != nullptr) zone_pool_->ReturnZone(zone_);
- zone_ = nullptr;
- }
-
- private:
- ZonePool* const zone_pool_;
- Zone* zone_;
- DISALLOW_COPY_AND_ASSIGN(Scope);
- };
-
- class StatsScope final {
- public:
- explicit StatsScope(ZonePool* zone_pool);
- ~StatsScope();
-
- size_t GetMaxAllocatedBytes();
- size_t GetCurrentAllocatedBytes();
- size_t GetTotalAllocatedBytes();
-
- private:
- friend class ZonePool;
- void ZoneReturned(Zone* zone);
-
- typedef std::map<Zone*, size_t> InitialValues;
-
- ZonePool* const zone_pool_;
- InitialValues initial_values_;
- size_t total_allocated_bytes_at_start_;
- size_t max_allocated_bytes_;
-
- DISALLOW_COPY_AND_ASSIGN(StatsScope);
- };
-
- explicit ZonePool(AccountingAllocator* allocator);
- ~ZonePool();
-
- size_t GetMaxAllocatedBytes();
- size_t GetTotalAllocatedBytes();
- size_t GetCurrentAllocatedBytes();
-
- private:
- Zone* NewEmptyZone();
- void ReturnZone(Zone* zone);
-
- static const size_t kMaxUnusedSize = 3;
- typedef std::vector<Zone*> Unused;
- typedef std::vector<Zone*> Used;
- typedef std::vector<StatsScope*> Stats;
-
- Unused unused_;
- Used used_;
- Stats stats_;
- size_t max_allocated_bytes_;
- size_t total_deleted_bytes_;
- AccountingAllocator* allocator_;
-
- DISALLOW_COPY_AND_ASSIGN(ZonePool);
-};
-
-} // namespace compiler
-} // namespace internal
-} // namespace v8
-
-#endif
« no previous file with comments | « src/compiler/wasm-compiler.cc ('k') | src/compiler/zone-pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698