summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Pannag Sanketi <psanketi@google.com> 2012-06-20 19:32:44 -0700
committer Android (Google) Code Review <android-gerrit@google.com> 2012-06-20 19:32:44 -0700
commit60c5b714dc747eef0b5c2a57db60b162315fba2f (patch)
treecd6665e0434cb9acab002448908985a0e05ace72
parent255cb7798160a083124cd2033e0619f8b3ed731c (diff)
parent22f2a8728ee2000a01aa6fc6108d8478d7c0ced9 (diff)
Merge "Crash in SurfaceTextureTarget filter open" into jb-dev
-rw-r--r--media/mca/filterpacks/java/android/filterpacks/videosrc/SurfaceTextureTarget.java15
1 files changed, 12 insertions, 3 deletions
diff --git a/media/mca/filterpacks/java/android/filterpacks/videosrc/SurfaceTextureTarget.java b/media/mca/filterpacks/java/android/filterpacks/videosrc/SurfaceTextureTarget.java
index 674a2bdcb539..b6d9f9413190 100644
--- a/media/mca/filterpacks/java/android/filterpacks/videosrc/SurfaceTextureTarget.java
+++ b/media/mca/filterpacks/java/android/filterpacks/videosrc/SurfaceTextureTarget.java
@@ -162,6 +162,10 @@ public class SurfaceTextureTarget extends Filter {
@Override
public synchronized void open(FilterContext context) {
// Set up SurfaceTexture internals
+ if (mSurfaceTexture == null) {
+ Log.e(TAG, "SurfaceTexture is null!!");
+ throw new RuntimeException("Could not register SurfaceTexture: " + mSurfaceTexture);
+ }
mSurfaceId = context.getGLEnvironment().registerSurfaceTexture(
mSurfaceTexture, mScreenWidth, mScreenHeight);
if (mSurfaceId <= 0) {
@@ -170,19 +174,24 @@ public class SurfaceTextureTarget extends Filter {
}
+ // Once the surface is unregistered, we still need the surfacetexture reference.
+ // That is because when the the filter graph stops and starts again, the app
+ // may not set the mSurfaceTexture again on the filter. In some cases, the app
+ // may not even know that the graph has re-started. So it is difficult to enforce
+ // that condition on an app using this filter. The only case where we need
+ // to let go of the mSurfaceTexure reference is when the app wants to shut
+ // down the graph on purpose, such as in the disconnect call.
@Override
public synchronized void close(FilterContext context) {
if (mSurfaceId > 0) {
context.getGLEnvironment().unregisterSurfaceId(mSurfaceId);
mSurfaceId = -1;
- // Once the surface is unregistered, remove the surfacetexture reference.
- // The surfaceId could not have been valid without a valid surfacetexture.
- mSurfaceTexture = null;
}
}
// This should be called from the client side when the surfacetexture is no longer
// valid. e.g. from onPause() in the application using the filter graph.
+ // In this case, we need to let go of our surfacetexture reference.
public synchronized void disconnect(FilterContext context) {
if (mLogVerbose) Log.v(TAG, "disconnect");
if (mSurfaceTexture == null) {