
This has been enabled by default since 2022: https://chromium-review.googlesource.com/c/chromium/src/+/3999284 Let's enforce it by default without the flag, but allow the switches to modify the limits if needed. Fixed: 356623897 Change-Id: I0f36a1cfc72fc5bef92cb916079a9085e6d8cd56 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6097690 Reviewed-by: Arthur Sonzogni <arthursonzogni@chromium.org> Commit-Queue: Arthur Sonzogni <arthursonzogni@chromium.org> Auto-Submit: Ari Chivukula <arichiv@chromium.org> Reviewed-by: Benoit Lize <lizeb@chromium.org> Cr-Commit-Position: refs/heads/main@{#1397224}
72 lines
2.4 KiB
C++
72 lines
2.4 KiB
C++
// Copyright 2018 The Chromium Authors
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "content/common/skia_utils.h"
|
|
|
|
#include "base/command_line.h"
|
|
#include "base/feature_list.h"
|
|
#include "base/strings/string_number_conversions.h"
|
|
#include "base/system/sys_info.h"
|
|
#include "base/trace_event/memory_dump_manager.h"
|
|
#include "build/build_config.h"
|
|
#include "content/public/common/content_switches.h"
|
|
#include "skia/ext/event_tracer_impl.h"
|
|
#include "skia/ext/skia_memory_dump_provider.h"
|
|
#include "third_party/skia/include/core/SkGraphics.h"
|
|
|
|
namespace content {
|
|
namespace {
|
|
|
|
// Maximum allocation size allowed for image scaling filters that
|
|
// require pre-scaling. Skia will fallback to a filter that doesn't
|
|
// require pre-scaling if the default filter would require an
|
|
// allocation that exceeds this limit.
|
|
const size_t kImageCacheSingleAllocationByteLimit = 64 * 1024 * 1024;
|
|
|
|
} // namespace
|
|
|
|
void InitializeSkia() {
|
|
// Make sure that any switches used here are propagated to the renderer and
|
|
// GPU processes.
|
|
const base::CommandLine& cmd = *base::CommandLine::ForCurrentProcess();
|
|
if (!cmd.HasSwitch(switches::kDisableSkiaRuntimeOpts)) {
|
|
SkGraphics::Init();
|
|
}
|
|
|
|
const int kMB = 1024 * 1024;
|
|
|
|
// Could also reduce the maximum number of cached strikes, but the intent
|
|
// being to reduce memory usage, only control cache memory usage.
|
|
SkGraphics::SetFontCacheLimit(kMB);
|
|
|
|
#if !BUILDFLAG(IS_ANDROID)
|
|
size_t font_cache_limit;
|
|
if (cmd.HasSwitch(switches::kSkiaFontCacheLimitMb)) {
|
|
if (base::StringToSizeT(
|
|
cmd.GetSwitchValueASCII(switches::kSkiaFontCacheLimitMb),
|
|
&font_cache_limit)) {
|
|
SkGraphics::SetFontCacheLimit(font_cache_limit * kMB);
|
|
}
|
|
}
|
|
|
|
size_t resource_cache_limit;
|
|
if (cmd.HasSwitch(switches::kSkiaResourceCacheLimitMb)) {
|
|
if (base::StringToSizeT(
|
|
cmd.GetSwitchValueASCII(switches::kSkiaResourceCacheLimitMb),
|
|
&resource_cache_limit)) {
|
|
SkGraphics::SetResourceCacheTotalByteLimit(resource_cache_limit * kMB);
|
|
}
|
|
}
|
|
#endif
|
|
|
|
InitSkiaEventTracer();
|
|
base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider(
|
|
skia::SkiaMemoryDumpProvider::GetInstance(), "Skia", nullptr);
|
|
|
|
SkGraphics::SetResourceCacheSingleAllocationByteLimit(
|
|
kImageCacheSingleAllocationByteLimit);
|
|
}
|
|
|
|
} // namespace content
|