Chromium Code Reviews| Index: chrome/browser/gpu_process_host.cc |
| =================================================================== |
| --- chrome/browser/gpu_process_host.cc (revision 65702) |
| +++ chrome/browser/gpu_process_host.cc (working copy) |
| @@ -194,6 +194,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 |
| IPC_MESSAGE_UNHANDLED_ERROR() |
| IPC_END_MESSAGE_MAP() |
| @@ -342,6 +346,62 @@ |
| 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( |
| + int32 renderer_id, |
| + int32 render_view_id, |
| + IPC::Message* reply_msg) { |
| + |
|
jam
2010/11/12 18:08:00
nit:extra line
nduca
2010/11/12 19:45:32
Done.
|
| + RenderViewHost* host = RenderViewHost::FromID(renderer_id, |
| + render_view_id); |
| + DCHECK(host); |
|
jam
2010/11/12 18:08:00
this, and 368: we normally don't add NULL dchecks
nduca
2010/11/12 19:45:32
Done.
|
| + |
| + RenderWidgetHostView* view = host->view(); |
| + DCHECK(view); |
| + gfx::PluginWindowHandle id = view->CreateCompositorHostWindow(); |
| + |
| + GpuHostMsg_CreateCompositorHostWindow::WriteReplyParams(reply_msg, id); |
| + |
| + // Have to reply from IO thread. |
|
jam
2010/11/12 18:08:00
you can actually just do host->Send directly
nduca
2010/11/12 19:45:32
Done.
jam
2010/11/12 20:34:41
I actually meant "host->Send", i.e. using the Rend
|
| + BrowserThread::PostTask( |
| + BrowserThread::IO, FROM_HERE, |
| + NewRunnableFunction(&SendDelayedReply, reply_msg)); |
| +} |
| + |
| +void ScheduleCompositeDispatcher(int32 renderer_id, int32 render_view_id) { |
| + RenderViewHost* host = RenderViewHost::FromID(renderer_id, |
| + render_view_id); |
| + DCHECK(host); |
| + |
| + |
| + 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) { |
| + BrowserThread::PostTask( |
| + BrowserThread::UI, FROM_HERE, |
| + NewRunnableFunction(&ScheduleCompositeDispatcher, |
| + renderer_id, render_view_id)); |
| +} |
| #endif |
| void GpuProcessHost::ReplyToRenderer( |