2015-08-20 15:00:32 +00:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkTypes.h"
|
2015-08-20 15:00:32 +00:00
|
|
|
|
|
|
|
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:
|
2015-09-30 11:31:23 +00:00
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
};
|
|
|
|
|
2015-08-20 15:00:32 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2018-03-29 17:40:02 +00:00
|
|
|
virtual void dumpStringValue(const char* /*dumpName*/,
|
|
|
|
const char* /*valueName*/,
|
|
|
|
const char* /*value*/) { }
|
|
|
|
|
2015-08-20 15:00:32 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2015-09-30 11:31:23 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2018-03-19 20:04:03 +00:00
|
|
|
/**
|
|
|
|
* 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; }
|
|
|
|
|
2015-08-20 15:00:32 +00:00
|
|
|
protected:
|
2021-01-26 19:29:06 +00:00
|
|
|
virtual ~SkTraceMemoryDump() = default;
|
|
|
|
SkTraceMemoryDump() = default;
|
|
|
|
SkTraceMemoryDump(const SkTraceMemoryDump&) = delete;
|
|
|
|
SkTraceMemoryDump& operator=(const SkTraceMemoryDump&) = delete;
|
2015-08-20 15:00:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|