| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/browser/android/child_process_launcher_android.h" | 5 #include "content/browser/android/child_process_launcher_android.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 #include <stdint.h> | 8 #include <stdint.h> |
| 9 | 9 |
| 10 #include <memory> | 10 #include <memory> |
| 11 #include <utility> | 11 #include <utility> |
| 12 | 12 |
| 13 #include "base/android/context_utils.h" | 13 #include "base/android/context_utils.h" |
| 14 #include "base/android/jni_android.h" | 14 #include "base/android/jni_android.h" |
| 15 #include "base/android/jni_array.h" | 15 #include "base/android/jni_array.h" |
| 16 #include "base/android/unguessable_token_android.h" |
| 16 #include "base/logging.h" | 17 #include "base/logging.h" |
| 17 #include "content/browser/android/scoped_surface_request_manager.h" | 18 #include "content/browser/android/scoped_surface_request_manager.h" |
| 18 #include "content/browser/frame_host/render_frame_host_impl.h" | 19 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 19 #include "content/browser/media/android/browser_media_player_manager.h" | 20 #include "content/browser/media/android/browser_media_player_manager.h" |
| 20 #include "content/browser/media/android/media_web_contents_observer_android.h" | 21 #include "content/browser/media/android/media_web_contents_observer_android.h" |
| 21 #include "content/browser/web_contents/web_contents_impl.h" | 22 #include "content/browser/web_contents/web_contents_impl.h" |
| 22 #include "content/public/browser/browser_thread.h" | 23 #include "content/public/browser/browser_thread.h" |
| 23 #include "content/public/browser/render_process_host.h" | 24 #include "content/public/browser/render_process_host.h" |
| 24 #include "content/public/common/content_switches.h" | 25 #include "content/public/common/content_switches.h" |
| 25 #include "gpu/ipc/common/gpu_surface_tracker.h" | 26 #include "gpu/ipc/common/gpu_surface_tracker.h" |
| (...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 189 if (jsurface.is_null()) | 190 if (jsurface.is_null()) |
| 190 return; | 191 return; |
| 191 | 192 |
| 192 DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); | 193 DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 193 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, base::Bind( | 194 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, base::Bind( |
| 194 &SetSurfacePeer, jsurface, pid, primary_id, secondary_id)); | 195 &SetSurfacePeer, jsurface, pid, primary_id, secondary_id)); |
| 195 } | 196 } |
| 196 | 197 |
| 197 void CompleteScopedSurfaceRequest(JNIEnv* env, | 198 void CompleteScopedSurfaceRequest(JNIEnv* env, |
| 198 const JavaParamRef<jclass>& clazz, | 199 const JavaParamRef<jclass>& clazz, |
| 199 jlong request_token_high, | 200 const JavaParamRef<jobject>& token, |
| 200 jlong request_token_low, | |
| 201 const JavaParamRef<jobject>& surface) { | 201 const JavaParamRef<jobject>& surface) { |
| 202 if (request_token_high == 0 && request_token_low == 0) { | 202 base::UnguessableToken requestToken = |
| 203 base::android::UnguessableTokenAndroid::FromJavaUnguessableToken(env, |
| 204 token); |
| 205 if (!requestToken) { |
| 203 DLOG(ERROR) << "Received invalid surface request token."; | 206 DLOG(ERROR) << "Received invalid surface request token."; |
| 204 return; | 207 return; |
| 205 } | 208 } |
| 206 | 209 |
| 207 DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); | 210 DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 208 | 211 |
| 209 ScopedJavaGlobalRef<jobject> jsurface; | 212 ScopedJavaGlobalRef<jobject> jsurface; |
| 210 jsurface.Reset(env, surface); | 213 jsurface.Reset(env, surface); |
| 211 ScopedSurfaceRequestManager::GetInstance()->FulfillScopedSurfaceRequest( | 214 ScopedSurfaceRequestManager::GetInstance()->FulfillScopedSurfaceRequest( |
| 212 base::UnguessableToken::Deserialize(request_token_high, | 215 requestToken, gl::ScopedJavaSurface(jsurface)); |
| 213 request_token_low), | |
| 214 gl::ScopedJavaSurface(jsurface)); | |
| 215 } | 216 } |
| 216 | 217 |
| 217 void CreateSurfaceTextureSurface(int surface_texture_id, | 218 void CreateSurfaceTextureSurface(int surface_texture_id, |
| 218 int client_id, | 219 int client_id, |
| 219 gl::SurfaceTexture* surface_texture) { | 220 gl::SurfaceTexture* surface_texture) { |
| 220 JNIEnv* env = AttachCurrentThread(); | 221 JNIEnv* env = AttachCurrentThread(); |
| 221 DCHECK(env); | 222 DCHECK(env); |
| 222 Java_ChildProcessLauncher_createSurfaceTextureSurface( | 223 Java_ChildProcessLauncher_createSurfaceTextureSurface( |
| 223 env, surface_texture_id, client_id, surface_texture->j_surface_texture()); | 224 env, surface_texture_id, client_id, surface_texture->j_surface_texture()); |
| 224 } | 225 } |
| (...skipping 26 matching lines...) Expand all Loading... |
| 251 gl::ScopedJavaSurface surface_view = | 252 gl::ScopedJavaSurface surface_view = |
| 252 gpu::GpuSurfaceTracker::GetInstance()->AcquireJavaSurface(surface_id); | 253 gpu::GpuSurfaceTracker::GetInstance()->AcquireJavaSurface(surface_id); |
| 253 return base::android::ScopedJavaLocalRef<jobject>(surface_view.j_surface()); | 254 return base::android::ScopedJavaLocalRef<jobject>(surface_view.j_surface()); |
| 254 } | 255 } |
| 255 | 256 |
| 256 bool RegisterChildProcessLauncher(JNIEnv* env) { | 257 bool RegisterChildProcessLauncher(JNIEnv* env) { |
| 257 return RegisterNativesImpl(env); | 258 return RegisterNativesImpl(env); |
| 258 } | 259 } |
| 259 | 260 |
| 260 } // namespace content | 261 } // namespace content |
| OLD | NEW |