mirror of https://github.com/xemu-project/xemu.git
vnc: fix two vnc update issues.
-----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQIcBAABAgAGBQJT0grXAAoJEEy22O7T6HE4KVEQANDpN0361blEAM4U1vdcJxeY ohQMDYrNOjMNVT8kVgWDTi0R9uaoMmbxt76wXsE7fpPtEX/dVnRUn5+f0yL3Bx2t nE2cAdBMrAGyHilUVcOWv9Ne8OMdNbT0V6tbLDKNaVtkR3o3omIEAJqeNWyb5cQW /BktWUwFhf+3r9LH3CCURfm4goH0uLr5jRLsAxkNnAZRwRGKAodaoAJMdVEA8r6R WX3JtKPtMJHnyZz55ccNGOIeigZ/LEAzkaXwJORnKYuYA8kXmje0xH8V4uE+/YSh CAADTsstIYXhaUEIDSKmCvIowmOGG5fX7wDTFN/cXU9dZXiR68Mm5snr9/ZhQXps rTPOBKDzBs1FoNrzrY95gqmKFfdZ/ptVMBOwShDyZvQV53w11ZGgd4IsN/gq28R3 Ax5oBmkgwiKpqzZbYNT7I6jDALS8/mk4mycVPcuBf8OKFtbkbZ3yHBlEPeOhOKCA SA9oYuKeUxPei3MInl4SzCBgfaL+oQ4uwAzgQJAcLQhWGSbxxm9vsKTbac6o4hww ZSIzQCHLV5z22iWQE+aI9gJNhmujw3kSusFs0rK/tZJMqHdSBAm50IWG5bvAWH1r vtonzQ9Nf09YwH4K7dM1i8/p+3OD4ECgCGQBpFpsozmJ9hQbfFI+NqxstgioTBvp 9EbC2CKBmf5bx8Ja9FLl =emO3 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/kraxel/tags/pull-vnc-20140725-1' into staging vnc: fix two vnc update issues. # gpg: Signature made Fri 25 Jul 2014 08:44:23 BST using RSA key ID D3E87138 # gpg: Good signature from "Gerd Hoffmann (work) <kraxel@redhat.com>" # gpg: aka "Gerd Hoffmann <gerd@kraxel.org>" # gpg: aka "Gerd Hoffmann (private) <kraxel@gmail.com>" * remotes/kraxel/tags/pull-vnc-20140725-1: vnc update fix fix full frame updates for VNC clients Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
7f0b2ff724
5
ui/vnc.c
5
ui/vnc.c
|
@ -887,6 +887,7 @@ static int find_and_clear_dirty_height(struct VncState *vs,
|
|||
|
||||
static int vnc_update_client(VncState *vs, int has_dirty, bool sync)
|
||||
{
|
||||
vs->has_dirty += has_dirty;
|
||||
if (vs->need_update && vs->csock != -1) {
|
||||
VncDisplay *vd = vs->vd;
|
||||
VncJob *job;
|
||||
|
@ -898,7 +899,7 @@ static int vnc_update_client(VncState *vs, int has_dirty, bool sync)
|
|||
/* kernel send buffers are full -> drop frames to throttle */
|
||||
return 0;
|
||||
|
||||
if (!has_dirty && !vs->audio_cap && !vs->force_update)
|
||||
if (!vs->has_dirty && !vs->audio_cap && !vs->force_update)
|
||||
return 0;
|
||||
|
||||
/*
|
||||
|
@ -941,6 +942,7 @@ static int vnc_update_client(VncState *vs, int has_dirty, bool sync)
|
|||
vnc_jobs_join(vs);
|
||||
}
|
||||
vs->force_update = 0;
|
||||
vs->has_dirty = 0;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
@ -1878,6 +1880,7 @@ static void framebuffer_update_request(VncState *vs, int incremental,
|
|||
return;
|
||||
}
|
||||
|
||||
vs->force_update = 1;
|
||||
vnc_set_area_dirty(vs->dirty, width, height, x, y, w, h);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue