Refresh all background instances after suspend if needed
NVIDIA drivers don't preserve FBO contents across suspend / resume cycles which results in broken backgrounds. We can work around that by forcing a refresh when coming out of suspend. https://bugzilla.gnome.org/show_bug.cgi?id=739178
This commit is contained in:
parent
2d71456944
commit
c3bf4a325d
@ -11,6 +11,7 @@ const St = imports.gi.St;
|
|||||||
|
|
||||||
const Background = imports.ui.background;
|
const Background = imports.ui.background;
|
||||||
const BackgroundMenu = imports.ui.backgroundMenu;
|
const BackgroundMenu = imports.ui.backgroundMenu;
|
||||||
|
const LoginManager = imports.misc.loginManager;
|
||||||
|
|
||||||
const DND = imports.ui.dnd;
|
const DND = imports.ui.dnd;
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
@ -273,6 +274,18 @@ const LayoutManager = new Lang.Class({
|
|||||||
global.screen.connect('in-fullscreen-changed',
|
global.screen.connect('in-fullscreen-changed',
|
||||||
Lang.bind(this, this._updateFullscreen));
|
Lang.bind(this, this._updateFullscreen));
|
||||||
this._monitorsChanged();
|
this._monitorsChanged();
|
||||||
|
|
||||||
|
// NVIDIA drivers don't preserve FBO contents across
|
||||||
|
// suspend/resume, see
|
||||||
|
// https://bugzilla.gnome.org/show_bug.cgi?id=739178
|
||||||
|
if (Shell.util_need_background_refresh()) {
|
||||||
|
LoginManager.getLoginManager().connect('prepare-for-sleep',
|
||||||
|
function(lm, suspending) {
|
||||||
|
if (suspending)
|
||||||
|
return;
|
||||||
|
Meta.Background.refresh_all();
|
||||||
|
});
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// This is called by Main after everything else is constructed
|
// This is called by Main after everything else is constructed
|
||||||
|
@ -5,6 +5,9 @@
|
|||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
|
||||||
|
#include <GL/gl.h>
|
||||||
|
#include <cogl/cogl.h>
|
||||||
|
|
||||||
#include "shell-util.h"
|
#include "shell-util.h"
|
||||||
#include <glib/gi18n-lib.h>
|
#include <glib/gi18n-lib.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
@ -358,3 +361,33 @@ shell_util_cursor_tracker_to_clutter (MetaCursorTracker *tracker,
|
|||||||
clutter_actor_hide (CLUTTER_ACTOR (texture));
|
clutter_actor_hide (CLUTTER_ACTOR (texture));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
typedef const gchar *(*ShellGLGetString) (GLenum);
|
||||||
|
|
||||||
|
static const gchar *
|
||||||
|
get_gl_vendor (void)
|
||||||
|
{
|
||||||
|
static const gchar *vendor = NULL;
|
||||||
|
|
||||||
|
if (!vendor)
|
||||||
|
{
|
||||||
|
ShellGLGetString gl_get_string;
|
||||||
|
gl_get_string = (ShellGLGetString) cogl_get_proc_address ("glGetString");
|
||||||
|
if (gl_get_string)
|
||||||
|
vendor = gl_get_string (GL_VENDOR);
|
||||||
|
}
|
||||||
|
|
||||||
|
return vendor;
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
shell_util_need_background_refresh (void)
|
||||||
|
{
|
||||||
|
if (!clutter_check_windowing_backend (CLUTTER_WINDOWING_X11))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (g_strcmp0 (get_gl_vendor (), "NVIDIA Corporation") == 0)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
@ -45,6 +45,8 @@ GdkPixbuf *shell_util_create_pixbuf_from_data (const guchar *data,
|
|||||||
void shell_util_cursor_tracker_to_clutter (MetaCursorTracker *tracker,
|
void shell_util_cursor_tracker_to_clutter (MetaCursorTracker *tracker,
|
||||||
ClutterTexture *texture);
|
ClutterTexture *texture);
|
||||||
|
|
||||||
|
gboolean shell_util_need_background_refresh (void);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __SHELL_UTIL_H__ */
|
#endif /* __SHELL_UTIL_H__ */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user