2021-02-11 13:57:15 +00:00
|
|
|
// Copyright 2021 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_STATISTICS_H_
|
|
|
|
#define INCLUDE_CPPGC_HEAP_STATISTICS_H_
|
|
|
|
|
2021-05-20 09:36:52 +00:00
|
|
|
#include <cstddef>
|
|
|
|
#include <cstdint>
|
2021-02-11 13:57:15 +00:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace cppgc {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* `HeapStatistics` contains memory consumption and utilization statistics for a
|
|
|
|
* cppgc heap.
|
|
|
|
*/
|
|
|
|
struct HeapStatistics final {
|
|
|
|
/**
|
|
|
|
* Specifies the detail level of the heap statistics. Brief statistics contain
|
|
|
|
* only the top-level allocated and used memory statistics for the entire
|
|
|
|
* heap. Detailed statistics also contain a break down per space and page, as
|
|
|
|
* well as freelist statistics and object type histograms. Note that used
|
|
|
|
* memory reported by brief statistics and detailed statistics might differ
|
|
|
|
* slightly.
|
|
|
|
*/
|
|
|
|
enum DetailLevel : uint8_t {
|
|
|
|
kBrief,
|
|
|
|
kDetailed,
|
|
|
|
};
|
|
|
|
|
2021-07-08 18:38:24 +00:00
|
|
|
/**
|
|
|
|
* Object statistics for a single type.
|
|
|
|
*/
|
|
|
|
struct ObjectStatsEntry {
|
|
|
|
/**
|
|
|
|
* Number of allocated bytes.
|
|
|
|
*/
|
|
|
|
size_t allocated_bytes;
|
|
|
|
/**
|
|
|
|
* Number of allocated objects.
|
|
|
|
*/
|
|
|
|
size_t object_count;
|
|
|
|
};
|
|
|
|
|
2021-02-11 13:57:15 +00:00
|
|
|
/**
|
|
|
|
* Page granularity statistics. For each page the statistics record the
|
|
|
|
* allocated memory size and overall used memory size for the page.
|
|
|
|
*/
|
|
|
|
struct PageStatistics {
|
2021-07-07 20:37:27 +00:00
|
|
|
/** Overall committed amount of memory for the page. */
|
|
|
|
size_t committed_size_bytes = 0;
|
|
|
|
/** Resident amount of memory held by the page. */
|
|
|
|
size_t resident_size_bytes = 0;
|
2021-02-11 13:57:15 +00:00
|
|
|
/** Amount of memory actually used on the page. */
|
|
|
|
size_t used_size_bytes = 0;
|
2021-07-08 18:38:24 +00:00
|
|
|
/** Statistics for object allocated on the page. Filled only when
|
|
|
|
* NameProvider::HideInternalNames() is false. */
|
|
|
|
std::vector<ObjectStatsEntry> object_statistics;
|
2021-02-11 13:57:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2021-05-07 12:16:57 +00:00
|
|
|
* Statistics of the freelist (used only in non-large object spaces). For
|
2021-02-11 13:57:15 +00:00
|
|
|
* each bucket in the freelist the statistics record the bucket size, the
|
|
|
|
* number of freelist entries in the bucket, and the overall allocated memory
|
|
|
|
* consumed by these freelist entries.
|
|
|
|
*/
|
|
|
|
struct FreeListStatistics {
|
|
|
|
/** bucket sizes in the freelist. */
|
|
|
|
std::vector<size_t> bucket_size;
|
|
|
|
/** number of freelist entries per bucket. */
|
|
|
|
std::vector<size_t> free_count;
|
2021-05-07 12:16:57 +00:00
|
|
|
/** memory size consumed by freelist entries per size. */
|
2021-02-11 13:57:15 +00:00
|
|
|
std::vector<size_t> free_size;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Space granularity statistics. For each space the statistics record the
|
|
|
|
* space name, the amount of allocated memory and overall used memory for the
|
|
|
|
* space. The statistics also contain statistics for each of the space's
|
|
|
|
* pages, its freelist and the objects allocated on the space.
|
|
|
|
*/
|
|
|
|
struct SpaceStatistics {
|
|
|
|
/** The space name */
|
|
|
|
std::string name;
|
2021-07-07 20:37:27 +00:00
|
|
|
/** Overall committed amount of memory for the heap. */
|
|
|
|
size_t committed_size_bytes = 0;
|
|
|
|
/** Resident amount of memory held by the heap. */
|
|
|
|
size_t resident_size_bytes = 0;
|
2021-02-11 13:57:15 +00:00
|
|
|
/** Amount of memory actually used on the space. */
|
|
|
|
size_t used_size_bytes = 0;
|
|
|
|
/** Statistics for each of the pages in the space. */
|
|
|
|
std::vector<PageStatistics> page_stats;
|
|
|
|
/** Statistics for the freelist of the space. */
|
|
|
|
FreeListStatistics free_list_stats;
|
|
|
|
};
|
|
|
|
|
2021-07-07 20:37:27 +00:00
|
|
|
/** Overall committed amount of memory for the heap. */
|
|
|
|
size_t committed_size_bytes = 0;
|
|
|
|
/** Resident amount of memory help by the heap. */
|
|
|
|
size_t resident_size_bytes = 0;
|
2021-02-11 13:57:15 +00:00
|
|
|
/** Amount of memory actually used on the heap. */
|
|
|
|
size_t used_size_bytes = 0;
|
|
|
|
/** Detail level of this HeapStatistics. */
|
|
|
|
DetailLevel detail_level;
|
|
|
|
|
|
|
|
/** Statistics for each of the spaces in the heap. Filled only when
|
2021-07-07 20:37:27 +00:00
|
|
|
* `detail_level` is `DetailLevel::kDetailed`. */
|
2021-02-11 13:57:15 +00:00
|
|
|
std::vector<SpaceStatistics> space_stats;
|
2021-07-07 20:37:27 +00:00
|
|
|
|
|
|
|
/**
|
2021-07-08 18:38:24 +00:00
|
|
|
* Vector of `cppgc::GarbageCollected` type names.
|
2021-07-07 20:37:27 +00:00
|
|
|
*/
|
|
|
|
std::vector<std::string> type_names;
|
2021-02-11 13:57:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace cppgc
|
|
|
|
|
|
|
|
#endif // INCLUDE_CPPGC_HEAP_STATISTICS_H_
|