blob: e10dda990dec9e6b894bbd088025039eb552e7b9 [file] [log] [blame]
/*
* Copyright (C) 2022 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License"),
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#pragma once
#include "utils/TimeUtils.h"
namespace android::uirenderer {
// Values mirror those from ComponentCallbacks2.java
enum class TrimLevel {
COMPLETE = 80,
MODERATE = 60,
BACKGROUND = 40,
UI_HIDDEN = 20,
RUNNING_CRITICAL = 15,
RUNNING_LOW = 10,
RUNNING_MODERATE = 5,
};
enum class CacheTrimLevel {
ALL_CACHES = 0,
FONT_CACHE = 1,
RESOURCE_CACHE = 2,
};
struct MemoryPolicy {
// The initial scale factor applied to the display resolution. The default is 1, but
// lower values may be used to start with a smaller initial cache size. The cache will
// be adjusted if larger frames are actually rendered
float initialMaxSurfaceAreaScale = 1.0f;
// The foreground cache size multiplier. The surface area of the screen will be multiplied
// by this
float surfaceSizeMultiplier = 12.0f * 4.0f;
// How much of the foreground cache size should be preserved when going into the background
float backgroundRetentionPercent = 0.5f;
// How long after the last renderer goes away before the GPU context is released. A value
// of 0 means only drop the context on background TRIM signals
nsecs_t contextTimeout = 10_s;
// The minimum amount of time to hold onto items in the resource cache
// The actual time used will be the max of this & when frames were actually rendered
nsecs_t minimumResourceRetention = 10_s;
// The maximum amount of time to hold onto items in the resource cache
nsecs_t maximumResourceRetention = 100000_s;
// If false, use only TRIM_UI_HIDDEN to drive background cache limits;
// If true, use all signals (such as all contexts are stopped) to drive the limits
bool useAlternativeUiHidden = true;
// Whether or not to only purge scratch resources when triggering UI Hidden or background
// collection
bool purgeScratchOnly = true;
// EXPERIMENTAL: Whether or not to trigger releasing GPU context when all contexts are stopped
// WARNING: Enabling this option can lead to instability, see b/266626090
bool releaseContextOnStoppedOnly = false;
};
const MemoryPolicy& loadMemoryPolicy();
} // namespace android::uirenderer