GETSOCKNAME(3XNET) X/Open Networking Services Library Functions
getsockname - get the socket name
cc [ flag ... ] file ... -lxnet [ library ... ]
#include <sys/socket.h>
int getsockname(int socket, struct sockaddr *restrict address,
socklen_t *restrict address_len);
The getsockname() function retrieves the locally-bound name of the
specified socket, stores this address in the sockaddr structure
pointed to by the address argument, and stores the length of this
address in the object pointed to by the address_len argument.
If the actual length of the address is greater than the length of the
supplied sockaddr structure, the stored address will be truncated.
If the socket has not been bound to a local name, the value stored in
the object pointed to by address is unspecified.
Upon successful completion, 0 is returned, the address argument
points to the address of the socket, and the address_len argument
points to the length of the address. Otherwise, -1 is returned and
errno is set to indicate the error.
The getsockname() function will fail:
EBADF
The socket argument is not a valid file descriptor.
EFAULT
The address or address_len parameter can not be
accessed or written.
ENOTSOCK
The socket argument does not refer to a socket.
EOPNOTSUPP
The operation is not supported for this socket's
protocol.
The getsockname() function may fail if:
EINVAL
The socket has been shut down.
ENOBUFS
Insufficient resources were available in the system to
complete the call.
ENOSR
There were insufficient STREAMS resources available for
the operation to complete.
See attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Standard |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+
sockaddr(3SOCKET), accept(3XNET), bind(3XNET), getpeername(3XNET),
socket(3XNET) attributes(7), standards(7)
June 10, 2002 GETSOCKNAME(3XNET)
NAME
getsockname - get the socket name
SYNOPSIS
cc [ flag ... ] file ... -lxnet [ library ... ]
#include <sys/socket.h>
int getsockname(int socket, struct sockaddr *restrict address,
socklen_t *restrict address_len);
DESCRIPTION
The getsockname() function retrieves the locally-bound name of the
specified socket, stores this address in the sockaddr structure
pointed to by the address argument, and stores the length of this
address in the object pointed to by the address_len argument.
If the actual length of the address is greater than the length of the
supplied sockaddr structure, the stored address will be truncated.
If the socket has not been bound to a local name, the value stored in
the object pointed to by address is unspecified.
RETURN VALUES
Upon successful completion, 0 is returned, the address argument
points to the address of the socket, and the address_len argument
points to the length of the address. Otherwise, -1 is returned and
errno is set to indicate the error.
ERRORS
The getsockname() function will fail:
EBADF
The socket argument is not a valid file descriptor.
EFAULT
The address or address_len parameter can not be
accessed or written.
ENOTSOCK
The socket argument does not refer to a socket.
EOPNOTSUPP
The operation is not supported for this socket's
protocol.
The getsockname() function may fail if:
EINVAL
The socket has been shut down.
ENOBUFS
Insufficient resources were available in the system to
complete the call.
ENOSR
There were insufficient STREAMS resources available for
the operation to complete.
ATTRIBUTES
See attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Standard |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+
SEE ALSO
sockaddr(3SOCKET), accept(3XNET), bind(3XNET), getpeername(3XNET),
socket(3XNET) attributes(7), standards(7)
June 10, 2002 GETSOCKNAME(3XNET)