Chromium Code Reviews| Index: chrome/browser/gpu_process_host.cc |
| =================================================================== |
| --- chrome/browser/gpu_process_host.cc (revision 66779) |
| +++ chrome/browser/gpu_process_host.cc (working copy) |
| @@ -202,6 +202,10 @@ |
| OnAcceleratedSurfaceSetIOSurface) |
| IPC_MESSAGE_HANDLER(GpuHostMsg_AcceleratedSurfaceBuffersSwapped, |
| OnAcceleratedSurfaceBuffersSwapped) |
| +#elif defined(OS_WIN) |
| + IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_CreateCompositorHostWindow, |
| + OnCreateCompositorHostWindow) |
| + IPC_MESSAGE_HANDLER(GpuHostMsg_ScheduleComposite, OnScheduleComposite) |
| #endif |
| // If the IO thread does not handle the message then automatically route it |
| // to the UI thread. The UI thread will report an error if it does not |
| @@ -347,6 +351,58 @@ |
| new BuffersSwappedDispatcher( |
| renderer_id, render_view_id, window, surface_id)); |
| } |
| + |
| +#elif defined(OS_WIN) |
| + |
| +namespace { |
| + |
| +void SendDelayedReply(IPC::Message* reply_msg) { |
| + GpuProcessHost::Get()->Send(reply_msg); |
| +} |
| + |
| +void CreateCompositorHostWindowDispatcher( |
| + int renderer_id, |
| + int render_view_id, |
| + IPC::Message* reply_msg) { |
| + RenderViewHost* host = RenderViewHost::FromID(renderer_id, |
|
apatrick_chromium
2010/11/19 23:09:51
What if the renderer process has been destroyed or
nduca
2010/11/20 00:28:49
Done.
|
| + render_view_id); |
| + |
| + RenderWidgetHostView* view = host->view(); |
| + gfx::PluginWindowHandle id = view->CreateCompositorHostWindow(); |
| + |
| + |
| + GpuHostMsg_CreateCompositorHostWindow::WriteReplyParams(reply_msg, id); |
| + BrowserThread::PostTask( |
|
apatrick_chromium
2010/11/19 23:09:51
If this is running on the UI thread it should be i
nduca
2010/11/20 00:28:49
Summarizing verbal conversation: the reason that t
|
| + BrowserThread::IO, FROM_HERE, |
| + NewRunnableFunction(&SendDelayedReply, reply_msg)); |
| +} |
| + |
| +void ScheduleCompositeDispatcher(int renderer_id, int render_view_id) { |
| + RenderViewHost* host = RenderViewHost::FromID(renderer_id, |
| + render_view_id); |
| + DCHECK(host); |
|
apatrick_chromium
2010/11/19 23:09:51
See above about renderer process terminating.
nduca
2010/11/20 00:28:49
Done.
|
| + |
| + |
| + host->ScheduleComposite(); |
| +} |
| +} // namespace |
| + |
| +void GpuProcessHost::OnCreateCompositorHostWindow( |
| + int32 renderer_id, |
| + int32 render_view_id, |
| + IPC::Message* reply_message) { |
| + BrowserThread::PostTask( |
| + BrowserThread::UI, FROM_HERE, |
| + NewRunnableFunction(&CreateCompositorHostWindowDispatcher, |
| + renderer_id, render_view_id, reply_message)); |
| +} |
| + |
| +void GpuProcessHost::OnScheduleComposite(int renderer_id, int render_view_id) { |
|
apatrick_chromium
2010/11/19 23:09:51
Messages received by GpuProcessHost but not handle
nduca
2010/11/20 00:28:49
Done.
|
| + BrowserThread::PostTask( |
| + BrowserThread::UI, FROM_HERE, |
| + NewRunnableFunction(&ScheduleCompositeDispatcher, |
| + renderer_id, render_view_id)); |
| +} |
| #endif |
| void GpuProcessHost::SendEstablishChannelReply( |