summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Romain Guy <romainguy@google.com> 2013-08-07 15:03:40 -0700
committer Romain Guy <romainguy@google.com> 2013-08-07 15:42:29 -0700
commitcb883303f97a8c08d53d972792630ca9bad94d65 (patch)
treedeabec6e0482514bcb1c0d410ed1288a6e23495a
parentb83f62236c8ca879f826941fd605a2f123262239 (diff)
Only destroy remote graphic buffers
Bug #9795157 Change-Id: Ia7a39d3ef40994fede185482a5b4ca5500249b34
-rw-r--r--core/java/android/view/HardwareRenderer.java9
1 files changed, 7 insertions, 2 deletions
diff --git a/core/java/android/view/HardwareRenderer.java b/core/java/android/view/HardwareRenderer.java
index d9e4600d42db..ba64f6bfd563 100644
--- a/core/java/android/view/HardwareRenderer.java
+++ b/core/java/android/view/HardwareRenderer.java
@@ -1983,7 +1983,12 @@ public abstract class HardwareRenderer {
if (map != null) {
GLES20Canvas.initAtlas(buffer, map);
}
- buffer.destroy();
+ // If IAssetAtlas is not the same class as the IBinder
+ // we are using a remote service and we can safely
+ // destroy the graphic buffer
+ if (atlas.getClass() != binder.getClass()) {
+ buffer.destroy();
+ }
}
}
} catch (RemoteException e) {
@@ -1994,7 +1999,7 @@ public abstract class HardwareRenderer {
@Override
boolean canDraw() {
return super.canDraw() && mGlCanvas != null;
- }
+ }
@Override
int onPreDraw(Rect dirty) {