[mutter/wip/display-no-wayland: 24/33] MonitorManager: store the presentation mode bit in XRandR
- From: Giovanni Campagna <gcampagna src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/display-no-wayland: 24/33] MonitorManager: store the presentation mode bit in XRandR
- Date: Fri, 16 Aug 2013 14:40:39 +0000 (UTC)
commit 49d64dcdccc0fe0f1c61bbc2dff47ea73e299089
Author: Giovanni Campagna <gcampagn redhat com>
Date: Thu Jul 25 11:16:51 2013 +0200
MonitorManager: store the presentation mode bit in XRandR
Use a private output property to store if the output is in
presentation mode or not, so that this information is not lost
after the configuration read back from the server.
https://bugzilla.gnome.org/show_bug.cgi?id=705670
src/core/monitor.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++-
src/meta/atomnames.h | 1 +
2 files changed, 51 insertions(+), 2 deletions(-)
---
diff --git a/src/core/monitor.c b/src/core/monitor.c
index d5dfdb6..ef6240e 100644
--- a/src/core/monitor.c
+++ b/src/core/monitor.c
@@ -33,6 +33,7 @@
#include <clutter/clutter.h>
#ifdef HAVE_RANDR
+#include <X11/Xatom.h>
#include <X11/extensions/Xrandr.h>
#include <X11/extensions/dpms.h>
#endif
@@ -339,6 +340,34 @@ wl_transform_from_xrandr_all (Rotation rotation)
return ret;
}
+static gboolean
+output_get_presentation_xrandr (MetaMonitorManager *manager,
+ MetaOutput *output)
+{
+ MetaDisplay *display = meta_get_display ();
+ gboolean value;
+ Atom actual_type;
+ int actual_format;
+ unsigned long nitems, bytes_after;
+ unsigned char *buffer;
+
+ XRRGetOutputProperty (manager->xdisplay,
+ (XID)output->output_id,
+ display->atom__MUTTER_PRESENTATION_OUTPUT,
+ 0, G_MAXLONG, False, False, XA_CARDINAL,
+ &actual_type, &actual_format,
+ &nitems, &bytes_after, &buffer);
+
+ if (actual_type != XA_CARDINAL || actual_format != 32 ||
+ nitems < 1)
+ return FALSE;
+
+ value = ((int*)buffer)[0];
+
+ XFree (buffer);
+ return value;
+}
+
static int
compare_outputs (const void *one,
const void *two)
@@ -539,7 +568,7 @@ read_monitor_infos_from_xrandr (MetaMonitorManager *manager)
}
meta_output->is_primary = ((XID)meta_output->output_id == primary_output);
- meta_output->is_presentation = FALSE;
+ meta_output->is_presentation = output_get_presentation_xrandr (manager, meta_output);
n_actual_outputs++;
}
@@ -1163,7 +1192,22 @@ wl_transform_to_xrandr (enum wl_output_transform transform)
g_assert_not_reached ();
}
-
+
+static void
+output_set_presentation_xrandr (MetaMonitorManager *manager,
+ MetaOutput *output,
+ gboolean presentation)
+{
+ MetaDisplay *display = meta_get_display ();
+ int value = presentation;
+
+ XRRChangeOutputProperty (manager->xdisplay,
+ (XID)output->output_id,
+ display->atom__MUTTER_PRESENTATION_OUTPUT,
+ XA_CARDINAL, 32, PropModeReplace,
+ (unsigned char*) &value, 1);
+}
+
static void
apply_config_xrandr (MetaMonitorManager *manager,
MetaCRTCInfo **crtcs,
@@ -1236,6 +1280,10 @@ apply_config_xrandr (MetaMonitorManager *manager,
DefaultRootWindow (manager->xdisplay),
(XID)output_info->output->output_id);
}
+
+ output_set_presentation_xrandr (manager,
+ output_info->output,
+ output_info->is_presentation);
}
/* Disable CRTCs not mentioned in the list */
diff --git a/src/meta/atomnames.h b/src/meta/atomnames.h
index 0646799..8abcc60 100644
--- a/src/meta/atomnames.h
+++ b/src/meta/atomnames.h
@@ -72,6 +72,7 @@ item(_MUTTER_TIMESTAMP_PING)
item(_MUTTER_FOCUS_SET)
item(_MUTTER_SENTINEL)
item(_MUTTER_VERSION)
+item(_MUTTER_PRESENTATION_OUTPUT)
item(WM_CLIENT_MACHINE)
item(MANAGER)
item(TARGETS)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]