diff options
author | backer@chromium.org <backer@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-30 17:42:42 +0000 |
---|---|---|
committer | backer@chromium.org <backer@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-30 17:42:42 +0000 |
commit | dd10939ad6d4d54a9b222d31d68e2596bf588eac (patch) | |
tree | 7d820c3c61e1631acc2e3a470ded1e5a184601ef /gfx/gtk_native_view_id_manager.h | |
parent | 7de8b59cd42e9bd59dd6cf541514ea79b1d2e70a (diff) | |
download | chromium_src-dd10939ad6d4d54a9b222d31d68e2596bf588eac.zip chromium_src-dd10939ad6d4d54a9b222d31d68e2596bf588eac.tar.gz chromium_src-dd10939ad6d4d54a9b222d31d68e2596bf588eac.tar.bz2 |
Defer window destruction until GPU finished drawing.
When a tab is closed, it takes a while before the GPU stops drawing into the window. Destroying the window before the GPU has flushed its drawing pipeline causes unsightly X11 errors. The custom widget class that we use for drawing
tab contents has a lock that is set when the GPU process is drawing to that widget. We use this lock to determine who should delete the associated window:
- if the lock is clear at the time of widget destruction, the widget destroys the window
- if the lock is set, the GPU process signals to the browser to destroy the widget (it has to be done in the browser process b/c the X window is wrapped in a GdkWindow that resides in the browser address space)
Most the management is done in GtkNativeViewManager. I've added another map from XID to GtkWidget to facilitate this management.
BUG=55158
TEST=Open two windows with http://webkit.org/blog-files/3d-transforms/poster-circle.html Close one of them. There should be no X11 errors generated.
Review URL: http://codereview.chromium.org/5275009
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@67719 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'gfx/gtk_native_view_id_manager.h')
-rw-r--r-- | gfx/gtk_native_view_id_manager.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/gfx/gtk_native_view_id_manager.h b/gfx/gtk_native_view_id_manager.h index 513537a..05cf0d7 100644 --- a/gfx/gtk_native_view_id_manager.h +++ b/gfx/gtk_native_view_id_manager.h @@ -12,6 +12,7 @@ #include "gfx/native_widget_types.h" typedef unsigned long XID; +struct _GtkPreserveWindow; // NativeViewIds are the opaque values which the renderer holds as a reference // to a window. These ids are often used in sync calls from the renderer and @@ -70,6 +71,14 @@ class GtkNativeViewManager { // returns: true if |id| is a valid id, false otherwise. bool GetPermanentXIDForId(XID* xid, gfx::NativeViewId id); + // Must be called from the UI thread because we may need to access a + // GtkWidget or destroy a GdkWindow. + // + // If the widget associated with the XID is still alive, allow the widget + // to destroy the associated XID when it wants. Otherwise, destroy the + // GdkWindow associated with the XID. + void ReleasePermanentXID(XID xid); + // These are actually private functions, but need to be called from statics. void OnRealize(gfx::NativeView widget); void OnUnrealize(gfx::NativeView widget); @@ -105,6 +114,26 @@ class GtkNativeViewManager { std::map<gfx::NativeView, gfx::NativeViewId> native_view_to_id_; std::map<gfx::NativeViewId, NativeViewInfo> id_to_info_; + struct PermanentXIDInfo { + PermanentXIDInfo() : widget(NULL), ref_count(0) { + } + _GtkPreserveWindow* widget; + int ref_count; + }; + + // Used to maintain the reference count for permanent XIDs + // (referenced by GetPermanentXIDForId and dereferenced by + // ReleasePermanentXID). Only those XIDs with a positive reference count + // will be in the table. + // + // In general, several GTK widgets may share the same X window. We assume + // that is not true of the widgets stored in this registry. + // + // An XID will map to NULL, if there is an outstanding reference but the + // widget was destroyed. In this case, the destruction of the X window + // is deferred to the dropping of all references. + std::map<XID, PermanentXIDInfo> perm_xid_to_info_; + DISALLOW_COPY_AND_ASSIGN(GtkNativeViewManager); }; |