vnc: prioritize ZRLE compression over ZLIB

In my investigation, ZRLE always compresses better than ZLIB so
prioritize ZRLE over ZLIB, even if the client hints that ZLIB is
preferred.

zlib buffer is always reset in zrle_compress_data(), so using offset to
calculate next_out and avail_out is useless.

Signed-off-by: Cameron Esfahani <dirty@apple.com>
Message-Id: <b5d129895d08a90d0a2a6183b95875bacfa998b8.1579582674.git.dirty@apple.com>
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
Cameron Esfahani 2020-01-20 21:00:52 -08:00 committed by Gerd Hoffmann
parent 0780ec7be8
commit 557ba0e572
2 changed files with 11 additions and 4 deletions

View File

@ -98,8 +98,8 @@ static int zrle_compress_data(VncState *vs, int level)
/* set pointers */ /* set pointers */
zstream->next_in = vs->zrle->zrle.buffer; zstream->next_in = vs->zrle->zrle.buffer;
zstream->avail_in = vs->zrle->zrle.offset; zstream->avail_in = vs->zrle->zrle.offset;
zstream->next_out = vs->zrle->zlib.buffer + vs->zrle->zlib.offset; zstream->next_out = vs->zrle->zlib.buffer;
zstream->avail_out = vs->zrle->zlib.capacity - vs->zrle->zlib.offset; zstream->avail_out = vs->zrle->zlib.capacity;
zstream->data_type = Z_BINARY; zstream->data_type = Z_BINARY;
/* start encoding */ /* start encoding */

View File

@ -2071,8 +2071,15 @@ static void set_encodings(VncState *vs, int32_t *encodings, size_t n_encodings)
break; break;
#endif #endif
case VNC_ENCODING_ZLIB: case VNC_ENCODING_ZLIB:
/*
* VNC_ENCODING_ZRLE compresses better than VNC_ENCODING_ZLIB.
* So prioritize ZRLE, even if the client hints that it prefers
* ZLIB.
*/
if ((vs->features & VNC_FEATURE_ZRLE_MASK) == 0) {
vs->features |= VNC_FEATURE_ZLIB_MASK; vs->features |= VNC_FEATURE_ZLIB_MASK;
vs->vnc_encoding = enc; vs->vnc_encoding = enc;
}
break; break;
case VNC_ENCODING_ZRLE: case VNC_ENCODING_ZRLE:
vs->features |= VNC_FEATURE_ZRLE_MASK; vs->features |= VNC_FEATURE_ZRLE_MASK;