Caches.cpp revision 117bdbcfa3e8306dad21e7e01fa71b00cdfa7265
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)
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();
614ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    initProperties();
62f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    initStaticProperties();
630f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    initExtensions();
64ba9b613437c34873fa95800a25fc51720638267cChris Craik    initTempProperties();
65e190aa69756aecfaffabdd4c6d32cb6b3220d842Romain Guy
66e190aa69756aecfaffabdd4c6d32cb6b3220d842Romain Guy    mDebugLevel = readDebugLevel();
6796a5c4c7bab6718524de7253da8309143ab48befChris Craik    ALOGD_IF(mDebugLevel != kDebugDisabled,
6896a5c4c7bab6718524de7253da8309143ab48befChris Craik            "Enabling debug mode %d", mDebugLevel);
69dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}
70dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase
713b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guybool Caches::init() {
723b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    if (mInitialized) return false;
738ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
74fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck    ATRACE_NAME("Caches::init");
75fbc8df03e498baf47ff1a5e05e182f1bcd60c770John Reck
76d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    mRegionMesh = nullptr;
776c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    mProgram = nullptr;
788ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
7954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount = 0;
8054c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
81c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy    debugLayersUpdates = false;
82c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy    debugOverdraw = false;
833ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    debugStencilClip = kStencilHide;
84c2a972131f1870042eb63847d4b24fbe718d8e3fRomain Guy
8596a5c4c7bab6718524de7253da8309143ab48befChris Craik    patchCache.init();
863b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
878ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = true;
883b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
8944eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = new PixelBufferState();
9044eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = new TextureState();
918aa195d7081b889f3a7b1f426cbd8556377aae5eRomain Guy
923b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    return true;
938ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy}
948ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
95b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guyvoid Caches::initFont() {
96b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    fontRenderer = GammaFontRenderer::createRenderer();
97b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy}
98b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy
99dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initExtensions() {
1003bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasDebugMarker()) {
101dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = glInsertEventMarkerEXT;
1020f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
103ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        startMark = glPushGroupMarkerEXT;
104ff78583d8a73ca35ce65b5d2592570ff6fb9901bChris Craik        endMark = glPopGroupMarkerEXT;
105dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    } else {
106dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        eventMark = eventMarkNull;
107dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        startMark = startMarkNull;
108dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        endMark = endMarkNull;
109dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    }
110dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
1110f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (mExtensions.hasDebugLabel() && (drawDeferDisabled || drawReorderDisabled)) {
112dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        setLabel = glLabelObjectEXT;
113dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        getLabel = glGetObjectLabelEXT;
114dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    } else {
115dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        setLabel = setLabelNull;
116dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy        getLabel = getLabelNull;
117dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    }
118dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
119dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
120dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guyvoid Caches::initConstraints() {
121dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy    glGetIntegerv(GL_MAX_TEXTURE_SIZE, &maxTextureSize);
122dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy}
123dfa1046ecab165eb0daf5caa8475e993350f4a2bRomain Guy
124f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guyvoid Caches::initStaticProperties() {
125f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    gpuPixelBuffersEnabled = false;
126f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
127f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    // OpenGL ES 3.0+ specific features
1287f4307668b10467ee39d41c7ea29cf1ff238a835Romain Guy    if (mExtensions.hasPixelBufferObjects()) {
129f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        char property[PROPERTY_VALUE_MAX];
130f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        if (property_get(PROPERTY_ENABLE_GPU_PIXEL_BUFFERS, property, "true") > 0) {
131f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy            gpuPixelBuffersEnabled = !strcmp(property, "true");
132f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy        }
133f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy    }
134f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy}
135f9f0016b1ff816eb2c7561eed482c056189005f8Romain Guy
1365bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guybool Caches::initProperties() {
1375bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy    bool prevDebugLayersUpdates = debugLayersUpdates;
1385bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy    bool prevDebugOverdraw = debugOverdraw;
1393ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    StencilClipDebug prevDebugStencilClip = debugStencilClip;
1405bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy
1414ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    char property[PROPERTY_VALUE_MAX];
142d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_LAYERS_UPDATES, property, nullptr) > 0) {
1434ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        INIT_LOGD("  Layers updates debug enabled: %s", property);
1444ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        debugLayersUpdates = !strcmp(property, "true");
1454ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    } else {
1464ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy        debugLayersUpdates = false;
1474ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy    }
1487c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy
149627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    debugOverdraw = false;
150d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_OVERDRAW, property, nullptr) > 0) {
1517c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy        INIT_LOGD("  Overdraw debug enabled: %s", property);
152627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        if (!strcmp(property, "show")) {
153627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            debugOverdraw = true;
154627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            mOverdrawDebugColorSet = kColorSet_Default;
155627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        } else if (!strcmp(property, "show_deuteranomaly")) {
156627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            debugOverdraw = true;
157627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            mOverdrawDebugColorSet = kColorSet_Deuteranomaly;
158627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy        }
1597c450aaa3caac2a05fcb20a177483d0e92378426Romain Guy    }
1605bb3c730f5ebd2a0db1b02a8981c6fdbea6c1a2eRomain Guy
1613ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    // See Properties.h for valid values
162d41c4d8c732095ae99c955b6b82f7306633004b1Chris Craik    if (property_get(PROPERTY_DEBUG_STENCIL_CLIP, property, nullptr) > 0) {
1633ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        INIT_LOGD("  Stencil clip debug enabled: %s", property);
1643ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        if (!strcmp(property, "hide")) {
1653ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilHide;
1663ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        } else if (!strcmp(property, "highlight")) {
1673ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilShowHighlight;
1683ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        } else if (!strcmp(property, "region")) {
1693ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy            debugStencilClip = kStencilShowRegion;
1703ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        }
1713ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    } else {
1723ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy        debugStencilClip = kStencilHide;
1733ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy    }
1743ff0bfdd144bba3b023eda8c49b25fb0d0de8653Romain Guy
1750f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (property_get(PROPERTY_DISABLE_DRAW_DEFER, property, "false")) {
1760f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        drawDeferDisabled = !strcasecmp(property, "true");
1770f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw defer %s", drawDeferDisabled ? "disabled" : "enabled");
1780f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    } else {
17958ddced27752b5e47b0d42fec66f8dcfde070ec1Chris Craik        drawDeferDisabled = false;
1800f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw defer enabled");
1810f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    }
1820f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
1830f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    if (property_get(PROPERTY_DISABLE_DRAW_REORDER, property, "false")) {
1840f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        drawReorderDisabled = !strcasecmp(property, "true");
1850f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw reorder %s", drawReorderDisabled ? "disabled" : "enabled");
1860f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    } else {
18758ddced27752b5e47b0d42fec66f8dcfde070ec1Chris Craik        drawReorderDisabled = false;
1880f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy        INIT_LOGD("  Draw reorder enabled");
1890f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy    }
1900f6675332c04c74909425d1d328f02b32c0ff40eRomain Guy
191117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik    return (prevDebugLayersUpdates != debugLayersUpdates)
192117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik            || (prevDebugOverdraw != debugOverdraw)
193117bdbcfa3e8306dad21e7e01fa71b00cdfa7265Chris Craik            || (prevDebugStencilClip != debugStencilClip);
1944ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy}
1954ff0cf4b83605bff630c4e6f1fabe4f72a3f93a1Romain Guy
1968ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guyvoid Caches::terminate() {
1978ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    if (!mInitialized) return;
19851d6a3db97bdd5315f1a17a4b447d10a92217b98Chris Craik    mRegionMesh.release();
1998ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
2008ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    fboCache.clear();
2018ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
2028ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    programCache.clear();
20334725687748cc2b4ace2bdb49becfdcd569e9a5dChris Craik    mProgram = nullptr;
2048ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy
2053b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    patchCache.clear();
2063b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy
20746bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy    clearGarbage();
20846bfc4811094e5b1e3196246e457d4c6b58332ecRomain Guy
20944eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mPixelBufferState;
21044eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mPixelBufferState = nullptr;
21144eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    delete mTextureState;
21244eb2c00861098dd3e2950d923646814b4cc57c2Chris Craik    mTextureState = nullptr;
2138ff6b9ebeeb24a6161ec6098e6bfdf8790ee5695Romain Guy    mInitialized = false;
2145b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
2155b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
2166c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(const ProgramDescription& description) {
2176c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    setProgram(programCache.get(description));
2186c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
2196c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
2206c15ffa196fc9b7724c189d833c3435d8db12266Chris Craikvoid Caches::setProgram(Program* program) {
2216c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    if (!program || !program->isInUse()) {
2226c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (mProgram) {
2236c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            mProgram->remove();
2246c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
2256c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        if (program) {
2266c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik            program->use();
2276c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        }
2286c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik        mProgram = program;
2296c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik    }
2306c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik}
2316c15ffa196fc9b7724c189d833c3435d8db12266Chris Craik
2325b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy///////////////////////////////////////////////////////////////////////////////
233c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy// Debug
234c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
235c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
236627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guyuint32_t Caches::getOverdrawColor(uint32_t amount) const {
237627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    static uint32_t sOverdrawColors[2][4] = {
238627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x2f00ff00, 0x3fff0000, 0x7fff0000 },
239627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy            { 0x2f0000ff, 0x4fffff00, 0x5fff8ad8, 0x7fff0000 }
240627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    };
241627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount < 1) amount = 1;
242627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    if (amount > 4) amount = 4;
243627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy    return sOverdrawColors[mOverdrawDebugColorSet][amount - 1];
244627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy}
245627c6fd91377ead85f74a365438e25610ef1e2eeRomain Guy
246c15008e72ec00ca20a271c3006dac649fd07533bRomain Guyvoid Caches::dumpMemoryUsage() {
2479c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    String8 stringLog;
2489c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    dumpMemoryUsage(stringLog);
2495baa3a62a97544669fba6d65a11c07f252e654ddSteve Block    ALOGD("%s", stringLog.string());
2509c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase}
2519c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase
2529c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haasevoid Caches::dumpMemoryUsage(String8 &log) {
2530e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    uint32_t total = 0;
2549c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Current memory usage / total memory usage (bytes):\n");
2559c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextureCache         %8d / %8d\n",
2569c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            textureCache.getSize(), textureCache.getMaxSize());
25717035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck    log.appendFormat("  LayerCache           %8d / %8d (numLayers = %zu)\n",
25817035b0211a3c9d45ea46a99217a6acbe76e8fbeJohn Reck            layerCache.getSize(), layerCache.getMaxSize(), layerCache.getCount());
2590e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    if (mRenderState) {
2600e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        int memused = 0;
26157998017ff137f7d4ec33df21b6596141f8c4547John Reck        for (std::set<Layer*>::iterator it = mRenderState->mActiveLayers.begin();
2620e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                it != mRenderState->mActiveLayers.end(); it++) {
2630e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            const Layer* layer = *it;
2640e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck            log.appendFormat("    Layer size %dx%d; isTextureLayer()=%d; texid=%u fbo=%u; refs=%d\n",
2650e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getWidth(), layer->getHeight(),
2660e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->isTextureLayer(), layer->getTexture(),
2670e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                    layer->getFbo(), layer->getStrongCount());
26888f5fc7c5a9fb1e677c508165f732cd76f5eef3aJohn Reck            memused += layer->getWidth() * layer->getHeight() * 4;
2690e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        }
2700e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        log.appendFormat("  Layers total   %8d (numLayers = %zu)\n",
2710e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck                memused, mRenderState->mActiveLayers.size());
2720e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck        total += memused;
2730e89e2b7bcb2c035e8cee77f93120e7c5617f8d2John Reck    }
2748d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    log.appendFormat("  RenderBufferCache    %8d / %8d\n",
2758d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.getSize(), renderBufferCache.getMaxSize());
2769c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  GradientCache        %8d / %8d\n",
2779c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            gradientCache.getSize(), gradientCache.getMaxSize());
2789c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  PathCache            %8d / %8d\n",
2799c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            pathCache.getSize(), pathCache.getMaxSize());
28005f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    log.appendFormat("  TessellationCache    %8d / %8d\n",
28105f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.getSize(), tessellationCache.getMaxSize());
2829c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  TextDropShadowCache  %8d / %8d\n", dropShadowCache.getSize(),
283c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy            dropShadowCache.getMaxSize());
2843b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    log.appendFormat("  PatchCache           %8d / %8d\n",
2853b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy            patchCache.getSize(), patchCache.getMaxSize());
286b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
2871e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeA8 = fontRenderer->getFontRendererSize(i, GL_ALPHA);
2881e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        const uint32_t sizeRGBA = fontRenderer->getFontRendererSize(i, GL_RGBA);
2891e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d A8    %8d / %8d\n", i, sizeA8, sizeA8);
2901e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d RGBA  %8d / %8d\n", i, sizeRGBA, sizeRGBA);
2911e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        log.appendFormat("  FontRenderer %d total %8d / %8d\n", i, sizeA8 + sizeRGBA,
2921e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease                sizeA8 + sizeRGBA);
293c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
294d2ba50ab861ec0950bda18dd0f463b687e66249fRomain Guy    log.appendFormat("Other:\n");
2959c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  FboCache             %8d / %8d\n",
2969c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase            fboCache.getSize(), fboCache.getMaxSize());
297c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
298c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += textureCache.getSize();
2998d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy    total += renderBufferCache.getSize();
300c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += gradientCache.getSize();
301c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += pathCache.getSize();
30205f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik    total += tessellationCache.getSize();
303c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    total += dropShadowCache.getSize();
3043b748a44c6bd2ea05fe16839caf73dbe50bd7ae9Romain Guy    total += patchCache.getSize();
305b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy    for (uint32_t i = 0; i < fontRenderer->getFontRendererCount(); i++) {
3061e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_ALPHA);
3071e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease        total += fontRenderer->getFontRendererSize(i, GL_RGBA);
308c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
309c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
3109c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("Total memory usage:\n");
3119c1e23baf5bfbebd1aebbd6d9a18c225325567ceChet Haase    log.appendFormat("  %d bytes, %.2f MB\n", total, total / 1024.0f / 1024.0f);
312c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy}
313c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
314c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy///////////////////////////////////////////////////////////////////////////////
315fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy// Memory management
316fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
317fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
318fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guyvoid Caches::clearGarbage() {
319fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    textureCache.clearGarbage();
320fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy    pathCache.clearGarbage();
321e3b0a0117a2ab4118f868a731b238fe8f2430276Romain Guy    patchCache.clearGarbage();
322fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy}
323fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy
324bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guyvoid Caches::flush(FlushMode mode) {
325bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    FLUSH_LOGD("Flushing caches (mode %d)", mode);
326bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
327b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    // We must stop tasks before clearing caches
328b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    if (mode > kFlushMode_Layers) {
329b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy        tasks.stop();
330b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy    }
331b0a41ed3dcc34a2b4026f6cc8336796f3523aa21Romain Guy
332bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    switch (mode) {
333bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Full:
334bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            textureCache.clear();
335bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            patchCache.clear();
336bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            dropShadowCache.clear();
337bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            gradientCache.clear();
338b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->clear();
339b746371de7f21ae36a14953d9b253df06838efb1Romain Guy            fboCache.clear();
340211efea7376371ee755edd2ad03e83ef6eea464eRomain Guy            dither.clear();
341bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            // fall through
342bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy        case kFlushMode_Moderate:
343b1d0a4ed21168fefcb82232c8f22cb95d60acb85Romain Guy            fontRenderer->flush();
344eca0ca2424afc1e98912405906edfc32f7733e16Romain Guy            textureCache.flush();
345bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            pathCache.clear();
34605f3d6e5111fd08df5cd9aae2c3d28399dc0e7f5Chris Craik            tessellationCache.clear();
3476d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            // fall through
3486d7475d666baefaa3ba9f0dcee25238739454241Romain Guy        case kFlushMode_Layers:
3496d7475d666baefaa3ba9f0dcee25238739454241Romain Guy            layerCache.clear();
3508d4aeb7111afac0c3c7e56d4ad5d92f9cfce2ffdRomain Guy            renderBufferCache.clear();
351bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy            break;
352bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy    }
3536a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase
3546a2d17f71342f981c9df1dc5beff33e30eb3ae2bChet Haase    clearGarbage();
3554ced2620b730a7c7140f73da503946f9827442bcJohn Reck    glFinish();
356bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy}
357bdf7609867a3f886455c51dba91623a86cceb6e2Romain Guy
358fe48f65922d4a3cc4aefe058cee5acec51504a20Romain Guy///////////////////////////////////////////////////////////////////////////////
35985ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Tiling
36085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
36185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
362f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guyvoid Caches::startTiling(GLuint x, GLuint y, GLuint width, GLuint height, bool discard) {
3633bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasTiledRendering() && !debugOverdraw) {
364f735c8e5cb59d6e1d1aa152fed7a6480a08d1c2aRomain Guy        glStartTilingQCOM(x, y, width, height, (discard ? GL_NONE : GL_COLOR_BUFFER_BIT0_QCOM));
36585ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
36685ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
36785ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
36885ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guyvoid Caches::endTiling() {
3693bbacf27c0be1bae4e4483577fc89ae3113abe5dRomain Guy    if (mExtensions.hasTiledRendering() && !debugOverdraw) {
3702b7028eabac80cec170572bc0e945a1d4224e595Romain Guy        glEndTilingQCOM(GL_COLOR_BUFFER_BIT0_QCOM);
37185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy    }
37285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy}
37385ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
37454c1a64d5441a964890b44280e4457e11f4f924aRomain Guybool Caches::hasRegisteredFunctors() {
37554c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    return mFunctorsCount > 0;
37654c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
37754c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
37854c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::registerFunctors(uint32_t functorCount) {
37954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    mFunctorsCount += functorCount;
38054c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
38154c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
38254c1a64d5441a964890b44280e4457e11f4f924aRomain Guyvoid Caches::unregisterFunctors(uint32_t functorCount) {
38354c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    if (functorCount > mFunctorsCount) {
38454c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount = 0;
38554c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    } else {
38654c1a64d5441a964890b44280e4457e11f4f924aRomain Guy        mFunctorsCount -= functorCount;
38754c1a64d5441a964890b44280e4457e11f4f924aRomain Guy    }
38854c1a64d5441a964890b44280e4457e11f4f924aRomain Guy}
38954c1a64d5441a964890b44280e4457e11f4f924aRomain Guy
39085ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
39185ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy// Regions
39285ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy///////////////////////////////////////////////////////////////////////////////
39385ef80d8902afe8d26cb75fa7837fd9e6d019620Romain Guy
3945b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain GuyTextureVertex* Caches::getRegionMesh() {
3955b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    // Create the mesh, 2 triangles and 4 vertices per rectangle in the region
3965b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    if (!mRegionMesh) {
39796a5c4c7bab6718524de7253da8309143ab48befChris Craik        mRegionMesh.reset(new TextureVertex[kMaxNumberOfQuads * 4]);
3985b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    }
3995b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
40051d6a3db97bdd5315f1a17a4b447d10a92217b98Chris Craik    return mRegionMesh.get();
4015b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy}
4025b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy
403ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
404ba9b613437c34873fa95800a25fc51720638267cChris Craik// Temporary Properties
405ba9b613437c34873fa95800a25fc51720638267cChris Craik///////////////////////////////////////////////////////////////////////////////
406ba9b613437c34873fa95800a25fc51720638267cChris Craik
407ba9b613437c34873fa95800a25fc51720638267cChris Craikvoid Caches::initTempProperties() {
408f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightDiameter = -1.0f;
409f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightPosY = -1.0f;
410f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyLightPosZ = -1.0f;
411f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    propertyAmbientRatio = -1.0f;
41214a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    propertyAmbientShadowStrength = -1;
41314a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    propertySpotShadowStrength = -1;
414ba9b613437c34873fa95800a25fc51720638267cChris Craik}
415ba9b613437c34873fa95800a25fc51720638267cChris Craik
416ba9b613437c34873fa95800a25fc51720638267cChris Craikvoid Caches::setTempProperty(const char* name, const char* value) {
417ba9b613437c34873fa95800a25fc51720638267cChris Craik    ALOGD("setting property %s to %s", name, value);
418a736cd9d3587a120e5233d627cd8bf06353be107Chris Craik    if (!strcmp(name, "ambientRatio")) {
419f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyAmbientRatio = fmin(fmax(atof(value), 0.0), 10.0);
420f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("ambientRatio = %.2f", propertyAmbientRatio);
421cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
422f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik    } else if (!strcmp(name, "lightDiameter")) {
423f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightDiameter = fmin(fmax(atof(value), 0.0), 3000.0);
424f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightDiameter = %.2f", propertyLightDiameter);
425cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
42659744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    } else if (!strcmp(name, "lightPosY")) {
427f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightPosY = fmin(fmax(atof(value), 0.0), 3000.0);
428f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightPos Y = %.2f", propertyLightPosY);
429f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        return;
43059744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    } else if (!strcmp(name, "lightPosZ")) {
431f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        propertyLightPosZ = fmin(fmax(atof(value), 0.0), 3000.0);
432f5be3ca5cc5b3a10747b577f60059a99862bb9a8Chris Craik        ALOGD("lightPos Z = %.2f", propertyLightPosZ);
433cc3c25622c731d14a6f01bce684330eccba7db5aztenghui        return;
43414a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    } else if (!strcmp(name, "ambientShadowStrength")) {
43514a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        propertyAmbientShadowStrength = atoi(value);
43614a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        ALOGD("ambient shadow strength = 0x%x out of 0xff", propertyAmbientShadowStrength);
43714a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        return;
43814a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui    } else if (!strcmp(name, "spotShadowStrength")) {
43914a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        propertySpotShadowStrength = atoi(value);
44014a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        ALOGD("spot shadow strength = 0x%x out of 0xff", propertySpotShadowStrength);
44114a4e35208b7e97bbfa38f36130827c86bfafc2bztenghui        return;
442ba9b613437c34873fa95800a25fc51720638267cChris Craik    }
443ba9b613437c34873fa95800a25fc51720638267cChris Craik    ALOGD("    failed");
444ba9b613437c34873fa95800a25fc51720638267cChris Craik}
445ba9b613437c34873fa95800a25fc51720638267cChris Craik
446dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace uirenderer
447dd78ccacff83f0714ad90be98b58ad85f5d08c66Chet Haase}; // namespace android
448