connect - Connect two sockets
#include <sys/socket.h>
int connect(
int socket,
const struct sockaddr *address,
socklen_t address_len );
[XNS4.0] The definition of the connect() function in
XNS4.0 uses a size_t data type instead of a socklen_t data
type as specified in XNS5.0 (the previous definition).
[Tru64 UNIX] The following definition of the connect()
function does not conform to current standards and is supported
only for backward compatibility (see standards(5)
). int connect(
int socket,
struct sockaddr *address,
int address_len );
Interfaces documented on this reference page conform to
industry standards as follows:
connect(): XNS4.0, XNS5.0
Refer to the standards(5) reference page for more information
about industry standards and associated tags.
Specifies a file descriptor for the socket. Points to a
sockaddr structure, the format of which is determined by
the domain and by the behavior requested for the socket.
The sockaddr structure is an overlay for a sockaddr_in,
sockaddr_un, sockaddr_in6, or sockaddr_storage structure,
depending on which of the supported address families is
active.
[Tru64 UNIX] If the compile-time option _SOCKADDR_LEN
is defined before the sys/socket.h header
file is included, the sockaddr structure takes
4.4BSD behavior, with a field for specifying the
length of the socket address. Otherwise, the
default 4.3BSD sockaddr structure is used, with the
length of the socket address assumed to be 14 bytes
or less.
If _SOCKADDR_LEN is defined, the 4.3BSD sockaddr
structure is defined with the name osockaddr.
Specifies the length of the sockaddr structure
pointed to by the address parameter.
The connect() function requests a connection between two
sockets. The kernel sets up the communications links
between the sockets; both sockets must use the same
address format and protocol.
The connect() function performs a different action for
each of the following types of initiating sockets: If the
initiating socket is SOCK_DGRAM, the connect() function
establishes the peer address. The peer address identifies
the socket where all datagrams are sent on subsequent
send() functions. It also identifies the socket from where
datagrams can be received; datagrams from other peer
addresses are not delivered. If address is a null address
for the protocol, the socket's peer address is reset.
No connections are made by this connect() function.
If the initiating socket is SOCK_STREAM, the connect()
function attempts to make a connection to
the socket specified by the address parameter. Each
communication space interprets the address parameter
differently.
If the function fails for a connection mode socket, applications
should use the close() function to deallocate the
socket and descriptor. If attempting to reinitiate the
connection, applications should create a new socket.
If the connection cannot be established immediately, one
of the following occurs: If the socket file descriptor is
marked non-blocking, the connect() function fails and sets
errno to [EINPROGRESS]. However, the connection request
is not aborted; the connection will be established asynchronously.
If you make a call to connect() for the same
socket before the connection is established, the function
fails and sets errno to [EALREADY]. If the socket file
descriptor is marked blocking, the connect() function
blocks for an unspecified amount of time until the connection
is established. If the timeout interval expires
before the connection is established, the function fails
and aborts the connection attempt. While blocked, if connect()
is interrupted by a signal, it fails and sets errno
to [EINTR]. However, the connection request is not
aborted; the connection is established asynchronously.
Upon successful completion, the connect() function returns
a value of 0 (zero). Otherwise, a value of -1 is returned
and errno is set to indicate the error.
If the connect() function fails, errno may be set to one
of the following values: Search permission is denied for a
component of the path prefix; or write access to the named
socket is denied.
[XNS4.0] This error applies to AF_UNIX sockets
only. The specified address is already in use.
The specified address is not available from the
local machine. The addresses in the specified
address family cannot be used with this socket. A
connection request is already in progress for the
specified socket. The socket parameter is not
valid. The attempt to connect was rejected. The
remote host reset the connection request. The
address parameter is not in a readable part of the
user address space. The specified host is not
reachable. O_NONBLOCK is set for the file descriptor
for the socket and the connection cannot be
immediately established; the connection will be
established asynchronously. The connect() function
was interrupted by a signal while waiting for the
connection to be established. The connection establishment
may continue asynchronously. The value of
the address_len parameter is invalid for the specified
address family; or the sa_family field in the
socket address structure is invalid for the protocol.
For an AF_UNIX socket, an I/O error occurred
while reading from or writing to the file system.
The socket is already connected. For an AF_UNIX
socket, too many symbolic links were encountered in
translating the pathname in address. A component
of the pathname exceeded NAME_MAX characters, or an
entire pathname exceeded PATH_MAX characters. The
local network connection is not operational. No
route to the network or host is present. Insufficient
resources are available in the system to complete
the call. For an AF_UNIX socket, a component
of the pathname does not name an existing file or
the pathname is an empty string. The available
STREAMS resources were insufficient for the operation
to complete. For an AF_UNIX socket, a component
of the path prefix of the pathname in address
is not a directory. The socket parameter refers to
a file, not a socket. The socket is listening and
cannot be connected. The specified address has a
different type than the socket bound to the specified
peer address. The establishment of a connection
timed out before a connection was made.
[Tru64 UNIX] The socket is marked nonblocking, so
the connection cannot be immediately completed.
The application program can select the socket for
writing during the connection process.
Functions: accept(2), bind(2), socket(2), getsockname(2),
select(2), send(2).
Standards: standards(5).
Network Programmer's Guide
connect(2)
[ Back ] |