1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35
   36
   37
   38
   39
   40
   41
   42
   43
   44
   45
   46
   47
   48
   49
   50
   51
   52
   53
   54
   55
   56
   57
   58
   59
   60
   61
   62
   63
   64
   65
   66
   67
   68
   69
   70
   71
   72
   73
   74
   75
   76
   77
   78
   79
   80
   81
   82
   83
   84
   85
   86
   87
   88
   89
   90
   91
   92
   93
   94
   95
   96
   97
   98
   99
  100
  101
  102
  103
  104
  105
  106
  107
  108
  109
  110
  111
  112

gpu / config / skia_limits.cc [blame]

// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "gpu/config/skia_limits.h"

#include <inttypes.h>

#include "base/system/sys_info.h"
#include "build/build_config.h"
#include "components/miracle_parameter/common/public/miracle_parameter.h"

namespace gpu {

namespace {

BASE_FEATURE(kGrCacheLimitsFeature,
             "GrCacheLimitsFeature",
             base::FEATURE_ENABLED_BY_DEFAULT);

MIRACLE_PARAMETER_FOR_INT(GetMaxGaneshResourceCacheBytes,
                          kGrCacheLimitsFeature,
                          "MaxGaneshResourceCacheBytes",
                          96 * 1024 * 1024)

MIRACLE_PARAMETER_FOR_INT(GetMaxDefaultGlyphCacheTextureBytes,
                          kGrCacheLimitsFeature,
                          "MaxDefaultGlyphCacheTextureBytes",
                          2048 * 1024 * 4)

#if !BUILDFLAG(IS_NACL)
// The limit of the bytes allocated toward GPU resources in the GrContext's
// GPU cache.
MIRACLE_PARAMETER_FOR_INT(GetMaxLowEndGaneshResourceCacheBytes,
                          kGrCacheLimitsFeature,
                          "MaxLowEndGaneshResourceCacheBytes",
                          48 * 1024 * 1024)

MIRACLE_PARAMETER_FOR_INT(GetMaxHighEndGaneshResourceCacheBytes,
                          kGrCacheLimitsFeature,
                          "MaxHighEndGaneshResourceCacheBytes",
                          256 * 1024 * 1024)

// Limits for glyph cache textures.
MIRACLE_PARAMETER_FOR_INT(GetMaxLowEndGlyphCacheTextureBytes,
                          kGrCacheLimitsFeature,
                          "MaxLowEndGlyphCacheTextureBytes",
                          1024 * 512 * 4)

// High-end / low-end memory cutoffs.
MIRACLE_PARAMETER_FOR_INT(GetHighEndMemoryThresholdMB,
                          kGrCacheLimitsFeature,
                          "HighEndMemoryThresholdMB",
                          4096)
#endif

// Limits for the Graphite client image provider which is responsible for
// uploading non-GPU backed images (e.g. raster, lazy/generated) to Graphite.
// The limits are smallish since only a small number of images take this path
// instead of being uploaded via the transfer cache.
MIRACLE_PARAMETER_FOR_INT(GetMaxGpuMainGraphiteImageProviderBytes,
                          kGrCacheLimitsFeature,
                          "MaxGpuMainGraphiteImageProviderBytes",
                          16 * 1024 * 1024)

// The limits for the Viz compositor's image provider are even smaller since
// the only time we encounter such images is via reference image filters on
// composited layers which is a pretty uncommon case.
MIRACLE_PARAMETER_FOR_INT(GetMaxVizCompositorGraphiteImageProviderBytes,
                          kGrCacheLimitsFeature,
                          "MaxVizCompositorGraphiteImageProviderBytes",
                          4 * 1024 * 1024)

}  // namespace

void DetermineGraphiteImageProviderCacheLimits(
    size_t* max_gpu_main_image_provider_cache_bytes,
    size_t* max_viz_compositor_image_provider_cache_bytes) {
  *max_gpu_main_image_provider_cache_bytes =
      GetMaxGpuMainGraphiteImageProviderBytes();
  *max_viz_compositor_image_provider_cache_bytes =
      GetMaxVizCompositorGraphiteImageProviderBytes();
}

void DetermineGrCacheLimitsFromAvailableMemory(
    size_t* max_resource_cache_bytes,
    size_t* max_glyph_cache_texture_bytes) {
  // Default limits.
  *max_resource_cache_bytes = GetMaxGaneshResourceCacheBytes();
  *max_glyph_cache_texture_bytes = GetMaxDefaultGlyphCacheTextureBytes();

// We can't call AmountOfPhysicalMemory under NACL, so leave the default.
#if !BUILDFLAG(IS_NACL)
  if (base::SysInfo::IsLowEndDevice()) {
    *max_resource_cache_bytes = GetMaxLowEndGaneshResourceCacheBytes();
    *max_glyph_cache_texture_bytes = GetMaxLowEndGlyphCacheTextureBytes();
  } else if (base::SysInfo::AmountOfPhysicalMemoryMB() >=
             GetHighEndMemoryThresholdMB()) {
    *max_resource_cache_bytes = GetMaxHighEndGaneshResourceCacheBytes();
  }
#endif
}

void DefaultGrCacheLimitsForTests(size_t* max_resource_cache_bytes,
                                  size_t* max_glyph_cache_texture_bytes) {
  constexpr size_t kDefaultGlyphCacheTextureBytes = 2048 * 1024 * 4;
  constexpr size_t kDefaultGaneshResourceCacheBytes = 96 * 1024 * 1024;
  *max_resource_cache_bytes = kDefaultGaneshResourceCacheBytes;
  *max_glyph_cache_texture_bytes = kDefaultGlyphCacheTextureBytes;
}

}  // namespace gpu