| 
send(3N)							      send(3N)
      send, sendto, sendmsg - send a message from a socket
      #include <sys/types.h>
     int send(int s, char *msg,	int len, int flags);
     int sendto(int s, char *msg, int len, int flags, caddr_t to,
	 int tolen);
     int sendmsg(int s,	msghdr *msg, int flags);
     s is a socket created with	socket.	 send, sendto, and sendmsg are used to
     transmit a	message	to another socket.  send may be	used only when the
     socket is in a connected state, while sendto and sendmsg may be used at
     any time.
     The address of the	target is given	by to with tolen specifying its	size.
     The length	of the message is given	by len.	 If the	message	is too long to
     pass atomically through the underlying protocol, then the error EMSGSIZE
     is	returned, and the message is not transmitted.
     No	indication of failure to deliver is implicit in	a send.	 Return	values
     of	-1 indicate some locally detected errors.
     If	no buffer space	is available at	the socket to hold the message to be
     transmitted, then send normally blocks, unless the	socket has been	placed
     in	non-blocking I/O mode [see fcntl(2)].  The select call may be used to
     determine when it is possible to send more	data.
     The flags parameter is formed by ORing one	or more	of the following:
     MSG_OOB   Send out-of-band	data on	sockets	that support this notion. The
	       underlying protocol must	also support out-of-band data.
	       Currently, only SOCK_STREAM sockets created in the AF_INET
	       address family support out-of-band data.
     MSG_DONTROUTE
	       The SO_DONTROUTE	option is turned on for	the duration of	the
	       operation.  It is used only by diagnostic or routing programs.
     See recv(3N) for a	description of the msghdr structure.
     These calls return	the number of bytes sent, or -1	if an error occurred.
      The calls fail if:
									Page 1
send(3N)							      send(3N)
     EBADF		 s is an invalid descriptor.
     ENOTSOCK		 s is a	descriptor for a file, not a socket.
     EINVAL		 tolen is not the size of a valid address for the
			 specified address family.
     EINTR		 The operation was interrupted by delivery of a	signal
			 before	any data could be buffered to be sent.
     EMSGSIZE		 The socket requires that message be sent atomically,
			 and the message was too long.
     EWOULDBLOCK	 The socket is marked non-blocking and the requested
			 operation would block.
     ENOMEM		 There was insufficient	user memory available for the
			 operation to complete.
     ENOSR		 There were insufficient STREAMS resources available
			 for the operation to complete.
     fcntl(2), write(2), connect(3N), getsockopt(3N), recv(3N),	socket(3N)
     The type of address structure passed to accept depends on the address
     family.  UNIX domain sockets (address family AF_UNIX) require a
     socketaddr_un structure as	defined	in sys/un.h; Internet domain sockets
     (address family AF_INET) require a	sockaddr_in structure as defined in
     netinet/in.h.  Other address families may require other structures.  Use
     the structure appropriate to the address family; cast the structure
     address to	a generic caddr_t in the call to send and pass the size	of the
     structure in the tolen argument.
									PPPPaaaaggggeeee 2222[ Back ] |