skia2/include/core/SkTraceMemoryDump.h
Derek Sollenberger 2da31edf76 Add ability to trace wrapped objects and be able to differentiate
the wrapped from unwrapped items.

Bug: b/182142615
Change-Id: Ic76157ab360b977db9c063e9536dd520992c2a03
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/393596
Commit-Queue: Derek Sollenberger <djsollen@google.com>
Reviewed-by: Greg Daniel <egdaniel@google.com>
Reviewed-by: Brian Salomon <bsalomon@google.com>
2021-04-08 18:38:14 +00:00

100 lines
3.7 KiB
C++

/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkTraceMemoryDump_DEFINED
#define SkTraceMemoryDump_DEFINED
#include "include/core/SkTypes.h"
class SkDiscardableMemory;
/**
* Interface for memory tracing.
* This interface is meant to be passed as argument to the memory dump methods of Skia objects.
* The implementation of this interface is provided by the embedder.
*/
class SK_API SkTraceMemoryDump {
public:
/**
* Enum to specify the level of the requested details for the dump from the Skia objects.
*/
enum LevelOfDetail {
// Dump only the minimal details to get the total memory usage (Usually just the totals).
kLight_LevelOfDetail,
// Dump the detailed breakdown of the objects in the caches.
kObjectsBreakdowns_LevelOfDetail
};
/**
* Appends a new memory dump (i.e. a row) to the trace memory infrastructure.
* If dumpName does not exist yet, a new one is created. Otherwise, a new column is appended to
* the previously created dump.
* Arguments:
* dumpName: an absolute, slash-separated, name for the item being dumped
* e.g., "skia/CacheX/EntryY".
* valueName: a string indicating the name of the column.
* e.g., "size", "active_size", "number_of_objects".
* This string is supposed to be long lived and is NOT copied.
* units: a string indicating the units for the value.
* e.g., "bytes", "objects".
* This string is supposed to be long lived and is NOT copied.
* value: the actual value being dumped.
*/
virtual void dumpNumericValue(const char* dumpName,
const char* valueName,
const char* units,
uint64_t value) = 0;
virtual void dumpStringValue(const char* /*dumpName*/,
const char* /*valueName*/,
const char* /*value*/) { }
/**
* Sets the memory backing for an existing dump.
* backingType and backingObjectId are used by the embedder to associate the memory dumped via
* dumpNumericValue with the corresponding dump that backs the memory.
*/
virtual void setMemoryBacking(const char* dumpName,
const char* backingType,
const char* backingObjectId) = 0;
/**
* Specialization for memory backed by discardable memory.
*/
virtual void setDiscardableMemoryBacking(
const char* dumpName,
const SkDiscardableMemory& discardableMemoryObject) = 0;
/**
* Returns the type of details requested in the dump. The granularity of the dump is supposed to
* match the LevelOfDetail argument. The level of detail must not affect the total size
* reported, but only granularity of the child entries.
*/
virtual LevelOfDetail getRequestedDetails() const = 0;
/**
* Returns true if we should dump wrapped objects. Wrapped objects come from outside Skia, and
* may be independently tracked there.
*/
virtual bool shouldDumpWrappedObjects() const { return true; }
/**
* If shouldDumpWrappedObjects() returns true then this function will be called to populate
* the output with information on whether the item being dumped is a wrapped object.
*/
virtual void dumpWrappedState(const char* /*dumpName*/, bool /*isWrappedObject*/) {}
protected:
virtual ~SkTraceMemoryDump() = default;
SkTraceMemoryDump() = default;
SkTraceMemoryDump(const SkTraceMemoryDump&) = delete;
SkTraceMemoryDump& operator=(const SkTraceMemoryDump&) = delete;
};
#endif