summaryrefslogtreecommitdiff
path: root/libs/hwui/LayerCache.cpp
diff options
context:
space:
mode:
author Romain Guy <romainguy@google.com> 2012-04-02 17:49:20 -0700
committer Android (Google) Code Review <android-gerrit@google.com> 2012-04-02 17:49:20 -0700
commite2eaf6997d429249904f842092b075f3da92c5be (patch)
tree2187a2a450cdf80d9b1ea10eb53d7d15b09753e6 /libs/hwui/LayerCache.cpp
parent7eae9cb4e732934741c66f3c76a1c1f7d556af43 (diff)
parent5c88fc744db977ef26887df9605beaa409394806 (diff)
Merge "Prevent crash when flushing the layers cache Bug #6258973"
Diffstat (limited to 'libs/hwui/LayerCache.cpp')
-rw-r--r--libs/hwui/LayerCache.cpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/libs/hwui/LayerCache.cpp b/libs/hwui/LayerCache.cpp
index d304b374850e..eea707edb457 100644
--- a/libs/hwui/LayerCache.cpp
+++ b/libs/hwui/LayerCache.cpp
@@ -69,10 +69,14 @@ void LayerCache::setMaxSize(uint32_t maxSize) {
void LayerCache::deleteLayer(Layer* layer) {
if (layer) {
- LAYER_LOGD("Destroying layer %dx%d", layer->getWidth(), layer->getHeight());
+ GLuint fbo = layer->getFbo();
+ LAYER_LOGD("Destroying layer %dx%d, fbo %d", layer->getWidth(), layer->getHeight(), fbo);
+
mSize -= layer->getWidth() * layer->getHeight() * 4;
- layer->deleteFbo();
+
+ if (fbo) Caches::getInstance().fboCache.put(fbo);
layer->deleteTexture();
+
delete layer;
}
}
@@ -174,6 +178,10 @@ bool LayerCache::put(Layer* layer) {
victim->layer.getHeight());
}
+ layer->deferredUpdateScheduled = false;
+ layer->renderer = NULL;
+ layer->displayList = NULL;
+
LayerEntry entry(layer);
mCache.add(entry);