diff options
author | backer@chromium.org <backer@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-01-21 18:37:37 +0000 |
---|---|---|
committer | backer@chromium.org <backer@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-01-21 18:37:37 +0000 |
commit | 9cf72aecda4f6c4279cbe397e6c133bbebb8c642 (patch) | |
tree | f8247c528f2a592f395cecc5217180cccbefd985 | |
parent | 34609b27e746a43a75a8139b5a22fcb007c4c057 (diff) | |
download | chromium_src-9cf72aecda4f6c4279cbe397e6c133bbebb8c642.zip chromium_src-9cf72aecda4f6c4279cbe397e6c133bbebb8c642.tar.gz chromium_src-9cf72aecda4f6c4279cbe397e6c133bbebb8c642.tar.bz2 |
Refactor GPUProcessHost to eliminate redundancy.
There was a lot of thread hopping from IO to UI back to IO to answer requests. This is was GpuProcessHostUIShim is for. Refactored to take advantage of it.
BUG=none
TEST=by hand and trybots
Review URL: http://codereview.chromium.org/6374007
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@72161 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/gpu_process_host.cc | 250 | ||||
-rw-r--r-- | chrome/browser/gpu_process_host.h | 20 | ||||
-rw-r--r-- | chrome/browser/gpu_process_host_ui_shim.cc | 127 | ||||
-rw-r--r-- | chrome/browser/gpu_process_host_ui_shim.h | 24 |
4 files changed, 149 insertions, 272 deletions
diff --git a/chrome/browser/gpu_process_host.cc b/chrome/browser/gpu_process_host.cc index a99db71..d3b8342f 100644 --- a/chrome/browser/gpu_process_host.cc +++ b/chrome/browser/gpu_process_host.cc @@ -13,8 +13,6 @@ #include "chrome/browser/gpu_blacklist.h" #include "chrome/browser/gpu_process_host_ui_shim.h" #include "chrome/browser/renderer_host/render_message_filter.h" -#include "chrome/browser/renderer_host/render_view_host.h" -#include "chrome/browser/renderer_host/render_widget_host_view.h" #include "chrome/browser/tab_contents/render_view_host_delegate_helper.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/gpu_feature_flags.h" @@ -28,15 +26,6 @@ #include "media/base/media_switches.h" #include "ui/base/resource/resource_bundle.h" -#if defined(OS_LINUX) -// These two #includes need to come after render_messages.h. -#include <gdk/gdkwindow.h> // NOLINT -#include <gdk/gdkx.h> // NOLINT -#include "gfx/gtk_native_view_id_manager.h" -#include "gfx/size.h" -#include "ui/base/x/x11_util.h" -#endif // defined(OS_LINUX) - namespace { enum GPUBlacklistTestResult { @@ -225,19 +214,6 @@ bool GpuProcessHost::OnControlMessageReceived(const IPC::Message& message) { IPC_BEGIN_MESSAGE_MAP(GpuProcessHost, message) IPC_MESSAGE_HANDLER(GpuHostMsg_ChannelEstablished, OnChannelEstablished) IPC_MESSAGE_HANDLER(GpuHostMsg_SynchronizeReply, OnSynchronizeReply) -#if defined(OS_LINUX) - IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_GetViewXID, OnGetViewXID) - IPC_MESSAGE_HANDLER(GpuHostMsg_ReleaseXID, OnReleaseXID) - IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_ResizeXID, OnResizeXID) -#elif defined(OS_MACOSX) - IPC_MESSAGE_HANDLER(GpuHostMsg_AcceleratedSurfaceSetIOSurface, - OnAcceleratedSurfaceSetIOSurface) - IPC_MESSAGE_HANDLER(GpuHostMsg_AcceleratedSurfaceBuffersSwapped, - OnAcceleratedSurfaceBuffersSwapped) -#elif defined(OS_WIN) - IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_GetCompositorHostWindow, - OnGetCompositorHostWindow) -#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 // handle it. @@ -285,232 +261,6 @@ void GpuProcessHost::OnSynchronizeReply() { } } -#if defined(OS_LINUX) - -namespace { - -void SendDelayedReply(IPC::Message* reply_msg) { - GpuProcessHost::Get()->Send(reply_msg); -} - -void GetViewXIDDispatcher(gfx::NativeViewId id, IPC::Message* reply_msg) { - XID xid; - - GtkNativeViewManager* manager = GtkNativeViewManager::GetInstance(); - if (!manager->GetPermanentXIDForId(&xid, id)) { - DLOG(ERROR) << "Can't find XID for view id " << id; - xid = 0; - } - - GpuHostMsg_GetViewXID::WriteReplyParams(reply_msg, xid); - - // Have to reply from IO thread. - BrowserThread::PostTask( - BrowserThread::IO, FROM_HERE, - NewRunnableFunction(&SendDelayedReply, reply_msg)); -} - -void ReleaseXIDDispatcher(unsigned long xid) { - GtkNativeViewManager* manager = GtkNativeViewManager::GetInstance(); - manager->ReleasePermanentXID(xid); -} - -void ResizeXIDDispatcher(unsigned long xid, gfx::Size size, - IPC::Message *reply_msg) { - GdkWindow* window = reinterpret_cast<GdkWindow*>(gdk_xid_table_lookup(xid)); - if (window) { - Display* display = GDK_WINDOW_XDISPLAY(window); - gdk_window_resize(window, size.width(), size.height()); - XSync(display, False); - } - - GpuHostMsg_ResizeXID::WriteReplyParams(reply_msg, (window != NULL)); - - // Have to reply from IO thread. - BrowserThread::PostTask( - BrowserThread::IO, FROM_HERE, - NewRunnableFunction(&SendDelayedReply, reply_msg)); -} - -} // namespace - -void GpuProcessHost::OnGetViewXID(gfx::NativeViewId id, - IPC::Message *reply_msg) { - // Have to request a permanent XID from UI thread. - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - NewRunnableFunction(&GetViewXIDDispatcher, id, reply_msg)); -} - -void GpuProcessHost::OnReleaseXID(unsigned long xid) { - // Have to release a permanent XID from UI thread. - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - NewRunnableFunction(&ReleaseXIDDispatcher, xid)); -} - -void GpuProcessHost::OnResizeXID(unsigned long xid, gfx::Size size, - IPC::Message *reply_msg) { - // Have to resize the window from UI thread. - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - NewRunnableFunction(&ResizeXIDDispatcher, xid, size, reply_msg)); -} - -#elif defined(OS_MACOSX) - -namespace { - -class SetIOSurfaceDispatcher : public Task { - public: - SetIOSurfaceDispatcher( - const GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params& params) - : params_(params) { - } - - void Run() { - RenderViewHost* host = RenderViewHost::FromID(params_.renderer_id, - params_.render_view_id); - if (!host) - return; - RenderWidgetHostView* view = host->view(); - if (!view) - return; - view->AcceleratedSurfaceSetIOSurface(params_.window, - params_.width, - params_.height, - params_.identifier); - } - - private: - GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params params_; - - DISALLOW_COPY_AND_ASSIGN(SetIOSurfaceDispatcher); -}; - -} // namespace - -void GpuProcessHost::OnAcceleratedSurfaceSetIOSurface( - const GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params& params) { - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - new SetIOSurfaceDispatcher(params)); -} - -namespace { - -class BuffersSwappedDispatcher : public Task { - public: - BuffersSwappedDispatcher( - int renderer_id, - int render_view_id, - gfx::PluginWindowHandle window, - uint64 surface_id, - int32 route_id, - uint64 swap_buffers_count) - : renderer_id_(renderer_id), - render_view_id_(render_view_id), - window_(window), - surface_id_(surface_id), - route_id_(route_id), - swap_buffers_count_(swap_buffers_count) { - } - - void Run() { - RenderViewHost* host = RenderViewHost::FromID(renderer_id_, - render_view_id_); - if (!host) - return; - RenderWidgetHostView* view = host->view(); - if (!view) - return; - view->AcceleratedSurfaceBuffersSwapped( - // Parameters needed to swap the IOSurface. - window_, - surface_id_, - // Parameters needed to formulate an acknowledgment. - renderer_id_, - route_id_, - swap_buffers_count_); - } - - private: - int renderer_id_; - int render_view_id_; - gfx::PluginWindowHandle window_; - uint64 surface_id_; - int32 route_id_; - uint64 swap_buffers_count_; - - DISALLOW_COPY_AND_ASSIGN(BuffersSwappedDispatcher); -}; - -} // namespace - -void GpuProcessHost::OnAcceleratedSurfaceBuffersSwapped( - const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params) { - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - new BuffersSwappedDispatcher( - // These are the parameters needed to look up the IOSurface - // on this side. - params.renderer_id, - params.render_view_id, - params.window, - params.surface_id, - // These are additional parameters needed to formulate an - // acknowledgment. - params.route_id, - params.swap_buffers_count)); -} - -#elif defined(OS_WIN) - -namespace { - -void SendDelayedReply(IPC::Message* reply_msg) { - GpuProcessHost::Get()->Send(reply_msg); -} - -void GetCompositorHostWindowDispatcher( - int renderer_id, - int render_view_id, - IPC::Message* reply_msg) { - RenderViewHost* host = RenderViewHost::FromID(renderer_id, - render_view_id); - if (!host) { - GpuHostMsg_GetCompositorHostWindow::WriteReplyParams(reply_msg, - gfx::kNullPluginWindow); - BrowserThread::PostTask( - BrowserThread::IO, FROM_HERE, - NewRunnableFunction(&SendDelayedReply, reply_msg)); - return; - } - - RenderWidgetHostView* view = host->view(); - gfx::PluginWindowHandle id = view->GetCompositorHostWindow(); - - - GpuHostMsg_GetCompositorHostWindow::WriteReplyParams(reply_msg, id); - BrowserThread::PostTask( - BrowserThread::IO, FROM_HERE, - NewRunnableFunction(&SendDelayedReply, reply_msg)); -} - -} // namespace - -void GpuProcessHost::OnGetCompositorHostWindow( - int renderer_id, - int render_view_id, - IPC::Message* reply_message) { - BrowserThread::PostTask( - BrowserThread::UI, FROM_HERE, - NewRunnableFunction(&GetCompositorHostWindowDispatcher, - renderer_id, render_view_id, reply_message)); -} - -#endif - void GpuProcessHost::SendEstablishChannelReply( const IPC::ChannelHandle& channel, const GPUInfo& gpu_info, diff --git a/chrome/browser/gpu_process_host.h b/chrome/browser/gpu_process_host.h index 5958a3b..8339f10 100644 --- a/chrome/browser/gpu_process_host.h +++ b/chrome/browser/gpu_process_host.h @@ -14,16 +14,10 @@ #include "chrome/browser/browser_child_process_host.h" #include "gfx/native_widget_types.h" -struct GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params; -struct GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params; class GpuBlacklist; class GPUInfo; class RenderMessageFilter; -namespace gfx { -class Size; -} - namespace IPC { struct ChannelHandle; class Message; @@ -84,20 +78,6 @@ class GpuProcessHost : public BrowserChildProcessHost, void OnChannelEstablished(const IPC::ChannelHandle& channel_handle, const GPUInfo& gpu_info); void OnSynchronizeReply(); -#if defined(OS_LINUX) - void OnGetViewXID(gfx::NativeViewId id, IPC::Message* reply_msg); - void OnReleaseXID(unsigned long xid); - void OnResizeXID(unsigned long xid, gfx::Size size, IPC::Message* reply_msg); -#elif defined(OS_MACOSX) - void OnAcceleratedSurfaceSetIOSurface( - const GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params& params); - void OnAcceleratedSurfaceBuffersSwapped( - const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params); -#elif defined(OS_WIN) - void OnGetCompositorHostWindow(int renderer_id, - int render_view_id, - IPC::Message* reply_message); -#endif // Sends the response for establish channel request to the renderer. void SendEstablishChannelReply(const IPC::ChannelHandle& channel, diff --git a/chrome/browser/gpu_process_host_ui_shim.cc b/chrome/browser/gpu_process_host_ui_shim.cc index 87c7be2..5419a44 100644 --- a/chrome/browser/gpu_process_host_ui_shim.cc +++ b/chrome/browser/gpu_process_host_ui_shim.cc @@ -7,9 +7,19 @@ #include "chrome/browser/browser_thread.h" #include "chrome/browser/gpu_process_host.h" #include "chrome/browser/renderer_host/render_view_host.h" +#include "chrome/browser/renderer_host/render_widget_host_view.h" #include "chrome/common/child_process_logging.h" #include "chrome/common/gpu_messages.h" +#if defined(OS_LINUX) +// These two #includes need to come after gpu_messages.h. +#include <gdk/gdkwindow.h> // NOLINT +#include <gdk/gdkx.h> // NOLINT +#include "ui/base/x/x11_util.h" +#include "gfx/gtk_native_view_id_manager.h" +#include "gfx/size.h" +#endif // defined(OS_LINUX) + // Tasks used by this file namespace { @@ -110,6 +120,109 @@ void GpuProcessHostUIShim::OnGraphicsInfoCollected(const GPUInfo& gpu_info) { gpu_info_collected_callback_->Run(); } +namespace { + +void SendDelayedReply(IPC::Message* reply_msg) { + BrowserThread::PostTask( + BrowserThread::IO, + FROM_HERE, + new SendOnIOThreadTask(reply_msg)); +} + +} // namespace + +#if defined(OS_LINUX) + +void GpuProcessHostUIShim::OnGetViewXID(gfx::NativeViewId id, + IPC::Message* reply_msg) { + XID xid; + + GtkNativeViewManager* manager = GtkNativeViewManager::GetInstance(); + if (!manager->GetPermanentXIDForId(&xid, id)) { + DLOG(ERROR) << "Can't find XID for view id " << id; + xid = 0; + } + + GpuHostMsg_GetViewXID::WriteReplyParams(reply_msg, xid); + SendDelayedReply(reply_msg); +} + +void GpuProcessHostUIShim::OnReleaseXID(unsigned long xid) { + GtkNativeViewManager* manager = GtkNativeViewManager::GetInstance(); + manager->ReleasePermanentXID(xid); +} + +void GpuProcessHostUIShim::OnResizeXID(unsigned long xid, gfx::Size size, + IPC::Message *reply_msg) { + GdkWindow* window = reinterpret_cast<GdkWindow*>(gdk_xid_table_lookup(xid)); + if (window) { + Display* display = GDK_WINDOW_XDISPLAY(window); + gdk_window_resize(window, size.width(), size.height()); + XSync(display, False); + } + + GpuHostMsg_ResizeXID::WriteReplyParams(reply_msg, (window != NULL)); + SendDelayedReply(reply_msg); +} + +#elif defined(OS_MACOSX) + +void GpuProcessHostUIShim::OnAcceleratedSurfaceSetIOSurface( + const GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params& params) { + RenderViewHost* host = RenderViewHost::FromID(params.renderer_id, + params.render_view_id); + if (!host) + return; + RenderWidgetHostView* view = host->view(); + if (!view) + return; + view->AcceleratedSurfaceSetIOSurface(params.window, + params.width, + params.height, + params.identifier); +} + +void GpuProcessHostUIShim::OnAcceleratedSurfaceBuffersSwapped( + const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params) { + RenderViewHost* host = RenderViewHost::FromID(params.renderer_id, + params.render_view_id); + if (!host) + return; + RenderWidgetHostView* view = host->view(); + if (!view) + return; + view->AcceleratedSurfaceBuffersSwapped( + // Parameters needed to swap the IOSurface. + params.window, + params.surface_id, + // Parameters needed to formulate an acknowledgment. + params.renderer_id, + params.route_id, + params.swap_buffers_count); +} + +#elif defined(OS_WIN) + +void GpuProcessHostUIShim::OnGetCompositorHostWindow( + int renderer_id, + int render_view_id, + IPC::Message* reply_msg) { + RenderViewHost* host = RenderViewHost::FromID(renderer_id, + render_view_id); + if (!host) { + GpuHostMsg_GetCompositorHostWindow::WriteReplyParams(reply_msg, + gfx::kNullPluginWindow); + SendDelayedReply(reply_msg); + return; + } + + RenderWidgetHostView* view = host->view(); + gfx::PluginWindowHandle id = view->GetCompositorHostWindow(); + + GpuHostMsg_GetCompositorHostWindow::WriteReplyParams(reply_msg, id); + SendDelayedReply(reply_msg); +} + void GpuProcessHostUIShim::OnScheduleComposite(int renderer_id, int render_view_id) { RenderViewHost* host = RenderViewHost::FromID(renderer_id, @@ -119,6 +232,7 @@ void GpuProcessHostUIShim::OnScheduleComposite(int renderer_id, } host->ScheduleComposite(); } +#endif bool GpuProcessHostUIShim::OnControlMessageReceived( const IPC::Message& message) { @@ -127,7 +241,18 @@ bool GpuProcessHostUIShim::OnControlMessageReceived( IPC_BEGIN_MESSAGE_MAP(GpuProcessHostUIShim, message) IPC_MESSAGE_HANDLER(GpuHostMsg_GraphicsInfoCollected, OnGraphicsInfoCollected) -#if defined(OS_WIN) +#if defined(OS_LINUX) + IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_GetViewXID, OnGetViewXID) + IPC_MESSAGE_HANDLER(GpuHostMsg_ReleaseXID, OnReleaseXID) + IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_ResizeXID, OnResizeXID) +#elif defined(OS_MACOSX) + IPC_MESSAGE_HANDLER(GpuHostMsg_AcceleratedSurfaceSetIOSurface, + OnAcceleratedSurfaceSetIOSurface) + IPC_MESSAGE_HANDLER(GpuHostMsg_AcceleratedSurfaceBuffersSwapped, + OnAcceleratedSurfaceBuffersSwapped) +#elif defined(OS_WIN) + IPC_MESSAGE_HANDLER_DELAY_REPLY(GpuHostMsg_GetCompositorHostWindow, + OnGetCompositorHostWindow) IPC_MESSAGE_HANDLER(GpuHostMsg_ScheduleComposite, OnScheduleComposite); #endif IPC_MESSAGE_UNHANDLED_ERROR() diff --git a/chrome/browser/gpu_process_host_ui_shim.h b/chrome/browser/gpu_process_host_ui_shim.h index 17bf970..f070ed1 100644 --- a/chrome/browser/gpu_process_host_ui_shim.h +++ b/chrome/browser/gpu_process_host_ui_shim.h @@ -20,6 +20,13 @@ #include "ipc/ipc_channel.h" #include "gfx/native_widget_types.h" +namespace gfx { +class Size; +} + +struct GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params; +struct GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params; + class GpuProcessHostUIShim : public IPC::Channel::Sender, public IPC::Channel::Listener, public base::NonThreadSafe { @@ -71,9 +78,24 @@ class GpuProcessHostUIShim : public IPC::Channel::Sender, // Message handlers. void OnGraphicsInfoCollected(const GPUInfo& gpu_info); - void OnScheduleComposite(int32 renderer_id, int32 render_view_id); bool OnControlMessageReceived(const IPC::Message& message); +#if defined(OS_LINUX) + void OnGetViewXID(gfx::NativeViewId id, IPC::Message* reply_msg); + void OnReleaseXID(unsigned long xid); + void OnResizeXID(unsigned long xid, gfx::Size size, IPC::Message* reply_msg); +#elif defined(OS_MACOSX) + void OnAcceleratedSurfaceSetIOSurface( + const GpuHostMsg_AcceleratedSurfaceSetIOSurface_Params& params); + void OnAcceleratedSurfaceBuffersSwapped( + const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params); +#elif defined(OS_WIN) + void OnGetCompositorHostWindow(int renderer_id, + int render_view_id, + IPC::Message* reply_message); + void OnScheduleComposite(int32 renderer_id, int32 render_view_id); +#endif + int last_routing_id_; GPUInfo gpu_info_; |