Commit 780ede1c authored by Ken Thomases's avatar Ken Thomases Committed by Alexandre Julliard

server: Make disconnecting a named pipe immediately close the client's…

server: Make disconnecting a named pipe immediately close the client's connection and allow the server to initiate a new connection. Signed-off-by: 's avatarKen Thomases <ken@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 88168d4b
...@@ -60,7 +60,6 @@ enum pipe_state ...@@ -60,7 +60,6 @@ enum pipe_state
ps_wait_open, ps_wait_open,
ps_connected_server, ps_connected_server,
ps_wait_disconnect, ps_wait_disconnect,
ps_disconnected_server,
ps_wait_connect ps_wait_connect
}; };
...@@ -344,7 +343,6 @@ static void set_server_state( struct pipe_server *server, enum pipe_state state ...@@ -344,7 +343,6 @@ static void set_server_state( struct pipe_server *server, enum pipe_state state
assert( !server->fd ); assert( !server->fd );
set_no_fd_status( server->ioctl_fd, STATUS_PIPE_LISTENING ); set_no_fd_status( server->ioctl_fd, STATUS_PIPE_LISTENING );
break; break;
case ps_disconnected_server:
case ps_wait_connect: case ps_wait_connect:
assert( !server->fd ); assert( !server->fd );
set_no_fd_status( server->ioctl_fd, STATUS_PIPE_DISCONNECTED ); set_no_fd_status( server->ioctl_fd, STATUS_PIPE_DISCONNECTED );
...@@ -430,9 +428,6 @@ static void pipe_client_destroy( struct object *obj) ...@@ -430,9 +428,6 @@ static void pipe_client_destroy( struct object *obj)
do a successful flush without it. */ do a successful flush without it. */
set_server_state( server, ps_wait_disconnect ); set_server_state( server, ps_wait_disconnect );
break; break;
case ps_disconnected_server:
set_server_state( server, ps_wait_connect );
break;
case ps_idle_server: case ps_idle_server:
case ps_wait_open: case ps_wait_open:
case ps_wait_disconnect: case ps_wait_disconnect:
...@@ -623,9 +618,6 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a ...@@ -623,9 +618,6 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a
case ps_connected_server: case ps_connected_server:
set_error( STATUS_PIPE_CONNECTED ); set_error( STATUS_PIPE_CONNECTED );
break; break;
case ps_disconnected_server:
set_error( STATUS_PIPE_BUSY );
break;
case ps_wait_disconnect: case ps_wait_disconnect:
set_error( STATUS_NO_DATA_DETECTED ); set_error( STATUS_NO_DATA_DETECTED );
break; break;
...@@ -644,10 +636,11 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a ...@@ -644,10 +636,11 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a
notify_empty( server ); notify_empty( server );
/* dump the client and server fds, but keep the pointers /* dump the client and server fds - client loses all waiting data */
around - client loses all waiting data */
do_disconnect( server ); do_disconnect( server );
set_server_state( server, ps_disconnected_server ); server->client->server = NULL;
server->client = NULL;
set_server_state( server, ps_wait_connect );
break; break;
case ps_wait_disconnect: case ps_wait_disconnect:
assert( !server->client ); assert( !server->client );
...@@ -658,7 +651,6 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a ...@@ -658,7 +651,6 @@ static obj_handle_t pipe_server_ioctl( struct fd *fd, ioctl_code_t code, const a
case ps_wait_open: case ps_wait_open:
set_error( STATUS_PIPE_LISTENING ); set_error( STATUS_PIPE_LISTENING );
break; break;
case ps_disconnected_server:
case ps_wait_connect: case ps_wait_connect:
set_error( STATUS_PIPE_DISCONNECTED ); set_error( STATUS_PIPE_DISCONNECTED );
break; break;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment