Commit ea01e5fd490be41f7876372e5acafb1f1d580478
1 parent
171cd1cd
Fix spurious VNC disconnects on Win32 (Hervé Poussineau).
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4251 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
13 additions
and
3 deletions
vnc.c
| ... | ... | @@ -633,8 +633,18 @@ static void buffer_append(Buffer *buffer, const void *data, size_t len) |
| 633 | 633 | static int vnc_client_io_error(VncState *vs, int ret, int last_errno) |
| 634 | 634 | { |
| 635 | 635 | if (ret == 0 || ret == -1) { |
| 636 | - if (ret == -1 && (last_errno == EINTR || last_errno == EAGAIN)) | |
| 637 | - return 0; | |
| 636 | + if (ret == -1) { | |
| 637 | + switch (last_errno) { | |
| 638 | + case EINTR: | |
| 639 | + case EAGAIN: | |
| 640 | +#ifdef _WIN32 | |
| 641 | + case WSAEWOULDBLOCK: | |
| 642 | +#endif | |
| 643 | + return 0; | |
| 644 | + default: | |
| 645 | + break; | |
| 646 | + } | |
| 647 | + } | |
| 638 | 648 | |
| 639 | 649 | VNC_DEBUG("Closing down client sock %d %d\n", ret, ret < 0 ? last_errno : 0); |
| 640 | 650 | qemu_set_fd_handler2(vs->csock, NULL, NULL, NULL, NULL); |
| ... | ... | @@ -2086,10 +2096,10 @@ int vnc_display_open(DisplayState *ds, const char *display) |
| 2086 | 2096 | struct sockaddr_in iaddr; |
| 2087 | 2097 | #ifndef _WIN32 |
| 2088 | 2098 | struct sockaddr_un uaddr; |
| 2099 | + const char *p; | |
| 2089 | 2100 | #endif |
| 2090 | 2101 | int reuse_addr, ret; |
| 2091 | 2102 | socklen_t addrlen; |
| 2092 | - const char *p; | |
| 2093 | 2103 | VncState *vs = ds ? (VncState *)ds->opaque : vnc_state; |
| 2094 | 2104 | const char *options; |
| 2095 | 2105 | int password = 0; | ... | ... |