aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2018-09-11 14:22:04 +0200
committerPierre Ossman <ossman@cendio.se>2018-09-11 14:22:04 +0200
commit44a1d71f33ad312991a201fc2c9ca4949edd7d54 (patch)
tree6a29529623d2c3f930973c566e72ccc9fbfc3204
parentc86ce3eeef5521134e8d30e6009dafc6b7c1759f (diff)
downloadtigervnc-44a1d71f33ad312991a201fc2c9ca4949edd7d54.tar.gz
tigervnc-44a1d71f33ad312991a201fc2c9ca4949edd7d54.zip
Explicitly check screen layout after change
There are some cases where the server state will not automatically be updated on a change. A prominent one is when only RFB attributes were changes (e.g. the screen ID) but nothing else. In that case there is no actual change in the X server, so it never sends any notification about change back to us.
-rw-r--r--unix/x0vncserver/XDesktop.cxx11
-rw-r--r--unix/xserver/hw/vnc/XserverDesktop.cc10
2 files changed, 16 insertions, 5 deletions
diff --git a/unix/x0vncserver/XDesktop.cxx b/unix/x0vncserver/XDesktop.cxx
index d8360abd..c7961f2a 100644
--- a/unix/x0vncserver/XDesktop.cxx
+++ b/unix/x0vncserver/XDesktop.cxx
@@ -567,11 +567,14 @@ unsigned int XDesktop::setScreenLayout(int fb_width, int fb_height,
VNCSConnectionST::setDesktopSize. Another ExtendedDesktopSize
with reason=0 will be sent in response to the changes seen by the
event handler. */
- if (adjustedLayout != layout) {
+ if (adjustedLayout != layout)
return rfb::resultInvalid;
- } else {
- return ret;
- }
+
+ // Explicitly update the server state with the result as there
+ // can be corner cases where we don't get feedback from the X server
+ server->setScreenLayout(computeScreenLayout());
+
+ return ret;
#else
return rfb::resultProhibited;
diff --git a/unix/xserver/hw/vnc/XserverDesktop.cc b/unix/xserver/hw/vnc/XserverDesktop.cc
index 4aac7655..7eaf3f91 100644
--- a/unix/xserver/hw/vnc/XserverDesktop.cc
+++ b/unix/xserver/hw/vnc/XserverDesktop.cc
@@ -557,6 +557,8 @@ void XserverDesktop::clientCutText(const char* str, int len)
unsigned int XserverDesktop::setScreenLayout(int fb_width, int fb_height,
const rfb::ScreenSet& layout)
{
+ unsigned int result;
+
char buffer[2048];
vlog.debug("Got request for framebuffer resize to %dx%d",
fb_width, fb_height);
@@ -564,7 +566,13 @@ unsigned int XserverDesktop::setScreenLayout(int fb_width, int fb_height,
vlog.debug("%s", buffer);
vncSetGlueContext(screenIndex);
- return ::setScreenLayout(fb_width, fb_height, layout, &outputIdMap);
+ result = ::setScreenLayout(fb_width, fb_height, layout, &outputIdMap);
+
+ // Explicitly update the server state with the result as there
+ // can be corner cases where we don't get feedback from the X core
+ refreshScreenLayout();
+
+ return result;
}
void XserverDesktop::grabRegion(const rfb::Region& region)