[mutter/wip/wayland-display: 49/62] MonitorManager: further extend the dummy backend
- From: Giovanni Campagna <gcampagna src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/wayland-display: 49/62] MonitorManager: further extend the dummy backend
- Date: Thu, 8 Aug 2013 08:32:13 +0000 (UTC)
commit 9cd307cbbe5259d4ae41fe92bd7c4927abcff47f
Author: Giovanni Campagna <gcampagn redhat com>
Date: Thu Jul 25 11:54:22 2013 +0200
MonitorManager: further extend the dummy backend
The default configuration is extended, which is only possible
if there are as many CRTCs as outputs, so make sure that's true.
Also, add more and bigger modes, so that different sizes will
be chosen for the three outputs.
A nice side effect of this is that with a real 1920x1080 + 1600x900
layout, if you disable the VGA you get a stage that matches the
screen size, which triggers the legacy fullscreen path in the
outside mutter.
src/core/monitor.c | 66 ++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 49 insertions(+), 17 deletions(-)
---
diff --git a/src/core/monitor.c b/src/core/monitor.c
index 9552e98..ab2dfd3 100644
--- a/src/core/monitor.c
+++ b/src/core/monitor.c
@@ -165,8 +165,8 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->screen_width = 1024;
manager->screen_height = 768;
- manager->modes = g_new0 (MetaMonitorMode, 3);
- manager->n_modes = 3;
+ manager->modes = g_new0 (MetaMonitorMode, 6);
+ manager->n_modes = 6;
manager->modes[0].mode_id = 1;
manager->modes[0].width = 1024;
@@ -183,8 +183,23 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->modes[2].height = 480;
manager->modes[2].refresh_rate = 60.0;
- manager->crtcs = g_new0 (MetaCRTC, 2);
- manager->n_crtcs = 2;
+ manager->modes[3].mode_id = 4;
+ manager->modes[3].width = 1920;
+ manager->modes[3].height = 1080;
+ manager->modes[3].refresh_rate = 60.0;
+
+ manager->modes[4].mode_id = 5;
+ manager->modes[4].width = 1920;
+ manager->modes[4].height = 1080;
+ manager->modes[4].refresh_rate = 55.0;
+
+ manager->modes[5].mode_id = 6;
+ manager->modes[5].width = 1600;
+ manager->modes[5].height = 900;
+ manager->modes[5].refresh_rate = 60.0;
+
+ manager->crtcs = g_new0 (MetaCRTC, 3);
+ manager->n_crtcs = 3;
manager->crtcs[0].crtc_id = 4;
manager->crtcs[0].rect.x = 0;
@@ -208,10 +223,21 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->crtcs[1].dirty = FALSE;
manager->crtcs[1].logical_monitor = NULL;
+ manager->crtcs[2].crtc_id = 5;
+ manager->crtcs[2].rect.x = 0;
+ manager->crtcs[2].rect.y = 0;
+ manager->crtcs[2].rect.width = 0;
+ manager->crtcs[2].rect.height = 0;
+ manager->crtcs[2].current_mode = NULL;
+ manager->crtcs[2].transform = WL_OUTPUT_TRANSFORM_NORMAL;
+ manager->crtcs[2].all_transforms = ALL_WL_TRANSFORMS;
+ manager->crtcs[2].dirty = FALSE;
+ manager->crtcs[2].logical_monitor = NULL;
+
manager->outputs = g_new0 (MetaOutput, 3);
manager->n_outputs = 3;
- manager->outputs[0].crtc = 0;
+ manager->outputs[0].crtc = NULL;
manager->outputs[0].output_id = 6;
manager->outputs[0].name = g_strdup ("HDMI");
manager->outputs[0].vendor = g_strdup ("MetaProducts Inc.");
@@ -220,16 +246,19 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->outputs[0].width_mm = 510;
manager->outputs[0].height_mm = 287;
manager->outputs[0].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
- manager->outputs[0].preferred_mode = &manager->modes[0];
- manager->outputs[0].n_modes = 3;
- manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 3);
+ manager->outputs[0].preferred_mode = &manager->modes[3];
+ manager->outputs[0].n_modes = 5;
+ manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 5);
manager->outputs[0].modes[0] = &manager->modes[0];
manager->outputs[0].modes[1] = &manager->modes[1];
manager->outputs[0].modes[2] = &manager->modes[2];
- manager->outputs[0].n_possible_crtcs = 2;
- manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 2);
+ manager->outputs[0].modes[3] = &manager->modes[3];
+ manager->outputs[0].modes[4] = &manager->modes[4];
+ manager->outputs[0].n_possible_crtcs = 3;
+ manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 3);
manager->outputs[0].possible_crtcs[0] = &manager->crtcs[0];
manager->outputs[0].possible_crtcs[1] = &manager->crtcs[1];
+ manager->outputs[0].possible_crtcs[2] = &manager->crtcs[2];
manager->outputs[0].n_possible_clones = 0;
manager->outputs[0].possible_clones = g_new0 (MetaOutput *, 0);
@@ -242,16 +271,18 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->outputs[1].width_mm = 222;
manager->outputs[1].height_mm = 125;
manager->outputs[1].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
- manager->outputs[1].preferred_mode = &manager->modes[0];
- manager->outputs[1].n_modes = 3;
- manager->outputs[1].modes = g_new0 (MetaMonitorMode *, 3);
+ manager->outputs[1].preferred_mode = &manager->modes[5];
+ manager->outputs[1].n_modes = 4;
+ manager->outputs[1].modes = g_new0 (MetaMonitorMode *, 4);
manager->outputs[1].modes[0] = &manager->modes[0];
manager->outputs[1].modes[1] = &manager->modes[1];
manager->outputs[1].modes[2] = &manager->modes[2];
- manager->outputs[1].n_possible_crtcs = 2;
- manager->outputs[1].possible_crtcs = g_new0 (MetaCRTC *, 2);
+ manager->outputs[1].modes[3] = &manager->modes[5];
+ manager->outputs[1].n_possible_crtcs = 3;
+ manager->outputs[1].possible_crtcs = g_new0 (MetaCRTC *, 3);
manager->outputs[1].possible_crtcs[0] = &manager->crtcs[0];
manager->outputs[1].possible_crtcs[1] = &manager->crtcs[1];
+ manager->outputs[1].possible_crtcs[2] = &manager->crtcs[2];
manager->outputs[1].n_possible_clones = 0;
manager->outputs[1].possible_clones = g_new0 (MetaOutput *, 0);
@@ -270,10 +301,11 @@ make_dummy_monitor_config (MetaMonitorManager *manager)
manager->outputs[2].modes[0] = &manager->modes[0];
manager->outputs[2].modes[1] = &manager->modes[1];
manager->outputs[2].modes[2] = &manager->modes[2];
- manager->outputs[2].n_possible_crtcs = 2;
- manager->outputs[2].possible_crtcs = g_new0 (MetaCRTC *, 2);
+ manager->outputs[2].n_possible_crtcs = 3;
+ manager->outputs[2].possible_crtcs = g_new0 (MetaCRTC *, 3);
manager->outputs[2].possible_crtcs[0] = &manager->crtcs[0];
manager->outputs[2].possible_crtcs[1] = &manager->crtcs[1];
+ manager->outputs[2].possible_crtcs[2] = &manager->crtcs[2];
manager->outputs[2].n_possible_clones = 0;
manager->outputs[2].possible_clones = g_new0 (MetaOutput *, 0);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]