diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /gfx/gl/GfxTexturesReporter.cpp | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'gfx/gl/GfxTexturesReporter.cpp')
-rw-r--r-- | gfx/gl/GfxTexturesReporter.cpp | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/gfx/gl/GfxTexturesReporter.cpp b/gfx/gl/GfxTexturesReporter.cpp new file mode 100644 index 0000000000..bd169e0013 --- /dev/null +++ b/gfx/gl/GfxTexturesReporter.cpp @@ -0,0 +1,77 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#include <string> +#include <sstream> +#include "nsExceptionHandler.h" +#include "GfxTexturesReporter.h" +#include "mozilla/StaticPrefs_gfx.h" + +using namespace mozilla::gl; + +NS_IMPL_ISUPPORTS(GfxTexturesReporter, nsIMemoryReporter) + +mozilla::Atomic<size_t> GfxTexturesReporter::sAmount(0); +mozilla::Atomic<size_t> GfxTexturesReporter::sPeakAmount(0); +mozilla::Atomic<size_t> GfxTexturesReporter::sTileWasteAmount(0); + +static std::string FormatBytes(size_t amount) { + std::stringstream stream; + int depth = 0; + double val = amount; + while (val > 1024) { + val /= 1024; + depth++; + } + + const char* unit; + switch (depth) { + case 0: + unit = "bytes"; + break; + case 1: + unit = "KB"; + break; + case 2: + unit = "MB"; + break; + case 3: + unit = "GB"; + break; + default: + unit = ""; + break; + } + + stream << val << " " << unit; + return stream.str(); +} + +/* static */ +void GfxTexturesReporter::UpdateAmount(MemoryUse action, size_t amount) { + if (action == MemoryFreed) { + MOZ_RELEASE_ASSERT( + amount <= sAmount, + "GFX: Current texture usage greater than update amount."); + sAmount -= amount; + + if (StaticPrefs::gfx_logging_texture_usage_enabled_AtStartup()) { + printf_stderr("Current texture usage: %s\n", + FormatBytes(sAmount).c_str()); + } + } else { + sAmount += amount; + if (sAmount > sPeakAmount) { + sPeakAmount.exchange(sAmount); + if (StaticPrefs::gfx_logging_peak_texture_usage_enabled_AtStartup()) { + printf_stderr("Peak texture usage: %s\n", + FormatBytes(sPeakAmount).c_str()); + } + } + } + + CrashReporter::AnnotateTexturesSize(sAmount); +} |