vnc: hextile: do not generate ForegroundSpecified and SubrectsColoured tiles
authorAnthony Liguori <aliguori@us.ibm.com>
Mon, 14 Dec 2009 20:11:56 +0000 (14:11 -0600)
committerAnthony Liguori <aliguori@us.ibm.com>
Fri, 18 Dec 2009 17:26:25 +0000 (11:26 -0600)
This violates the RFB specification (section 6.6.4).  It happens to work with
most clients but it's still wrong.

Reported-by: Yaniv Kaul <ykaul@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
vnchextile.h

index c96ede3..432ed89 100644 (file)
@@ -73,7 +73,7 @@ static void CONCAT(send_hextile_tile_, NAME)(VncState *vs,
        *last_bg = bg;
     }
 
-    if (!*has_fg || *last_fg != fg) {
+    if (n_colors < 3 && (!*has_fg || *last_fg != fg)) {
        flags |= 0x04;
        *has_fg = 1;
        *last_fg = fg;
@@ -165,8 +165,6 @@ static void CONCAT(send_hextile_tile_, NAME)(VncState *vs,
            irow += ds_get_linesize(vs->ds) / sizeof(pixel_t);
        }
 
-       /* A SubrectsColoured subtile invalidates the foreground color */
-       *has_fg = 0;
        if (n_data > (w * h * sizeof(pixel_t))) {
            n_colors = 4;
            flags = 0x01;