Skip to content

socket_release

NAME

socket_release() - release ownership of a socket to another object

SYNOPSIS

#include <socket_err.h>

int socket_release( int socket, object ob,
                    string release_callback );

DESCRIPTION

socket_release()  is used to change ownership (and control) of a socket
to another object.  It is useful in daemon objects (like  inetd)  which
handle  connection  set-up  and  then  transfer  a  connected socket to
another object for further processing.

Socket ownership transfer involves  a  handshake  between  the  current
owner object and the socket to which the current owner wishes to trans‐
fer the socket.  The handshake is initiated  when  socket_release()  is
called.   socket_release() does appropriate security/integrity checking
and then calls the release_callback function in object ob.  This  func‐
tion is used to notify ob that socket ownership is being transferred to
it.  It is then ob's responsibility to call socket_acquire() within the
release  callback  function.   If  socket_acquire()  is called then the
handshake is complete and socket ownership has been successfully trans‐
ferred  to  ob.  ob may decline to accept responsibility for the socket
by not calling socket_acquire(),  in  which  case  ownership  does  not
change and the current socket owner must decide how to respond to this.

If  the  socket  owner is successfully transfered then socket_release()
returns EESUCCESS.  If ob does not accept ownership for the socket then
EESOCKNOTRLSD is returned.  Other errors can be returned based on secu‐
rity violation, bad socket descriptor vbalues, etc.

SEE ALSO

socket_acquire(3)