79b272058d
Resolves: 1240721
67 lines
2.3 KiB
Diff
67 lines
2.3 KiB
Diff
From 93792a366e8c3020fe735d1080aa2ce58a2d03fa Mon Sep 17 00:00:00 2001
|
|
Message-Id: <93792a366e8c3020fe735d1080aa2ce58a2d03fa.1442072848.git.crobinso@redhat.com>
|
|
In-Reply-To: <e56c03deda6df3aaddcc778bd6cf1bd724e3172b.1442072848.git.crobinso@redhat.com>
|
|
References: <e56c03deda6df3aaddcc778bd6cf1bd724e3172b.1442072848.git.crobinso@redhat.com>
|
|
From: Pavel Grunt <pgrunt@redhat.com>
|
|
Date: Fri, 10 Jul 2015 10:37:27 +0200
|
|
Subject: [PATCH 2/2] Send monitor config if at least one monitor has
|
|
dimensions
|
|
|
|
If a client (virt-manager, spicy) is not setting display dimensions
|
|
and the "resize-guest" property is disabled, spice-gtk sends a wrong
|
|
monitor config message where all the monitors have width = heigh = 0
|
|
when the agent connects. This message can confuse the guest, in that
|
|
case the guest will change the resolution of its monitor.
|
|
|
|
Regression since 28312b8d1e287a320851e8828825f2ca138d8b0b
|
|
|
|
Resolves:
|
|
https://bugzilla.redhat.com/show_bug.cgi?id=1240721
|
|
(cherry picked from commit 4b5e6ec2114e1250c81027ebeac9cfe8d059153f)
|
|
---
|
|
src/channel-main.c | 21 +++++++++++++++++++++
|
|
1 file changed, 21 insertions(+)
|
|
|
|
diff --git a/src/channel-main.c b/src/channel-main.c
|
|
index fbf7677..8a61379 100644
|
|
--- a/src/channel-main.c
|
|
+++ b/src/channel-main.c
|
|
@@ -1411,6 +1411,22 @@ static void agent_clipboard_release(SpiceMainChannel *channel, guint selection)
|
|
agent_msg_queue(channel, VD_AGENT_CLIPBOARD_RELEASE, msgsize, msg);
|
|
}
|
|
|
|
+static gboolean any_display_has_dimensions(SpiceMainChannel *channel)
|
|
+{
|
|
+ SpiceMainChannelPrivate *c;
|
|
+ guint i;
|
|
+
|
|
+ g_return_if_fail(SPICE_IS_MAIN_CHANNEL(channel));
|
|
+ c = channel->priv;
|
|
+
|
|
+ for (i = 0; i < MAX_DISPLAY; i++) {
|
|
+ if (c->display[i].width > 0 && c->display[i].height > 0)
|
|
+ return TRUE;
|
|
+ }
|
|
+
|
|
+ return FALSE;
|
|
+}
|
|
+
|
|
/* main context*/
|
|
static gboolean timer_set_display(gpointer data)
|
|
{
|
|
@@ -1423,6 +1439,11 @@ static gboolean timer_set_display(gpointer data)
|
|
if (!c->agent_connected)
|
|
return FALSE;
|
|
|
|
+ if (!any_display_has_dimensions(channel)) {
|
|
+ SPICE_DEBUG("Not sending monitors config, at least one monitor must have dimensions");
|
|
+ return FALSE;
|
|
+ }
|
|
+
|
|
session = spice_channel_get_session(SPICE_CHANNEL(channel));
|
|
|
|
/* ensure we have an explicit monitor configuration at least for
|
|
--
|
|
2.5.0
|
|
|