Museum

Home

Lab Overview

Retrotechnology Articles

⇒ Online Manual

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

getnetpath(3N)



netdir(3N)                     DG/UX R4.11MU05                    netdir(3N)


NAME
       netdir: netdir_getbyname, netdir_getbyaddr, netdir_free,
       netdir_mergeaddr, taddr2uaddr, uaddr2taddr, netdir_perror,
       netdir_sperror - generic transport name-to-address translation

SYNOPSIS
       #include <netdir.h>
       int
       netdir_getbyname(config, service, addrs)
            struct netconfig  *config;
            struct nd_hostserv  *service;
            struct nd_addrlist  **addrs;
       int
       netdir_getbyaddr(config, service, netaddr)
            struct netconfig  *config;
            struct nd_hostservlist  **service;
            struct netbuf  *netaddr;
       void
       netdir_free(ptr, ident)
            void *ptr;
            int ident;
       int
       netdir_mergeaddr(config, mrg_uaddr, s_uaddr, c_uaddr)
            struct netconfig  *config;
            char  **mrg_uaddr, *s_uaddr, *c_uaddr;
       char *
       taddr2uaddr(config, addr)
            struct netconfig  *config;
            struct netbuf  *addr;
       struct netbuf *
       uaddr2taddr(config, uaddr)
            struct netconfig  *config;
            char  *uaddr;
       int
       netdir_options(netconfig, option, fd, pointer_to_args)
            struct netconfig  *netconfig;
            int  option;
            int fd;
            char  *point_to_args;
       void
       netdir_perror(s)
       char  *s;
       char *
       netdir_sperror()


DESCRIPTION
       These routines provide a generic interface for name-to-address
       mapping that will work with a all transport protocols.  This
       interface provides a generic way for programs to convert transport
       specific addresses into common structures and back again.

       The netdir_getbyname() routine maps the machine name and service name
       in the nd_hostserv structure to a collection of addresses of the type
       understood by the transport identified in the netconfig structure.
       This routine returns all addresses that are valid for that transport
       in the nd_addrlist structure.  The nd_hostserv and nd_addrlist
       structures have the following elements.  The netconfig structure is
       described on the netconfig(4) manual page.
              struct nd_addrlist
                   int n_cnt
                   struct netbuf  *n_addrs;
              struct nd_hostserv
                   char  *h_host;
                   char  *h_serv;

       netdir_getbyname() accepts some special-case host names.  These host
       names are hints to the underlying mapping routines that define the
       intent of the request.  This information is required for some
       transport provider developers to provide the correct information back
       to the caller.  The host names are defined in /usr/include/netdir.h.
       The currently defined host names are:

       HOST_SELF   Represents the address to which local programs will bind
                   their endpoints.  HOST_SELF differs from the host name
                   provided by gethostname(3), which represents the address
                   to which remote programs will bind their endpoints.

       HOST_ANY    Represents any host accessible by this transport
                   provider.  HOST_ANY allows applications to specify a
                   required service without specifying a particular host
                   name.

       HOST_BROADCAST
                   Represents the address for all hosts accessible by this
                   transport provider.  Network requests to this address
                   will be received by all machines.

       All fields of the nd_hostserv structure must be initialized.

       To find all available transports, call the netdir_getbyname() routine
       with each struct netconfig structure returned by the getnetpath(3N)
       call.

       The netdir_getbyaddr() routine maps addresses to service names.  This
       routine returns a list of host and service pairs that would yield
       this address.  If more than one tuple of host and service name is
       returned then the first tuple contains the preferred host and service
       names.
              struct nd_hostservlist
                   int  *h_cnt;
                   struct hostserv  *h_hostservs;

       The netdir_free() structure is used to free the structures allocated
       by the name to address translation routines.

       The netdir_mergeaddr() routine is used by a network service to return
       an optimized network addresses to a client.  This routine takes the
       universal address of the endpoint that the service has bound to,
       which is pointed to by the s_uaddr parameter, and the address of the
       endpoint that a request came in on, which is pointed to by the
       c_uaddr parameter, to create an optimized address for communication
       with the service.  The service address should be an address returned
       by the netdir_getbyname() call, specified with the special host name
       HOST_SELF.

       The taddr2uaddr() and uaddr2taddr() routines support translation
       between universal addresses and TLI type netbufs.  They take and
       return character string pointers.  The taddr2uaddr() routine returns
       a pointer to a string that contains the universal address and returns
       NULL if the conversion is not possible.  This is not a fatal
       condition as some transports may not support a universal address
       form.

       option, fd, and pointer_to_args are passed to the netdir_options
       routine for the transport specified in netconfigp.  There are four
       values for option:
            ND_SET_BROADCAST
            ND_SET_RESERVEDPORT
            ND_CHECK_RESERVEDPORT
            ND_MERGEADDR
       If a transport provider does not support an option, netdir_options
       returns -1 and sets _nderror to ND_NOCTRL.

       The specific actions of each option follow.

       ND_SET_BROADCAST    Sets the transport provider up to allow
                           broadcast, if the transport supports broadcast.
                           fd is a file descriptor into the transport (i.e.,
                           the result of a t_open of /dev/udp).
                           pointer_to_args is not used.  If this completes,
                           broadcast operations may be performed on file
                           descriptor fd.

       ND_SET_RESERVEDPORT Allows the application to bind to a reserved
                           port, if that concept exists for the transport
                           provider.  fd is a file descriptor into the
                           transport (it must not be bound to an address).
                           If pointer_to_args is NULL, fd will be bound to a
                           reserved port.  If pointer_to_args is a pointer
                           to a netbuf structure, an attempt will be made to
                           bind to a reserved port on the specified address.

       ND_CHECK_RESERVEDPORT
                           Used to verify that an address corresponds to a
                           reserved port, if that concept exists for the
                           transport provider.  fd is not used.
                           pointer_to_args is a pointer to a netbuf
                           structure that contains an address.  This option
                           returns 0 only if the address specified in
                           pointer_to_args is reserved.

       ND_MERGEADDR        Used to take a ``local address'' (like the
                           0.0.0.0 address that TCP uses) and return a
                           ``real address'' that client machines can connect
                           to.  fd is not used.  pointer_to_args is a
                           pointer to a struct nd_mergearg, which has the
                           following form:
                           struct nd_mergearg {
                                char *s_uaddr;  /* server's universal address */
                                char *c_uaddr;  /* client's universal address */
                                char *m_uaddr;  /* the result */
                           }
                           s_uaddr is something like 0.0.0.0.1.12, and, if
                           the call is successful, m_uaddr will be set to
                           something like 192.11.109.89.1.12.  For most
                           transports, m_uaddr is exactly what s_uaddr is.

       The netdir_perror() routine prints an error message on the standard
       output stating why one of the name-to-address mapping routines
       failed.  The error message is preceded by the string given as an
       argument.

       The netdir_sperror() routine returns a string containing an error
       message stating why one of the name-to-address mapping routines
       failed.

SEE ALSO
       getnetpath(3N).


Licensed material--property of copyright holder(s)

Typewritten Software • bear@typewritten.org • Edmonds, WA 98026