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