Caches.cpp revision 6c15ffa196fc9b7724c189d833c3435d8db12266
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
21bb0acdf9e1d862a7cf0e2533321fc1105c29b5e3Romain Guy#include "DisplayListRenderer.h"
222dc236b2bae13b9a0ed9b3f7320502aecd7983b3Tom Hudson#include "GammaFontRenderer.h"
2309b7c91de73b59aa3f679b3ae3ba299f82ec9f8aRomain Guy#include "LayerRenderer.h"
2465fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include "Properties.h"
2565fe5eeb19e2e15c8b1ee91e8a2dcf0c25e48ca6Chris Craik#include "renderstate/RenderState.h"
2663d41abb40b3ce40d8b9bccb1cf186e8158a3687ztenghui#include "ShadowTessellator.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)
5196a5c4c7bab6718524de7253da8309143ab48befChris Craik        : patchCache(renderState)
5244eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik        , dither(*this)
5396a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mRenderState(&renderState)
5496a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mExtensions(Extensions::getInstance())
5596a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mInitialized(false) {
5696a5c4c7bab6718524de7253da8309143ab48befChris Craik    INIT_LOGD("Creating OpenGL renderer caches");
578ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    init();
58b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    initFont();
59dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    initConstraints();
604ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    initProperties();
61f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    initStaticProperties();
620f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    initExtensions();
63ba9b613437c34873fa95800a25fc51720638267cChris Craik    initTempProperties();
64e190aa69756aecfaffabdd4c6d32cb6b3220d842Romain Guy
65e190aa69756aecfaffabdd4c6d32cb6b3220d842Romain Guy    mDebugLevel = readDebugLevel();
6696a5c4c7bab6718524de7253da8309143ab48befChris Craik    ALOGD_IF(mDebugLevel != kDebugDisabled,
6796a5c4c7bab6718524de7253da8309143ab48befChris Craik            "Enabling debug mode %d", mDebugLevel);
68dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}
69dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
703b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guybool Caches::init() {
713b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    if (mInitialized) return false;
728ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
73fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck    ATRACE_NAME("Caches::init");
74fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck
75d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    mRegionMesh = nullptr;
766c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    mProgram = nullptr;
778ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
7854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount = 0;
7954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
80c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy    debugLayersUpdates = false;
81c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy    debugOverdraw = false;
823ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    debugStencilClip = kStencilHide;
83c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy
8496a5c4c7bab6718524de7253da8309143ab48befChris Craik    patchCache.init();
853b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
868ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = true;
873b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
8844eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = new PixelBufferState();
8944eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = new TextureState();
908aa195d7081b889f3a7b1f426cbd8556377aae5eRomain Guy
913b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    return true;
928ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy}
938ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
94b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guyvoid Caches::initFont() {
95b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    fontRenderer = GammaFontRenderer::createRenderer();
96b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy}
97b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy
98dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initExtensions() {
993bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasDebugMarker()) {
100dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = glInsertEventMarkerEXT;
1010f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
102ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        startMark = glPushGroupMarkerEXT;
103ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        endMark = glPopGroupMarkerEXT;
104dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    } else {
105dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = eventMarkNull;
106dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        startMark = startMarkNull;
107dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        endMark = endMarkNull;
108dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    }
109dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
1100f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (mExtensions.hasDebugLabel() && (drawDeferDisabled || drawReorderDisabled)) {
111dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        setLabel = glLabelObjectEXT;
112dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        getLabel = glGetObjectLabelEXT;
113dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    } else {
114dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        setLabel = setLabelNull;
115dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        getLabel = getLabelNull;
116dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    }
117dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
118dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
119dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initConstraints() {
120dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    glGetIntegerv(GL_MAX_TEXTURE_SIZE, &maxTextureSize);
121dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
122dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
123f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guyvoid Caches::initStaticProperties() {
124f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    gpuPixelBuffersEnabled = false;
125f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
126f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    // OpenGL ES 3.0+ specific features
1277f4307668b10467ee39d41c7ea29cf1ff238a835Romain Guy    if (mExtensions.hasPixelBufferObjects()) {
128f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        char property[PROPERTY_VALUE_MAX];
129f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        if (property_get(PROPERTY_ENABLE_GPU_PIXEL_BUFFERS, property, "true") > 0) {
130f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy            gpuPixelBuffersEnabled = !strcmp(property, "true");
131f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        }
132f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    }
133f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy}
134f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
1355bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guybool Caches::initProperties() {
1365bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy    bool prevDebugLayersUpdates = debugLayersUpdates;
1375bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy    bool prevDebugOverdraw = debugOverdraw;
1383ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    StencilClipDebug prevDebugStencilClip = debugStencilClip;
1395bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy
1404ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    char property[PROPERTY_VALUE_MAX];
141d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_LAYERS_UPDATES, property, nullptr) > 0) {
1424ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        INIT_LOGD("  Layers updates debug enabled: %s", property);
1434ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        debugLayersUpdates = !strcmp(property, "true");
1444ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    } else {
1454ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        debugLayersUpdates = false;
1464ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    }
1477c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy
148627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    debugOverdraw = false;
149d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_OVERDRAW, property, nullptr) > 0) {
1507c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy        INIT_LOGD("  Overdraw debug enabled: %s", property);
151627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        if (!strcmp(property, "show")) {
152627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            debugOverdraw = true;
153627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            mOverdrawDebugColorSet = kColorSet_Default;
154627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        } else if (!strcmp(property, "show_deuteranomaly")) {
155627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            debugOverdraw = true;
156627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            mOverdrawDebugColorSet = kColorSet_Deuteranomaly;
157627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        }
1587c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy    }
1595bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy
1603ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    // See Properties.h for valid values
161d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_STENCIL_CLIP, property, nullptr) > 0) {
1623ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        INIT_LOGD("  Stencil clip debug enabled: %s", property);
1633ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        if (!strcmp(property, "hide")) {
1643ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilHide;
1653ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        } else if (!strcmp(property, "highlight")) {
1663ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilShowHighlight;
1673ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        } else if (!strcmp(property, "region")) {
1683ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilShowRegion;
1693ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        }
1703ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    } else {
1713ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        debugStencilClip = kStencilHide;
1723ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    }
1733ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy
1740f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (property_get(PROPERTY_DISABLE_DRAW_DEFER, property, "false")) {
1750f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        drawDeferDisabled = !strcasecmp(property, "true");
1760f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw defer %s", drawDeferDisabled ? "disabled" : "enabled");
1770f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    } else {
17858ddced27752b5e47b0d42fec66f8dcfde070ec1Chris Craik        drawDeferDisabled = false;
1790f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw defer enabled");
1800f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    }
1810f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
1820f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (property_get(PROPERTY_DISABLE_DRAW_REORDER, property, "false")) {
1830f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        drawReorderDisabled = !strcasecmp(property, "true");
1840f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw reorder %s", drawReorderDisabled ? "disabled" : "enabled");
1850f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    } else {
18658ddced27752b5e47b0d42fec66f8dcfde070ec1Chris Craik        drawReorderDisabled = false;
1870f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw reorder enabled");
1880f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    }
1890f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
1905bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy    return (prevDebugLayersUpdates != debugLayersUpdates) ||
1913ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            (prevDebugOverdraw != debugOverdraw) ||
1923ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            (prevDebugStencilClip != debugStencilClip);
1934ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy}
1944ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy
1958ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guyvoid Caches::terminate() {
1968ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    if (!mInitialized) return;
19751d6a3db97bdd5315f1a17a4b447d10a92217b98Chris Craik    mRegionMesh.release();
1988ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
1998ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    fboCache.clear();
2008ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
2018ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    programCache.clear();
2026c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    setProgram(nullptr);
2038ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
2043b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    patchCache.clear();
2053b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
20646bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy    clearGarbage();
20746bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy
20844eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mPixelBufferState;
20944eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = nullptr;
21044eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mTextureState;
21144eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = nullptr;
2128ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = false;
2135b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
2145b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
2156c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(const ProgramDescription& description) {
2166c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    setProgram(programCache.get(description));
2176c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
2186c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
2196c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(Program* program) {
2206c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    if (!program || !program->isInUse()) {
2216c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (mProgram) {
2226c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            mProgram->remove();
2236c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
2246c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (program) {
2256c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            program->use();
2266c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
2276c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        mProgram = program;
2286c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    }
2296c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
2306c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
2315b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy///////////////////////////////////////////////////////////////////////////////
232c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy// Debug
233c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
234c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
235627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guyuint32_t Caches::getOverdrawColor(uint32_t amount) const {
236627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    static uint32_t sOverdrawColors[2][4] = {
237627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x2f00ff00, 0x3fff0000, 0x7fff0000 },
238627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x4fffff00, 0x5fff8ad8, 0x7fff0000 }
239627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    };
240627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount < 1) amount = 1;
241627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount > 4) amount = 4;
242627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    return sOverdrawColors[mOverdrawDebugColorSet][amount - 1];
243627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy}
244627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy
245c15008e72ec00ca20a271c3006dac649fd07533bRomain Guyvoid Caches::dumpMemoryUsage() {
2469c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    String8 stringLog;
2479c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    dumpMemoryUsage(stringLog);
2485baa3a62a97544669fba6d65a11c07f252e654ddSteve Block    ALOGD("%s", stringLog.string());
2499c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase}
2509c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase
2519c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haasevoid Caches::dumpMemoryUsage(String8 &log) {
2520e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    uint32_t total = 0;
2539c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Current memory usage / total memory usage (bytes):\n");
2549c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextureCache         %8d / %8d\n",
2559c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            textureCache.getSize(), textureCache.getMaxSize());
25617035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck    log.appendFormat("  LayerCache           %8d / %8d (numLayers = %zu)\n",
25717035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck            layerCache.getSize(), layerCache.getMaxSize(), layerCache.getCount());
2580e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    if (mRenderState) {
2590e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        int memused = 0;
26057998017ff137f7d4ec33df21b6596141f8c4547John Reck        for (std::set<Layer*>::iterator it = mRenderState->mActiveLayers.begin();
2610e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                it != mRenderState->mActiveLayers.end(); it++) {
2620e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            const Layer* layer = *it;
2630e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            log.appendFormat("    Layer size %dx%d; isTextureLayer()=%d; texid=%u fbo=%u; refs=%d\n",
2640e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getWidth(), layer->getHeight(),
2650e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->isTextureLayer(), layer->getTexture(),
2660e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getFbo(), layer->getStrongCount());
26788f5fc7c5a9fb1e677c508165f732cd76f5eef3aJohn Reck            memused += layer->getWidth() * layer->getHeight() * 4;
2680e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        }
2690e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        log.appendFormat("  Layers total   %8d (numLayers = %zu)\n",
2700e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                memused, mRenderState->mActiveLayers.size());
2710e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        total += memused;
2720e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    }
2738d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    log.appendFormat("  RenderBufferCache    %8d / %8d\n",
2748d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.getSize(), renderBufferCache.getMaxSize());
2759c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  GradientCache        %8d / %8d\n",
2769c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            gradientCache.getSize(), gradientCache.getMaxSize());
2779c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  PathCache            %8d / %8d\n",
2789c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            pathCache.getSize(), pathCache.getMaxSize());
27905f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    log.appendFormat("  TessellationCache    %8d / %8d\n",
28005f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.getSize(), tessellationCache.getMaxSize());
2819c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextDropShadowCache  %8d / %8d\n", dropShadowCache.getSize(),
282c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy            dropShadowCache.getMaxSize());
2833b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    log.appendFormat("  PatchCache           %8d / %8d\n",
2843b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy            patchCache.getSize(), patchCache.getMaxSize());
285b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
2861e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeA8 = fontRenderer->getFontRendererSize(i, GL_ALPHA);
2871e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeRGBA = fontRenderer->getFontRendererSize(i, GL_RGBA);
2881e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d A8    %8d / %8d\n", i, sizeA8, sizeA8);
2891e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d RGBA  %8d / %8d\n", i, sizeRGBA, sizeRGBA);
2901e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d total %8d / %8d\n", i, sizeA8 + sizeRGBA,
2911e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease                sizeA8 + sizeRGBA);
292c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
293d2ba50ab861ec0950bda18dd0f463b687e66249fRomain Guy    log.appendFormat("Other:\n");
2949c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  FboCache             %8d / %8d\n",
2959c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            fboCache.getSize(), fboCache.getMaxSize());
296c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
297c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += textureCache.getSize();
2988d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    total += renderBufferCache.getSize();
299c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += gradientCache.getSize();
300c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += pathCache.getSize();
30105f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    total += tessellationCache.getSize();
302c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += dropShadowCache.getSize();
3033b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    total += patchCache.getSize();
304b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
3051e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_ALPHA);
3061e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_RGBA);
307c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
308c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
3099c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Total memory usage:\n");
3109c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  %d bytes, %.2f MB\n", total, total / 1024.0f / 1024.0f);
311c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy}
312c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
313c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
314fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy// Memory management
315fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
316fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
317fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guyvoid Caches::clearGarbage() {
318fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    textureCache.clearGarbage();
319fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    pathCache.clearGarbage();
320e3b0a0117a2ab4118f868a731b238fe8f2430276Romain Guy    patchCache.clearGarbage();
321fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy}
322fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
323bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guyvoid Caches::flush(FlushMode mode) {
324bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    FLUSH_LOGD("Flushing caches (mode %d)", mode);
325bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
326b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    // We must stop tasks before clearing caches
327b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    if (mode > kFlushMode_Layers) {
328b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy        tasks.stop();
329b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    }
330b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy
331bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    switch (mode) {
332bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Full:
333bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            textureCache.clear();
334bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            patchCache.clear();
335bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            dropShadowCache.clear();
336bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            gradientCache.clear();
337b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->clear();
338b746371de7f21ae36a14953d9b253df06838efb1Romain Guy            fboCache.clear();
339211efea7376371ee755edd2ad03e83ef6eea464eRomain Guy            dither.clear();
340bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            // fall through
341bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Moderate:
342b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->flush();
343eca0ca2424afc1e98912405906edfc32f7733e16Romain Guy            textureCache.flush();
344bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            pathCache.clear();
34505f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.clear();
3466d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            // fall through
3476d7475d666baefaa3ba9f0dcee25238739454241Romain Guy        case kFlushMode_Layers:
3486d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            layerCache.clear();
3498d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.clear();
350bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            break;
351bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    }
3526a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase
3536a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase    clearGarbage();
3544ced2620b730a7c7140f73da503946f9827442bcJohn Reck    glFinish();
355bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy}
356bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
357fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
35885ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Tiling
35985ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
36085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
361f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guyvoid Caches::startTiling(GLuint x, GLuint y, GLuint width, GLuint height, bool discard) {
3623bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasTiledRendering() && !debugOverdraw) {
363f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guy        glStartTilingQCOM(x, y, width, height, (discard ? GL_NONE : GL_COLOR_BUFFER_BIT0_QCOM));
36485ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
36585ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
36685ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
36785ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guyvoid Caches::endTiling() {
3683bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasTiledRendering() && !debugOverdraw) {
3692b7028eabac80cec170572bc0e945a1d4224e595Romain Guy        glEndTilingQCOM(GL_COLOR_BUFFER_BIT0_QCOM);
37085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
37185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
37285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
37354c1a64d5441a964890b44280e4457e11f4f924aRomain Guybool Caches::hasRegisteredFunctors() {
37454c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    return mFunctorsCount > 0;
37554c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
37654c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
37754c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::registerFunctors(uint32_t functorCount) {
37854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount += functorCount;
37954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
38054c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
38154c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::unregisterFunctors(uint32_t functorCount) {
38254c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    if (functorCount > mFunctorsCount) {
38354c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount = 0;
38454c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    } else {
38554c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount -= functorCount;
38654c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    }
38754c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
38854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
38985ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
39085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Regions
39185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
39285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
3935b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain GuyTextureVertex* Caches::getRegionMesh() {
3945b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    // Create the mesh, 2 triangles and 4 vertices per rectangle in the region
3955b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    if (!mRegionMesh) {
39696a5c4c7bab6718524de7253da8309143ab48befChris Craik        mRegionMesh.reset(new TextureVertex[kMaxNumberOfQuads * 4]);
3975b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    }
3985b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
39951d6a3db97bdd5315f1a17a4b447d10a92217b98Chris Craik    return mRegionMesh.get();
4005b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
4015b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
402ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
403ba9b613437c34873fa95800a25fc51720638267cChris Craik// Temporary Properties
404ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
405ba9b613437c34873fa95800a25fc51720638267cChris Craik
406ba9b613437c34873fa95800a25fc51720638267cChris Craikvoid Caches::initTempProperties() {
407f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightDiameter = -1.0f;
408f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightPosY = -1.0f;
409f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightPosZ = -1.0f;
410f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyAmbientRatio = -1.0f;
41114a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    propertyAmbientShadowStrength = -1;
41214a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    propertySpotShadowStrength = -1;
413ba9b613437c34873fa95800a25fc51720638267cChris Craik}
414ba9b613437c34873fa95800a25fc51720638267cChris Craik
415ba9b613437c34873fa95800a25fc51720638267cChris Craikvoid Caches::setTempProperty(const char* name, const char* value) {
416ba9b613437c34873fa95800a25fc51720638267cChris Craik    ALOGD("setting property %s to %s", name, value);
417a736cd9d3587a120e5233d627cd8bf06353be107Chris Craik    if (!strcmp(name, "ambientRatio")) {
418f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyAmbientRatio = fmin(fmax(atof(value), 0.0), 10.0);
419f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("ambientRatio = %.2f", propertyAmbientRatio);
420cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
421f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    } else if (!strcmp(name, "lightDiameter")) {
422f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightDiameter = fmin(fmax(atof(value), 0.0), 3000.0);
423f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightDiameter = %.2f", propertyLightDiameter);
424cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
42559744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    } else if (!strcmp(name, "lightPosY")) {
426f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightPosY = fmin(fmax(atof(value), 0.0), 3000.0);
427f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightPos Y = %.2f", propertyLightPosY);
428f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        return;
42959744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    } else if (!strcmp(name, "lightPosZ")) {
430f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightPosZ = fmin(fmax(atof(value), 0.0), 3000.0);
431f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightPos Z = %.2f", propertyLightPosZ);
432cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
43314a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    } else if (!strcmp(name, "ambientShadowStrength")) {
43414a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        propertyAmbientShadowStrength = atoi(value);
43514a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        ALOGD("ambient shadow strength = 0x%x out of 0xff", propertyAmbientShadowStrength);
43614a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        return;
43714a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    } else if (!strcmp(name, "spotShadowStrength")) {
43814a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        propertySpotShadowStrength = atoi(value);
43914a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        ALOGD("spot shadow strength = 0x%x out of 0xff", propertySpotShadowStrength);
44014a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        return;
441ba9b613437c34873fa95800a25fc51720638267cChris Craik    }
442ba9b613437c34873fa95800a25fc51720638267cChris Craik    ALOGD("    failed");
443ba9b613437c34873fa95800a25fc51720638267cChris Craik}
444ba9b613437c34873fa95800a25fc51720638267cChris Craik
445dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace uirenderer
446dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace android
447