From: "Alexandre Restovtsev" <tetromino@gmail.com>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/gnome:master commit in: gnome-base/gnome-desktop/, gnome-base/gnome-desktop/files/
Date: Tue, 4 Oct 2011 04:04:33 +0000 (UTC) [thread overview]
Message-ID: <e90a114d0f5819701c5113bf436304f9a743ce51.tetromino@gentoo> (raw)
commit: e90a114d0f5819701c5113bf436304f9a743ce51
Author: Alexandre Rostovtsev <tetromino <AT> gmail <DOT> com>
AuthorDate: Tue Oct 4 03:12:28 2011 +0000
Commit: Alexandre Restovtsev <tetromino <AT> gmail <DOT> com>
CommitDate: Tue Oct 4 03:12:28 2011 +0000
URL: http://git.overlays.gentoo.org/gitweb/?p=proj/gnome.git;a=commit;h=e90a114d
gnome-base/gnome-desktop: add DPMS timeout clearing and fix wall clock fallback
Add upstream patches to add a gnome_rr_screen_clear_dpms_timeouts()
function to clear DPMS timeouts (needed for gnome-settins-daemon), and
to fix the wall clock fallback code to not hang gnome-screensaver.
---
...ome-desktop-3.2.0-GnomeWallClock-fallback.patch | 47 ++++++++
...3.2.0-gnome_rr_screen_clear_dpms_timeouts.patch | 116 ++++++++++++++++++++
...-3.2.0.ebuild => gnome-desktop-3.2.0-r1.ebuild} | 12 ++-
3 files changed, 174 insertions(+), 1 deletions(-)
diff --git a/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-GnomeWallClock-fallback.patch b/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-GnomeWallClock-fallback.patch
new file mode 100644
index 0000000..82b59c5
--- /dev/null
+++ b/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-GnomeWallClock-fallback.patch
@@ -0,0 +1,47 @@
+From 311476792ba7948f0eba5e4d9a1328cf3ff18950 Mon Sep 17 00:00:00 2001
+From: Colin Walters <walters@verbum.org>
+Date: Mon, 3 Oct 2011 16:35:20 -0400
+Subject: [PATCH 2/2] GnomeWallClock: Fix non-Linux fallback code
+
+This fixes the "infinite loop in gnome-screensaver" bug. Only
+dispatch in cancel on set when the monotonic timeout has expired,
+otherwise we will drop into a tight loop.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=660343
+---
+ libgnome-desktop/gnome-datetime-source.c | 9 ++++++---
+ 1 files changed, 6 insertions(+), 3 deletions(-)
+
+diff --git a/libgnome-desktop/gnome-datetime-source.c b/libgnome-desktop/gnome-datetime-source.c
+index 05ec80a..a35d5b3 100644
+--- a/libgnome-desktop/gnome-datetime-source.c
++++ b/libgnome-desktop/gnome-datetime-source.c
+@@ -57,8 +57,10 @@ static gboolean
+ g_datetime_source_is_expired (GDateTimeSource *datetime_source)
+ {
+ gint64 real_now;
++ gint64 monotonic_now;
+
+ real_now = g_get_real_time ();
++ monotonic_now = g_source_get_time ((GSource*)datetime_source);
+
+ if (datetime_source->initially_expired)
+ return TRUE;
+@@ -66,10 +68,11 @@ g_datetime_source_is_expired (GDateTimeSource *datetime_source)
+ if (datetime_source->real_expiration <= real_now)
+ return TRUE;
+
+- /* We can't really detect without system support when things change;
+- * so just trigger every second.
++ /* We can't really detect without system support when things
++ * change; so just trigger every second (i.e. our wakeup
++ * expiration)
+ */
+- if (datetime_source->cancel_on_set)
++ if (datetime_source->cancel_on_set && monotonic_now >= datetime_source->wakeup_expiration)
+ return TRUE;
+
+ return FALSE;
+--
+1.7.7
+
diff --git a/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-gnome_rr_screen_clear_dpms_timeouts.patch b/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-gnome_rr_screen_clear_dpms_timeouts.patch
new file mode 100644
index 0000000..4e6d780
--- /dev/null
+++ b/gnome-base/gnome-desktop/files/gnome-desktop-3.2.0-gnome_rr_screen_clear_dpms_timeouts.patch
@@ -0,0 +1,116 @@
+From 55daaf0972c0021a20624dcd16df5e14cca5d430 Mon Sep 17 00:00:00 2001
+From: Richard Hughes <richard@hughsie.com>
+Date: Mon, 3 Oct 2011 16:19:23 +0100
+Subject: [PATCH 1/2] When setting the DPMS mode manually, clear the timeouts
+
+Based on a patch from Michael Vogt, many thanks.
+
+Resolves https://bugzilla.gnome.org/show_bug.cgi?id=660482
+---
+ libgnome-desktop/gnome-rr.c | 57 ++++++++++++++++++++++++++++++++++++++++---
+ 1 files changed, 53 insertions(+), 4 deletions(-)
+
+diff --git a/libgnome-desktop/gnome-rr.c b/libgnome-desktop/gnome-rr.c
+index d5f0590..465dee9 100644
+--- a/libgnome-desktop/gnome-rr.c
++++ b/libgnome-desktop/gnome-rr.c
+@@ -1234,7 +1234,36 @@ out:
+ }
+
+ /**
++ * gnome_rr_screen_clear_dpms_timeouts:
++ **/
++static gboolean
++gnome_rr_screen_clear_dpms_timeouts (GnomeRRScreen *screen,
++ GError **error)
++{
++ gboolean ret = TRUE;
++ gint rc;
++
++ gdk_error_trap_push ();
++ rc = DPMSSetTimeouts (screen->priv->xdisplay, 0, 0, 0);
++ if (gdk_error_trap_pop ())
++ ret = FALSE;
++
++ if (!ret || rc != Success) {
++ ret = FALSE;
++ g_set_error_literal (error,
++ GNOME_RR_ERROR,
++ GNOME_RR_ERROR_UNKNOWN,
++ "Could not set DPMS timeouts");
++ goto out;
++ }
++out:
++ return ret;
++}
++
++/**
+ * gnome_rr_screen_set_dpms_mode:
++ *
++ * This method also disables the DPMS timeouts.
+ **/
+ gboolean
+ gnome_rr_screen_set_dpms_mode (GnomeRRScreen *screen,
+@@ -1243,6 +1272,7 @@ gnome_rr_screen_set_dpms_mode (GnomeRRScreen *screen,
+ {
+ CARD16 state = 0;
+ gboolean ret;
++ gint rc;
+ GnomeRRDpmsMode current_mode;
+
+ g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
+@@ -1251,8 +1281,10 @@ gnome_rr_screen_set_dpms_mode (GnomeRRScreen *screen,
+ ret = gnome_rr_screen_get_dpms_mode (screen, ¤t_mode, error);
+ if (!ret)
+ goto out;
+- if (current_mode == mode)
++ if (current_mode == mode) {
++ ret = gnome_rr_screen_clear_dpms_timeouts (screen, error);
+ goto out;
++ }
+
+ switch (mode) {
+ case GNOME_RR_DPMS_ON:
+@@ -1273,12 +1305,11 @@ gnome_rr_screen_set_dpms_mode (GnomeRRScreen *screen,
+ }
+
+ gdk_error_trap_push ();
+- ret = DPMSForceLevel (screen->priv->xdisplay, state);
+- gdk_flush ();
++ rc = DPMSForceLevel (screen->priv->xdisplay, state);
+ if (gdk_error_trap_pop ())
+ ret = FALSE;
+
+- if (!ret) {
++ if (!ret || rc != Success) {
+ ret = FALSE;
+ g_set_error_literal (error,
+ GNOME_RR_ERROR,
+@@ -1286,6 +1317,24 @@ gnome_rr_screen_set_dpms_mode (GnomeRRScreen *screen,
+ "Could not change DPMS mode");
+ goto out;
+ }
++
++ gdk_error_trap_push ();
++ rc = DPMSSetTimeouts (screen->priv->xdisplay, 0, 0, 0);
++ if (gdk_error_trap_pop ())
++ ret = FALSE;
++
++ if (!ret || rc != Success) {
++ ret = FALSE;
++ g_set_error_literal (error,
++ GNOME_RR_ERROR,
++ GNOME_RR_ERROR_UNKNOWN,
++ "Could not set DPMS timeouts");
++ goto out;
++ }
++
++ ret = gnome_rr_screen_clear_dpms_timeouts (screen, error);
++ if (!ret)
++ goto out;
+ out:
+ return ret;
+ }
+--
+1.7.7
+
diff --git a/gnome-base/gnome-desktop/gnome-desktop-3.2.0.ebuild b/gnome-base/gnome-desktop/gnome-desktop-3.2.0-r1.ebuild
similarity index 89%
rename from gnome-base/gnome-desktop/gnome-desktop-3.2.0.ebuild
rename to gnome-base/gnome-desktop/gnome-desktop-3.2.0-r1.ebuild
index 300f0d8..ffbc212 100644
--- a/gnome-base/gnome-desktop/gnome-desktop-3.2.0.ebuild
+++ b/gnome-base/gnome-desktop/gnome-desktop-3.2.0-r1.ebuild
@@ -6,7 +6,7 @@ EAPI="4"
GCONF_DEBUG="yes"
GNOME2_LA_PUNT="yes"
-inherit gnome2
+inherit eutils gnome2
if [[ ${PV} = 9999 ]]; then
inherit git-2 gnome2-live
fi
@@ -85,3 +85,13 @@ src_unpack() {
die "ln -sf failed"
fi
}
+
+src_prepare() {
+ # Useful upstream patches, will be in next release
+ # Clear DPMS timeouts, bug #385063
+ epatch "${FILESDIR}/${P}-gnome_rr_screen_clear_dpms_timeouts.patch"
+ # Fix GNomeWallClock fallback code
+ epatch "${FILESDIR}/${P}-GnomeWallClock-fallback.patch"
+
+ gnome2_src_prepare
+}
next reply other threads:[~2011-10-04 4:04 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-10-04 4:04 Alexandre Restovtsev [this message]
-- strict thread matches above, loose matches on Subject: below --
2019-09-14 21:00 [gentoo-commits] proj/gnome:master commit in: gnome-base/gnome-desktop/, gnome-base/gnome-desktop/files/ Sobhan Mohammadpour
2019-02-23 20:37 Mart Raudsepp
2018-11-16 17:25 Gilles Dartiguelongue
2012-11-21 22:27 Gilles Dartiguelongue
2012-10-28 16:42 Gilles Dartiguelongue
2011-10-18 7:37 Alexandre Restovtsev
2011-10-05 8:00 Alexandre Restovtsev
2011-05-30 17:11 Nirbheek Chauhan
2011-05-02 15:56 Nirbheek Chauhan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=e90a114d0f5819701c5113bf436304f9a743ce51.tetromino@gentoo \
--to=tetromino@gmail.com \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox