mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
shm: use shutdown() instead of close()
we make sure both ends get notified when the socket is closed by using shutdown() instead of close(). https://bugzilla.gnome.org/show_bug.cgi?id=724077
This commit is contained in:
parent
73d9a8b0c9
commit
f5a1ccd0de
1 changed files with 3 additions and 3 deletions
|
@ -429,7 +429,7 @@ sp_writer_close (ShmPipe * self, sp_buffer_free_callback callback,
|
|||
void *user_data)
|
||||
{
|
||||
if (self->main_socket >= 0)
|
||||
close (self->main_socket);
|
||||
shutdown (self->main_socket, SHUT_RDWR);
|
||||
|
||||
if (self->socket_path) {
|
||||
unlink (self->socket_path);
|
||||
|
@ -840,7 +840,7 @@ sp_writer_accept_client (ShmPipe * self)
|
|||
return client;
|
||||
|
||||
error:
|
||||
close (fd);
|
||||
shutdown (fd, SHUT_RDWR);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
@ -892,7 +892,7 @@ sp_writer_close_client (ShmPipe * self, ShmClient * client,
|
|||
ShmBuffer *buffer = NULL, *prev_buf = NULL;
|
||||
ShmClient *item = NULL, *prev_item = NULL;
|
||||
|
||||
close (client->fd);
|
||||
shutdown (client->fd, SHUT_RDWR);
|
||||
|
||||
again:
|
||||
for (buffer = self->buffers; buffer; buffer = buffer->next) {
|
||||
|
|
Loading…
Reference in a new issue