Caches.cpp revision 441cc421b51377ec27bf97ed690c63aa5509ae90
1dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase/*
2dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * Copyright (C) 2010 The Android Open Source Project
3dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase *
4dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * Licensed under the Apache License, Version 2.0 (the "License");
5dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * you may not use this file except in compliance with the License.
6dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * You may obtain a copy of the License at
7dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase *
8dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase *      http://www.apache.org/licenses/LICENSE-2.0
9dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase *
10dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * Unless required by applicable law or agreed to in writing, software
11dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * distributed under the License is distributed on an "AS IS" BASIS,
12dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * See the License for the specific language governing permissions and
14dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase * limitations under the License.
15dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase */
16dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
17dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase#define LOG_TAG "OpenGLRenderer"
18dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
19dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase#include "Caches.h"
2065fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik
212dc236b2bae13b9a0ed9b3f7320502aecd7983b3Tom Hudson#include "GammaFontRenderer.h"
2209b7c91de73b59aa3f679b3ae3ba299f82ec9f8aRomain Guy#include "LayerRenderer.h"
2365fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include "Properties.h"
2465fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include "renderstate/RenderState.h"
2563d41abb40b3ce40d8b9bccb1cf186e8158a3687ztenghui#include "ShadowTessellator.h"
26d7db4d767246b41d44995acb93d03d220b53c748John Reck#include "utils/GLUtils.h"
2765fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik
2865fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include <utils/Log.h>
2965fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include <utils/String8.h>
30dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
31dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haasenamespace android {
32dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haasenamespace uirenderer {
33dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
3496a5c4c7bab6718524de7253da8309143ab48befChris CraikCaches* Caches::sInstance = nullptr;
3596a5c4c7bab6718524de7253da8309143ab48befChris Craik
36dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase///////////////////////////////////////////////////////////////////////////////
37bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy// Macros
38bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy///////////////////////////////////////////////////////////////////////////////
39bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
40bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy#if DEBUG_CACHE_FLUSH
415baa3a62a97544669fba6d65a11c07f252e654ddSteve Block    #define FLUSH_LOGD(...) ALOGD(__VA_ARGS__)
42bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy#else
43bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    #define FLUSH_LOGD(...)
44bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy#endif
45bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
46bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy///////////////////////////////////////////////////////////////////////////////
47dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase// Constructors/destructor
48dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase///////////////////////////////////////////////////////////////////////////////
49dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
5096a5c4c7bab6718524de7253da8309143ab48befChris CraikCaches::Caches(RenderState& renderState)
51117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik        : gradientCache(mExtensions)
52117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik        , patchCache(renderState)
53117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik        , programCache(mExtensions)
5444eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik        , dither(*this)
5596a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mRenderState(&renderState)
5696a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mInitialized(false) {
5796a5c4c7bab6718524de7253da8309143ab48befChris Craik    INIT_LOGD("Creating OpenGL renderer caches");
588ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    init();
59b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    initFont();
60dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    initConstraints();
61f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    initStaticProperties();
620f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    initExtensions();
63dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}
64dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
653b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guybool Caches::init() {
663b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    if (mInitialized) return false;
678ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
68fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck    ATRACE_NAME("Caches::init");
69fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck
70d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    mRegionMesh = nullptr;
716c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    mProgram = nullptr;
728ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
7354c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount = 0;
7454c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
7596a5c4c7bab6718524de7253da8309143ab48befChris Craik    patchCache.init();
763b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
778ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = true;
783b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
7944eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = new PixelBufferState();
8044eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = new TextureState();
818aa195d7081b889f3a7b1f426cbd8556377aae5eRomain Guy
823b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    return true;
838ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy}
848ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
85b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guyvoid Caches::initFont() {
86b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    fontRenderer = GammaFontRenderer::createRenderer();
87b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy}
88b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy
89dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initExtensions() {
903bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasDebugMarker()) {
91dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = glInsertEventMarkerEXT;
920f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
93ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        startMark = glPushGroupMarkerEXT;
94ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        endMark = glPopGroupMarkerEXT;
95dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    } else {
96dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = eventMarkNull;
97dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        startMark = startMarkNull;
98dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        endMark = endMarkNull;
99dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    }
100dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
101dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
102dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initConstraints() {
103dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    glGetIntegerv(GL_MAX_TEXTURE_SIZE, &maxTextureSize);
104dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
105dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
106f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guyvoid Caches::initStaticProperties() {
107f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    gpuPixelBuffersEnabled = false;
108f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
109f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    // OpenGL ES 3.0+ specific features
1107f4307668b10467ee39d41c7ea29cf1ff238a835Romain Guy    if (mExtensions.hasPixelBufferObjects()) {
111f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        char property[PROPERTY_VALUE_MAX];
112f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        if (property_get(PROPERTY_ENABLE_GPU_PIXEL_BUFFERS, property, "true") > 0) {
113f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy            gpuPixelBuffersEnabled = !strcmp(property, "true");
114f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        }
115f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    }
116f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy}
117f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
1188ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guyvoid Caches::terminate() {
1198ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    if (!mInitialized) return;
120441cc421b51377ec27bf97ed690c63aa5509ae90Sangkyu Lee    mRegionMesh.reset(nullptr);
1218ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
1228ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    fboCache.clear();
1238ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
1248ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    programCache.clear();
12534725687748cc2b4ace2bdb49becfdcd569e9a5dChris Craik    mProgram = nullptr;
1268ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
1273b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    patchCache.clear();
1283b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
12946bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy    clearGarbage();
13046bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy
13144eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mPixelBufferState;
13244eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = nullptr;
13344eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mTextureState;
13444eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = nullptr;
1358ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = false;
1365b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
1375b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
1386c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(const ProgramDescription& description) {
1396c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    setProgram(programCache.get(description));
1406c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
1416c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
1426c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(Program* program) {
1436c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    if (!program || !program->isInUse()) {
1446c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (mProgram) {
1456c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            mProgram->remove();
1466c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
1476c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (program) {
1486c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            program->use();
1496c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
1506c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        mProgram = program;
1516c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    }
1526c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
1536c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
1545b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy///////////////////////////////////////////////////////////////////////////////
155c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy// Debug
156c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
157c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
158627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guyuint32_t Caches::getOverdrawColor(uint32_t amount) const {
159627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    static uint32_t sOverdrawColors[2][4] = {
160627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x2f00ff00, 0x3fff0000, 0x7fff0000 },
161627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x4fffff00, 0x5fff8ad8, 0x7fff0000 }
162627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    };
163627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount < 1) amount = 1;
164627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount > 4) amount = 4;
1652507c34d91bb0d722b6012e85cb47387b2aa6873Chris Craik
1662507c34d91bb0d722b6012e85cb47387b2aa6873Chris Craik    int overdrawColorIndex = static_cast<int>(Properties::overdrawColorSet);
1672507c34d91bb0d722b6012e85cb47387b2aa6873Chris Craik    return sOverdrawColors[overdrawColorIndex][amount - 1];
168627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy}
169627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy
170c15008e72ec00ca20a271c3006dac649fd07533bRomain Guyvoid Caches::dumpMemoryUsage() {
1719c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    String8 stringLog;
1729c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    dumpMemoryUsage(stringLog);
1735baa3a62a97544669fba6d65a11c07f252e654ddSteve Block    ALOGD("%s", stringLog.string());
1749c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase}
1759c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase
1769c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haasevoid Caches::dumpMemoryUsage(String8 &log) {
1770e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    uint32_t total = 0;
1789c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Current memory usage / total memory usage (bytes):\n");
1799c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextureCache         %8d / %8d\n",
1809c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            textureCache.getSize(), textureCache.getMaxSize());
18117035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck    log.appendFormat("  LayerCache           %8d / %8d (numLayers = %zu)\n",
18217035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck            layerCache.getSize(), layerCache.getMaxSize(), layerCache.getCount());
1830e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    if (mRenderState) {
1840e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        int memused = 0;
18557998017ff137f7d4ec33df21b6596141f8c4547John Reck        for (std::set<Layer*>::iterator it = mRenderState->mActiveLayers.begin();
1860e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                it != mRenderState->mActiveLayers.end(); it++) {
1870e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            const Layer* layer = *it;
1880e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            log.appendFormat("    Layer size %dx%d; isTextureLayer()=%d; texid=%u fbo=%u; refs=%d\n",
1890e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getWidth(), layer->getHeight(),
190f27133df2d179c99d6bc1ae644af09e9153a0071Chris Craik                    layer->isTextureLayer(), layer->getTextureId(),
1910e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getFbo(), layer->getStrongCount());
19288f5fc7c5a9fb1e677c508165f732cd76f5eef3aJohn Reck            memused += layer->getWidth() * layer->getHeight() * 4;
1930e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        }
1940e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        log.appendFormat("  Layers total   %8d (numLayers = %zu)\n",
1950e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                memused, mRenderState->mActiveLayers.size());
1960e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        total += memused;
1970e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    }
1988d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    log.appendFormat("  RenderBufferCache    %8d / %8d\n",
1998d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.getSize(), renderBufferCache.getMaxSize());
2009c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  GradientCache        %8d / %8d\n",
2019c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            gradientCache.getSize(), gradientCache.getMaxSize());
2029c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  PathCache            %8d / %8d\n",
2039c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            pathCache.getSize(), pathCache.getMaxSize());
20405f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    log.appendFormat("  TessellationCache    %8d / %8d\n",
20505f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.getSize(), tessellationCache.getMaxSize());
2069c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextDropShadowCache  %8d / %8d\n", dropShadowCache.getSize(),
207c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy            dropShadowCache.getMaxSize());
2083b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    log.appendFormat("  PatchCache           %8d / %8d\n",
2093b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy            patchCache.getSize(), patchCache.getMaxSize());
210b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
2111e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeA8 = fontRenderer->getFontRendererSize(i, GL_ALPHA);
2121e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeRGBA = fontRenderer->getFontRendererSize(i, GL_RGBA);
2131e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d A8    %8d / %8d\n", i, sizeA8, sizeA8);
2141e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d RGBA  %8d / %8d\n", i, sizeRGBA, sizeRGBA);
2151e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d total %8d / %8d\n", i, sizeA8 + sizeRGBA,
2161e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease                sizeA8 + sizeRGBA);
217c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
218d2ba50ab861ec0950bda18dd0f463b687e66249fRomain Guy    log.appendFormat("Other:\n");
2199c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  FboCache             %8d / %8d\n",
2209c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            fboCache.getSize(), fboCache.getMaxSize());
221c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
222c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += textureCache.getSize();
2238d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    total += renderBufferCache.getSize();
224c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += gradientCache.getSize();
225c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += pathCache.getSize();
22605f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    total += tessellationCache.getSize();
227c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += dropShadowCache.getSize();
2283b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    total += patchCache.getSize();
229b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
2301e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_ALPHA);
2311e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_RGBA);
232c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
233c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
2349c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Total memory usage:\n");
2359c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  %d bytes, %.2f MB\n", total, total / 1024.0f / 1024.0f);
236c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy}
237c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
238c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
239fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy// Memory management
240fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
241fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
242fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guyvoid Caches::clearGarbage() {
243fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    textureCache.clearGarbage();
244fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    pathCache.clearGarbage();
245e3b0a0117a2ab4118f868a731b238fe8f2430276Romain Guy    patchCache.clearGarbage();
246fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy}
247fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
248bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guyvoid Caches::flush(FlushMode mode) {
249bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    FLUSH_LOGD("Flushing caches (mode %d)", mode);
250bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
251bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    switch (mode) {
252bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Full:
253bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            textureCache.clear();
254bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            patchCache.clear();
255bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            dropShadowCache.clear();
256bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            gradientCache.clear();
257b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->clear();
258b746371de7f21ae36a14953d9b253df06838efb1Romain Guy            fboCache.clear();
259211efea7376371ee755edd2ad03e83ef6eea464eRomain Guy            dither.clear();
260bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            // fall through
261bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Moderate:
262b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->flush();
263eca0ca2424afc1e98912405906edfc32f7733e16Romain Guy            textureCache.flush();
264bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            pathCache.clear();
26505f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.clear();
2666d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            // fall through
2676d7475d666baefaa3ba9f0dcee25238739454241Romain Guy        case kFlushMode_Layers:
2686d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            layerCache.clear();
2698d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.clear();
270bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            break;
271bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    }
2726a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase
2736a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase    clearGarbage();
2744ced2620b730a7c7140f73da503946f9827442bcJohn Reck    glFinish();
275d7db4d767246b41d44995acb93d03d220b53c748John Reck    // Errors during cleanup should be considered non-fatal, dump them and
276d7db4d767246b41d44995acb93d03d220b53c748John Reck    // and move on. TODO: All errors or just errors like bad surface?
277d7db4d767246b41d44995acb93d03d220b53c748John Reck    GLUtils::dumpGLErrors();
278bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy}
279bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
280fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
28185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Tiling
28285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
28385ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
284f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guyvoid Caches::startTiling(GLuint x, GLuint y, GLuint width, GLuint height, bool discard) {
2852507c34d91bb0d722b6012e85cb47387b2aa6873Chris Craik    if (mExtensions.hasTiledRendering() && !Properties::debugOverdraw) {
286f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guy        glStartTilingQCOM(x, y, width, height, (discard ? GL_NONE : GL_COLOR_BUFFER_BIT0_QCOM));
28785ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
28885ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
28985ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
29085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guyvoid Caches::endTiling() {
2912507c34d91bb0d722b6012e85cb47387b2aa6873Chris Craik    if (mExtensions.hasTiledRendering() && !Properties::debugOverdraw) {
2922b7028eabac80cec170572bc0e945a1d4224e595Romain Guy        glEndTilingQCOM(GL_COLOR_BUFFER_BIT0_QCOM);
29385ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
29485ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
29585ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
29654c1a64d5441a964890b44280e4457e11f4f924aRomain Guybool Caches::hasRegisteredFunctors() {
29754c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    return mFunctorsCount > 0;
29854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
29954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
30054c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::registerFunctors(uint32_t functorCount) {
30154c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount += functorCount;
30254c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
30354c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
30454c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::unregisterFunctors(uint32_t functorCount) {
30554c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    if (functorCount > mFunctorsCount) {
30654c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount = 0;
30754c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    } else {
30854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount -= functorCount;
30954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    }
31054c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
31154c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
31285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
31385ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Regions
31485ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
31585ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
3165b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain GuyTextureVertex* Caches::getRegionMesh() {
3175b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    // Create the mesh, 2 triangles and 4 vertices per rectangle in the region
3185b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    if (!mRegionMesh) {
31996a5c4c7bab6718524de7253da8309143ab48befChris Craik        mRegionMesh.reset(new TextureVertex[kMaxNumberOfQuads * 4]);
3205b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    }
3215b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
32251d6a3db97bdd5315f1a17a4b447d10a92217b98Chris Craik    return mRegionMesh.get();
3235b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
3245b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
325ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
326ba9b613437c34873fa95800a25fc51720638267cChris Craik// Temporary Properties
327ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
328ba9b613437c34873fa95800a25fc51720638267cChris Craik
329dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace uirenderer
330dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace android
331