| 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/browser_plugin/browser_plugin_message_filter.h" | 5 #include "content/browser/browser_plugin/browser_plugin_message_filter.h" |
| 6 | 6 |
| 7 #include "base/supports_user_data.h" | 7 #include "base/supports_user_data.h" |
| 8 #include "content/browser/browser_plugin/browser_plugin_guest.h" | 8 #include "content/browser/browser_plugin/browser_plugin_guest.h" |
| 9 #include "content/browser/gpu/gpu_process_host.h" | 9 #include "content/browser/gpu/gpu_process_host.h" |
| 10 #include "content/browser/web_contents/web_contents_impl.h" | 10 #include "content/browser/web_contents/web_contents_impl.h" |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 63 WebContents* guest_web_contents) { | 63 WebContents* guest_web_contents) { |
| 64 if (!guest_web_contents) | 64 if (!guest_web_contents) |
| 65 return; | 65 return; |
| 66 static_cast<WebContentsImpl*>(guest_web_contents)->GetBrowserPluginGuest()-> | 66 static_cast<WebContentsImpl*>(guest_web_contents)->GetBrowserPluginGuest()-> |
| 67 OnMessageReceivedFromEmbedder(message); | 67 OnMessageReceivedFromEmbedder(message); |
| 68 } | 68 } |
| 69 | 69 |
| 70 void BrowserPluginMessageFilter::ForwardMessageToGuest( | 70 void BrowserPluginMessageFilter::ForwardMessageToGuest( |
| 71 const IPC::Message& message) { | 71 const IPC::Message& message) { |
| 72 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 72 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 73 RenderProcessHostImpl* host = static_cast<RenderProcessHostImpl*>( | 73 RenderViewHost* rvh = RenderViewHost::FromID(render_process_id_, |
| 74 RenderProcessHost::FromID(render_process_id_)); | 74 message.routing_id()); |
| 75 if (!host) | 75 if (!rvh) |
| 76 return; | 76 return; |
| 77 | 77 |
| 78 int instance_id = 0; | 78 WebContents* embedder_web_contents = WebContents::FromRenderViewHost(rvh); |
| 79 |
| 80 int browser_plugin_instance_id = 0; |
| 79 // All allowed messages must have instance_id as their first parameter. | 81 // All allowed messages must have instance_id as their first parameter. |
| 80 PickleIterator iter(message); | 82 PickleIterator iter(message); |
| 81 bool success = iter.ReadInt(&instance_id); | 83 bool success = iter.ReadInt(&browser_plugin_instance_id); |
| 82 DCHECK(success); | 84 DCHECK(success); |
| 83 host->GetBrowserContext()->GetGuestManager()-> | 85 embedder_web_contents->GetBrowserContext()->GetGuestManager()-> |
| 84 MaybeGetGuestByInstanceIDOrKill( | 86 MaybeGetGuestByInstanceIDOrKill( |
| 85 instance_id, | 87 embedder_web_contents, |
| 86 render_process_id_, | 88 browser_plugin_instance_id, |
| 87 base::Bind(&BrowserPluginGuestMessageCallback, | 89 base::Bind(&BrowserPluginGuestMessageCallback, |
| 88 message)); | 90 message)); |
| 89 } | 91 } |
| 90 | 92 |
| 91 void BrowserPluginMessageFilter::OnSwapBuffersACK( | 93 void BrowserPluginMessageFilter::OnSwapBuffersACK( |
| 92 const FrameHostMsg_BuffersSwappedACK_Params& params) { | 94 const FrameHostMsg_BuffersSwappedACK_Params& params) { |
| 93 GpuProcessHost* gpu_host = GpuProcessHost::FromID(params.gpu_host_id); | 95 GpuProcessHost* gpu_host = GpuProcessHost::FromID(params.gpu_host_id); |
| 94 if (!gpu_host) | 96 if (!gpu_host) |
| 95 return; | 97 return; |
| 96 AcceleratedSurfaceMsg_BufferPresented_Params ack_params; | 98 AcceleratedSurfaceMsg_BufferPresented_Params ack_params; |
| 97 ack_params.mailbox = params.mailbox; | 99 ack_params.mailbox = params.mailbox; |
| 98 ack_params.sync_point = params.sync_point; | 100 ack_params.sync_point = params.sync_point; |
| 99 gpu_host->Send(new AcceleratedSurfaceMsg_BufferPresented(params.gpu_route_id, | 101 gpu_host->Send(new AcceleratedSurfaceMsg_BufferPresented(params.gpu_route_id, |
| 100 ack_params)); | 102 ack_params)); |
| 101 } | 103 } |
| 102 | 104 |
| 103 } // namespace content | 105 } // namespace content |
| OLD | NEW |