GETPEERNAME(2) System Calls Manual GETPEERNAME(2)

getpeernameget address of connected peer

#include <sys/socket.h>

int
getpeername(int socket, struct sockaddr *restrict address, socklen_t *restrict address_len);

The () function returns the address of the peer connected to the specified socket.

The address_len parameter should be initialized to indicate the amount of space pointed to by address. On return it contains the actual size of the address returned (in bytes).

The address is truncated if the buffer provided is too small.

The getpeername() function returns the value 0 if successful; otherwise the value -1 is returned and the global variable errno is set to indicate the error.

The call succeeds unless:

[]
The argument socket is not a valid descriptor.
[]
The address parameter points to memory not in a valid part of the process address space.
[]
socket has been shut down.
[]
Insufficient resources were available in the system to perform the operation.
[]
Either the socket is not connected or it has not had the peer pre-specified.
[]
The argument socket refers to something other than a socket (e.g., a file).
[]
getpeername() is not supported for the protocol in use by socket.

accept(2), bind(2), getsockname(2), socket(2)

The getpeername() function call appeared in 4.2BSD.

June 4, 1993 BSD 4.2