OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #if defined(ENABLE_GPU) | 5 #if defined(ENABLE_GPU) |
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/process_util.h" | 9 #include "base/process_util.h" |
10 #include "base/shared_memory.h" | 10 #include "base/shared_memory.h" |
(...skipping 366 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
377 params.route_id = route_id(); | 377 params.route_id = route_id(); |
378 params.swap_buffers_count = scheduler_->swap_buffers_count(); | 378 params.swap_buffers_count = scheduler_->swap_buffers_count(); |
379 gpu_channel_manager->Send( | 379 gpu_channel_manager->Send( |
380 new GpuHostMsg_AcceleratedSurfaceBuffersSwapped(params)); | 380 new GpuHostMsg_AcceleratedSurfaceBuffersSwapped(params)); |
381 | 381 |
382 scheduler_->SetScheduled(false); | 382 scheduler_->SetScheduled(false); |
383 } | 383 } |
384 | 384 |
385 void GpuCommandBufferStub::AcceleratedSurfaceBuffersSwapped( | 385 void GpuCommandBufferStub::AcceleratedSurfaceBuffersSwapped( |
386 uint64 swap_buffers_count) { | 386 uint64 swap_buffers_count) { |
387 TRACE_EVENT0("gpu", | 387 TRACE_EVENT1("gpu", |
388 "GpuCommandBufferStub::AcceleratedSurfaceBuffersSwapped"); | 388 "GpuCommandBufferStub::AcceleratedSurfaceBuffersSwapped", |
389 | 389 "frame", swap_buffers_count); |
390 // Multiple swapbuffers may get consolidated together into a single | 390 OnSwapBuffers(); |
391 // AcceleratedSurfaceBuffersSwapped call. Since OnSwapBuffers expects to be | |
392 // called one time for every swap, make up the difference here. | |
393 uint64 delta = swap_buffers_count - | |
394 scheduler_->acknowledged_swap_buffers_count(); | |
395 | 391 |
396 scheduler_->set_acknowledged_swap_buffers_count(swap_buffers_count); | 392 scheduler_->set_acknowledged_swap_buffers_count(swap_buffers_count); |
397 | |
398 for(uint64 i = 0; i < delta; i++) | |
399 OnSwapBuffers(); | |
400 | |
401 // Wake up the GpuScheduler to start doing work again. | 393 // Wake up the GpuScheduler to start doing work again. |
402 scheduler_->SetScheduled(true); | 394 scheduler_->SetScheduled(true); |
403 } | 395 } |
404 #endif // defined(OS_MACOSX) | 396 #endif // defined(OS_MACOSX) |
405 | 397 |
| 398 void GpuCommandBufferStub::CommandBufferWasDestroyed() { |
| 399 TRACE_EVENT0("gpu", "GpuCommandBufferStub::CommandBufferWasDestroyed"); |
| 400 // In case the renderer is currently blocked waiting for a sync reply from |
| 401 // the stub, this method allows us to cleanup and unblock pending messages. |
| 402 while (!scheduler_->IsScheduled()) |
| 403 scheduler_->SetScheduled(true); |
| 404 // Handle any deferred messages now that the scheduler is scheduled. |
| 405 HandleDeferredMessages(); |
| 406 } |
| 407 |
406 void GpuCommandBufferStub::ResizeCallback(gfx::Size size) { | 408 void GpuCommandBufferStub::ResizeCallback(gfx::Size size) { |
407 if (handle_ == gfx::kNullPluginWindow) { | 409 if (handle_ == gfx::kNullPluginWindow) { |
408 scheduler_->decoder()->ResizeOffscreenFrameBuffer(size); | 410 scheduler_->decoder()->ResizeOffscreenFrameBuffer(size); |
409 scheduler_->decoder()->UpdateOffscreenFrameBufferSize(); | 411 scheduler_->decoder()->UpdateOffscreenFrameBufferSize(); |
410 } else { | 412 } else { |
411 #if defined(TOOLKIT_USES_GTK) && !defined(TOUCH_UI) || defined(OS_WIN) | 413 #if defined(TOOLKIT_USES_GTK) && !defined(TOUCH_UI) || defined(OS_WIN) |
412 GpuChannelManager* gpu_channel_manager = channel_->gpu_channel_manager(); | 414 GpuChannelManager* gpu_channel_manager = channel_->gpu_channel_manager(); |
413 gpu_channel_manager->Send( | 415 gpu_channel_manager->Send( |
414 new GpuHostMsg_ResizeView(renderer_id_, | 416 new GpuHostMsg_ResizeView(renderer_id_, |
415 render_view_id_, | 417 render_view_id_, |
(...skipping 28 matching lines...) Expand all Loading... |
444 gfx::GLContext::LosesAllContextsOnContextLost()) { | 446 gfx::GLContext::LosesAllContextsOnContextLost()) { |
445 channel_->LoseAllContexts(); | 447 channel_->LoseAllContexts(); |
446 } else { | 448 } else { |
447 IPC::Message* msg = new GpuCommandBufferMsg_UpdateState(route_id_, state); | 449 IPC::Message* msg = new GpuCommandBufferMsg_UpdateState(route_id_, state); |
448 msg->set_unblock(true); | 450 msg->set_unblock(true); |
449 Send(msg); | 451 Send(msg); |
450 } | 452 } |
451 } | 453 } |
452 | 454 |
453 #endif // defined(ENABLE_GPU) | 455 #endif // defined(ENABLE_GPU) |
OLD | NEW |