NAME
shutdown —
disable sends or receives on a
socket
SYNOPSIS
#include
<sys/types.h>
#include <sys/socket.h>
int
shutdown(int
s, int how);
DESCRIPTION
The
shutdown()
system call disables sends or receives on a socket.
If the file descriptor s is associated with
a SOCK_STREAM socket, all or part of the full-duplex
connection will be shut down.
The how argument specifies the type of shutdown. Possible values are:
The following protocol specific actions apply to the use of
SHUT_WR based on the properties of the socket
associated with the file descriptor s:
| DOMAIN | TYPE | PROTOCOL | RETURN VALUE AND ACTION |
PF_INET |
SOCK_DGRAM |
IPPROTO_UDP |
Return 0. ICMP messages will not be generated. |
PF_INET |
SOCK_STREAM |
IPPROTO_TCP |
Return 0. Send queued data, wait for ACK, then send FIN. |
PF_INET6 |
SOCK_DGRAM |
IPPROTO_UDP |
Return 0. ICMP messages will not be generated. |
PF_INET6 |
SOCK_STREAM |
IPPROTO_TCP |
Return 0. Send queued data, wait for ACK, then send FIN. |
RETURN VALUES
The shutdown() function returns the
value 0 if successful; otherwise the value -1 is returned and
the global variable errno is set to indicate the
error.
ERRORS
The shutdown() system call fails if:
- [
EBADF] - The s argument is not a valid file descriptor.
- [
EINVAL] - The how argument is invalid.
- [
ENOTCONN] - The s argument specifies a
SOCK_STREAMsocket which is not connected. - [
ENOTSOCK] - The s argument does not refer to a socket.
- [
EOPNOTSUPP] - The socket associated with the file descriptor s does not support this operation.
SEE ALSO
HISTORY
The shutdown() function call appeared in
4.2BSD. The SHUT_RD,
SHUT_WR, and SHUT_RDWR
constants appeared in IEEE Std 1003.1g-2000
(“POSIX.1g”).
BUGS
The ICMP “port unreachable” message should be
generated in response to datagrams received on a local port to which
s is bound after shutdown() is
called.