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/gpu/browser_gpu_channel_host_factory.h" | 5 #include "content/browser/gpu/browser_gpu_channel_host_factory.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/debug/trace_event.h" | 8 #include "base/debug/trace_event.h" |
9 #include "base/synchronization/waitable_event.h" | 9 #include "base/synchronization/waitable_event.h" |
10 #include "base/threading/thread_restrictions.h" | 10 #include "base/threading/thread_restrictions.h" |
(...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
289 // In this case we need to wait for this before we can show any UI /anyway/, | 289 // In this case we need to wait for this before we can show any UI /anyway/, |
290 // so it won't cause additional jank. | 290 // so it won't cause additional jank. |
291 // TODO(piman): Make this asynchronous (http://crbug.com/125248). | 291 // TODO(piman): Make this asynchronous (http://crbug.com/125248). |
292 TRACE_EVENT0("browser", | 292 TRACE_EVENT0("browser", |
293 "BrowserGpuChannelHostFactory::CreateViewCommandBuffer"); | 293 "BrowserGpuChannelHostFactory::CreateViewCommandBuffer"); |
294 base::ThreadRestrictions::ScopedAllowWait allow_wait; | 294 base::ThreadRestrictions::ScopedAllowWait allow_wait; |
295 request.event.Wait(); | 295 request.event.Wait(); |
296 return request.succeeded; | 296 return request.succeeded; |
297 } | 297 } |
298 | 298 |
299 void BrowserGpuChannelHostFactory::CreateImageOnIO( | |
300 gfx::PluginWindowHandle window, | |
301 int32 image_id, | |
302 const CreateImageCallback& callback) { | |
303 GpuProcessHost* host = GpuProcessHost::FromID(gpu_host_id_); | |
304 if (!host) { | |
305 ImageCreatedOnIO(callback, gfx::Size()); | |
306 return; | |
307 } | |
308 | |
309 host->CreateImage( | |
310 window, | |
311 gpu_client_id_, | |
312 image_id, | |
313 base::Bind(&BrowserGpuChannelHostFactory::ImageCreatedOnIO, callback)); | |
314 } | |
315 | |
316 // static | |
317 void BrowserGpuChannelHostFactory::ImageCreatedOnIO( | |
318 const CreateImageCallback& callback, const gfx::Size size) { | |
319 BrowserThread::PostTask( | |
320 BrowserThread::UI, | |
321 FROM_HERE, | |
322 base::Bind(&BrowserGpuChannelHostFactory::OnImageCreated, | |
323 callback, size)); | |
324 } | |
325 | |
326 // static | |
327 void BrowserGpuChannelHostFactory::OnImageCreated( | |
328 const CreateImageCallback& callback, const gfx::Size size) { | |
329 callback.Run(size); | |
330 } | |
331 | |
332 void BrowserGpuChannelHostFactory::CreateImage( | |
333 gfx::PluginWindowHandle window, | |
334 int32 image_id, | |
335 const CreateImageCallback& callback) { | |
336 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
337 GetIOLoopProxy()->PostTask(FROM_HERE, base::Bind( | |
338 &BrowserGpuChannelHostFactory::CreateImageOnIO, | |
339 base::Unretained(this), | |
340 window, | |
341 image_id, | |
342 callback)); | |
343 } | |
344 | |
345 void BrowserGpuChannelHostFactory::DeleteImageOnIO( | |
346 int32 image_id, int32 sync_point) { | |
347 GpuProcessHost* host = GpuProcessHost::FromID(gpu_host_id_); | |
348 if (!host) { | |
349 return; | |
350 } | |
351 | |
352 host->DeleteImage(gpu_client_id_, image_id, sync_point); | |
353 } | |
354 | |
355 void BrowserGpuChannelHostFactory::DeleteImage( | |
356 int32 image_id, int32 sync_point) { | |
357 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
358 GetIOLoopProxy()->PostTask(FROM_HERE, base::Bind( | |
359 &BrowserGpuChannelHostFactory::DeleteImageOnIO, | |
360 base::Unretained(this), | |
361 image_id, | |
362 sync_point)); | |
363 } | |
364 | |
365 GpuChannelHost* BrowserGpuChannelHostFactory::EstablishGpuChannelSync( | 299 GpuChannelHost* BrowserGpuChannelHostFactory::EstablishGpuChannelSync( |
366 CauseForGpuLaunch cause_for_gpu_launch) { | 300 CauseForGpuLaunch cause_for_gpu_launch) { |
367 EstablishGpuChannel(cause_for_gpu_launch, base::Closure()); | 301 EstablishGpuChannel(cause_for_gpu_launch, base::Closure()); |
368 | 302 |
369 if (pending_request_) | 303 if (pending_request_) |
370 pending_request_->Wait(); | 304 pending_request_->Wait(); |
371 | 305 |
372 return gpu_channel_.get(); | 306 return gpu_channel_.get(); |
373 } | 307 } |
374 | 308 |
(...skipping 176 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
551 const gfx::GpuMemoryBufferHandle& handle, | 485 const gfx::GpuMemoryBufferHandle& handle, |
552 int32 sync_point) { | 486 int32 sync_point) { |
553 GpuProcessHost* host = GpuProcessHost::FromID(gpu_host_id_); | 487 GpuProcessHost* host = GpuProcessHost::FromID(gpu_host_id_); |
554 if (!host) | 488 if (!host) |
555 return; | 489 return; |
556 | 490 |
557 host->DestroyGpuMemoryBuffer(handle, sync_point); | 491 host->DestroyGpuMemoryBuffer(handle, sync_point); |
558 } | 492 } |
559 | 493 |
560 } // namespace content | 494 } // namespace content |
OLD | NEW |