The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/rpc/rpc.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*      $NetBSD: rpc.h,v 1.13 2000/06/02 22:57:56 fvdl Exp $    */
    2 
    3 /*
    4  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
    5  * unrestricted use provided that this legend is included on all tape
    6  * media and as a part of the software program in whole or part.  Users
    7  * may copy or modify Sun RPC without charge, but are not authorized
    8  * to license or distribute it to anyone else except as part of a product or
    9  * program developed by the user.
   10  *
   11  * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
   12  * WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
   13  * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
   14  *
   15  * Sun RPC is provided with no support and without any obligation on the
   16  * part of Sun Microsystems, Inc. to assist in its use, correction,
   17  * modification or enhancement.
   18  *
   19  * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
   20  * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
   21  * OR ANY PART THEREOF.
   22  *
   23  * In no event will Sun Microsystems, Inc. be liable for any lost revenue
   24  * or profits or other special, indirect and consequential damages, even if
   25  * Sun has been advised of the possibility of such damages.
   26  *
   27  * Sun Microsystems, Inc.
   28  * 2550 Garcia Avenue
   29  * Mountain View, California  94043
   30  *
   31  *      from: @(#)rpc.h 1.9 88/02/08 SMI
   32  *      from: @(#)rpc.h 2.4 89/07/11 4.0 RPCSRC
   33  * $FreeBSD: releng/8.0/sys/rpc/rpc.h 177633 2008-03-26 15:23:12Z dfr $
   34  */
   35 
   36 /*
   37  * rpc.h, Just includes the billions of rpc header files necessary to
   38  * do remote procedure calling.
   39  *
   40  * Copyright (C) 1984, Sun Microsystems, Inc.
   41  */
   42 #ifndef _RPC_RPC_H
   43 #define _RPC_RPC_H
   44 
   45 #include <rpc/types.h>          /* some typedefs */
   46 #include <sys/socket.h>
   47 #include <netinet/in.h>
   48 
   49 /* external data representation interfaces */
   50 #include <rpc/xdr.h>            /* generic (de)serializer */
   51 
   52 /* Client side only authentication */
   53 #include <rpc/auth.h>           /* generic authenticator (client side) */
   54 
   55 /* Client side (mostly) remote procedure call */
   56 #include <rpc/clnt.h>           /* generic rpc stuff */
   57 
   58 /* semi-private protocol headers */
   59 #include <rpc/rpc_msg.h>        /* protocol for rpc messages */
   60 
   61 #ifndef _KERNEL
   62 #include <rpc/auth_unix.h>      /* protocol for unix style cred */
   63 /*
   64  *  Uncomment-out the next line if you are building the rpc library with
   65  *  DES Authentication (see the README file in the secure_rpc/ directory).
   66  */
   67 #include <rpc/auth_des.h>       /* protocol for des style cred */
   68 #endif
   69 
   70 /* Server side only remote procedure callee */
   71 #include <rpc/svc.h>            /* service manager and multiplexer */
   72 #include <rpc/svc_auth.h>       /* service side authenticator */
   73 
   74 #ifndef _KERNEL
   75 /* Portmapper client, server, and protocol headers */
   76 #include <rpc/pmap_clnt.h>
   77 #endif
   78 #include <rpc/pmap_prot.h>
   79 
   80 #include <rpc/rpcb_clnt.h>      /* rpcbind interface functions */
   81 
   82 #ifndef _KERNEL
   83 #include <rpc/rpcent.h>
   84 #endif
   85 
   86 #ifndef UDPMSGSIZE
   87 #define UDPMSGSIZE 8800
   88 #endif
   89 
   90 __BEGIN_DECLS
   91 extern int get_myaddress(struct sockaddr_in *);
   92 #ifndef _KERNEL
   93 extern int bindresvport(int, struct sockaddr_in *);
   94 #endif
   95 extern int registerrpc(int, int, int, char *(*)(char [UDPMSGSIZE]),
   96     xdrproc_t, xdrproc_t);
   97 extern int callrpc(const char *, int, int, int, xdrproc_t, void *,
   98     xdrproc_t , void *);
   99 extern int getrpcport(char *, int, int, int);
  100 
  101 char *taddr2uaddr(const struct netconfig *, const struct netbuf *);
  102 struct netbuf *uaddr2taddr(const struct netconfig *, const char *);
  103 
  104 struct sockaddr;
  105 extern int bindresvport_sa(int, struct sockaddr *);
  106 __END_DECLS
  107 
  108 /*
  109  * The following are not exported interfaces, they are for internal library
  110  * and rpcbind use only. Do not use, they may change without notice.
  111  */
  112 __BEGIN_DECLS
  113 #ifndef _KERNEL
  114 int __rpc_nconf2fd(const struct netconfig *);
  115 int __rpc_nconf2sockinfo(const struct netconfig *, struct __rpc_sockinfo *);
  116 int __rpc_fd2sockinfo(int, struct __rpc_sockinfo *);
  117 #else
  118 struct socket *__rpc_nconf2socket(const struct netconfig *);
  119 int __rpc_nconf2sockinfo(const struct netconfig *, struct __rpc_sockinfo *);
  120 int __rpc_socket2sockinfo(struct socket *, struct __rpc_sockinfo *);
  121 #endif
  122 u_int __rpc_get_t_size(int, int, int);
  123 __END_DECLS
  124 
  125 #endif /* !_RPC_RPC_H */

Cache object: 097ca67d0f179655b47c8607deadca0e


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.