1dfdcada3SDoug Rabson /* 2dfdcada3SDoug Rabson * Please do not edit this file. 3dfdcada3SDoug Rabson * It was generated using rpcgen. 4dfdcada3SDoug Rabson */ 5dfdcada3SDoug Rabson 6dfdcada3SDoug Rabson #ifndef _RPCB_PROT_H_RPCGEN 7dfdcada3SDoug Rabson #define _RPCB_PROT_H_RPCGEN 8dfdcada3SDoug Rabson 9dfdcada3SDoug Rabson #include <rpc/rpc.h> 10dfdcada3SDoug Rabson 11dfdcada3SDoug Rabson #ifdef __cplusplus 12dfdcada3SDoug Rabson extern "C" { 13dfdcada3SDoug Rabson #endif 14dfdcada3SDoug Rabson 15dfdcada3SDoug Rabson /* 16dfdcada3SDoug Rabson * $FreeBSD$ 17dfdcada3SDoug Rabson * 18dfdcada3SDoug Rabson * Sun RPC is a product of Sun Microsystems, Inc. and is provided for 19dfdcada3SDoug Rabson * unrestricted use provided that this legend is included on all tape 20dfdcada3SDoug Rabson * media and as a part of the software program in whole or part. Users 21dfdcada3SDoug Rabson * may copy or modify Sun RPC without charge, but are not authorized 22dfdcada3SDoug Rabson * to license or distribute it to anyone else except as part of a product or 23dfdcada3SDoug Rabson * program developed by the user. 24dfdcada3SDoug Rabson * 25dfdcada3SDoug Rabson * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE 26dfdcada3SDoug Rabson * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR 27dfdcada3SDoug Rabson * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. 28dfdcada3SDoug Rabson * 29dfdcada3SDoug Rabson * Sun RPC is provided with no support and without any obligation on the 30dfdcada3SDoug Rabson * part of Sun Microsystems, Inc. to assist in its use, correction, 31dfdcada3SDoug Rabson * modification or enhancement. 32dfdcada3SDoug Rabson * 33dfdcada3SDoug Rabson * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE 34dfdcada3SDoug Rabson * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC 35dfdcada3SDoug Rabson * OR ANY PART THEREOF. 36dfdcada3SDoug Rabson * 37dfdcada3SDoug Rabson * In no event will Sun Microsystems, Inc. be liable for any lost revenue 38dfdcada3SDoug Rabson * or profits or other special, indirect and consequential damages, even if 39dfdcada3SDoug Rabson * Sun has been advised of the possibility of such damages. 40dfdcada3SDoug Rabson * 41dfdcada3SDoug Rabson * Sun Microsystems, Inc. 42dfdcada3SDoug Rabson * 2550 Garcia Avenue 43dfdcada3SDoug Rabson * Mountain View, California 94043 44dfdcada3SDoug Rabson */ 45dfdcada3SDoug Rabson /* 46dfdcada3SDoug Rabson * Copyright (c) 1988 by Sun Microsystems, Inc. 47dfdcada3SDoug Rabson */ 48dfdcada3SDoug Rabson /* from rpcb_prot.x */ 49dfdcada3SDoug Rabson 50dfdcada3SDoug Rabson /* #pragma ident "@(#)rpcb_prot.x 1.5 94/04/29 SMI" */ 51dfdcada3SDoug Rabson 52dfdcada3SDoug Rabson #ifndef _KERNEL 53dfdcada3SDoug Rabson 54dfdcada3SDoug Rabson 55dfdcada3SDoug Rabson /* 56dfdcada3SDoug Rabson * The following procedures are supported by the protocol in version 3: 57dfdcada3SDoug Rabson * 58dfdcada3SDoug Rabson * RPCBPROC_NULL() returns () 59dfdcada3SDoug Rabson * takes nothing, returns nothing 60dfdcada3SDoug Rabson * 61dfdcada3SDoug Rabson * RPCBPROC_SET(rpcb) returns (bool_t) 62dfdcada3SDoug Rabson * TRUE is success, FALSE is failure. Registers the tuple 63dfdcada3SDoug Rabson * [prog, vers, address, owner, netid]. 64dfdcada3SDoug Rabson * Finds out owner and netid information on its own. 65dfdcada3SDoug Rabson * 66dfdcada3SDoug Rabson * RPCBPROC_UNSET(rpcb) returns (bool_t) 67dfdcada3SDoug Rabson * TRUE is success, FALSE is failure. Un-registers tuple 68dfdcada3SDoug Rabson * [prog, vers, netid]. addresses is ignored. 69dfdcada3SDoug Rabson * If netid is NULL, unregister all. 70dfdcada3SDoug Rabson * 71dfdcada3SDoug Rabson * RPCBPROC_GETADDR(rpcb) returns (string). 72dfdcada3SDoug Rabson * 0 is failure. Otherwise returns the universal address where the 73dfdcada3SDoug Rabson * triple [prog, vers, netid] is registered. Ignore address and owner. 74dfdcada3SDoug Rabson * 75dfdcada3SDoug Rabson * RPCBPROC_DUMP() RETURNS (rpcblist_ptr) 76dfdcada3SDoug Rabson * used to dump the entire rpcbind maps 77dfdcada3SDoug Rabson * 78dfdcada3SDoug Rabson * RPCBPROC_CALLIT(rpcb_rmtcallargs) 79dfdcada3SDoug Rabson * RETURNS (rpcb_rmtcallres); 80dfdcada3SDoug Rabson * Calls the procedure on the remote machine. If it is not registered, 81dfdcada3SDoug Rabson * this procedure is quiet; i.e. it does not return error information!!! 82dfdcada3SDoug Rabson * This routine only passes null authentication parameters. 83dfdcada3SDoug Rabson * It has no interface to xdr routines for RPCBPROC_CALLIT. 84dfdcada3SDoug Rabson * 85dfdcada3SDoug Rabson * RPCBPROC_GETTIME() returns (int). 86dfdcada3SDoug Rabson * Gets the remote machines time 87dfdcada3SDoug Rabson * 88dfdcada3SDoug Rabson * RPCBPROC_UADDR2TADDR(strint) RETURNS (struct netbuf) 89dfdcada3SDoug Rabson * Returns the netbuf address from universal address. 90dfdcada3SDoug Rabson * 91dfdcada3SDoug Rabson * RPCBPROC_TADDR2UADDR(struct netbuf) RETURNS (string) 92dfdcada3SDoug Rabson * Returns the universal address from netbuf address. 93dfdcada3SDoug Rabson * 94dfdcada3SDoug Rabson * END OF RPCBIND VERSION 3 PROCEDURES 95dfdcada3SDoug Rabson */ 96dfdcada3SDoug Rabson /* 97dfdcada3SDoug Rabson * Except for RPCBPROC_CALLIT, the procedures above are carried over to 98dfdcada3SDoug Rabson * rpcbind version 4. Those below are added or modified for version 4. 99dfdcada3SDoug Rabson * NOTE: RPCBPROC_BCAST HAS THE SAME FUNCTIONALITY AND PROCEDURE NUMBER 100dfdcada3SDoug Rabson * AS RPCBPROC_CALLIT. 101dfdcada3SDoug Rabson * 102dfdcada3SDoug Rabson * RPCBPROC_BCAST(rpcb_rmtcallargs) 103dfdcada3SDoug Rabson * RETURNS (rpcb_rmtcallres); 104dfdcada3SDoug Rabson * Calls the procedure on the remote machine. If it is not registered, 105dfdcada3SDoug Rabson * this procedure IS quiet; i.e. it DOES NOT return error information!!! 106dfdcada3SDoug Rabson * This routine should be used for broadcasting and nothing else. 107dfdcada3SDoug Rabson * 108dfdcada3SDoug Rabson * RPCBPROC_GETVERSADDR(rpcb) returns (string). 109dfdcada3SDoug Rabson * 0 is failure. Otherwise returns the universal address where the 110dfdcada3SDoug Rabson * triple [prog, vers, netid] is registered. Ignore address and owner. 111dfdcada3SDoug Rabson * Same as RPCBPROC_GETADDR except that if the given version number 112dfdcada3SDoug Rabson * is not available, the address is not returned. 113dfdcada3SDoug Rabson * 114dfdcada3SDoug Rabson * RPCBPROC_INDIRECT(rpcb_rmtcallargs) 115dfdcada3SDoug Rabson * RETURNS (rpcb_rmtcallres); 116dfdcada3SDoug Rabson * Calls the procedure on the remote machine. If it is not registered, 117dfdcada3SDoug Rabson * this procedure is NOT quiet; i.e. it DOES return error information!!! 118dfdcada3SDoug Rabson * as any normal application would expect. 119dfdcada3SDoug Rabson * 120dfdcada3SDoug Rabson * RPCBPROC_GETADDRLIST(rpcb) returns (rpcb_entry_list_ptr). 121dfdcada3SDoug Rabson * Same as RPCBPROC_GETADDR except that it returns a list of all the 122dfdcada3SDoug Rabson * addresses registered for the combination (prog, vers) (for all 123dfdcada3SDoug Rabson * transports). 124dfdcada3SDoug Rabson * 125dfdcada3SDoug Rabson * RPCBPROC_GETSTAT(void) returns (rpcb_stat_byvers) 126dfdcada3SDoug Rabson * Returns the statistics about the kind of requests received by rpcbind. 127dfdcada3SDoug Rabson */ 128dfdcada3SDoug Rabson 129dfdcada3SDoug Rabson /* 130dfdcada3SDoug Rabson * A mapping of (program, version, network ID) to address 131dfdcada3SDoug Rabson */ 132dfdcada3SDoug Rabson 133dfdcada3SDoug Rabson struct rpcb { 134dfdcada3SDoug Rabson rpcprog_t r_prog; 135dfdcada3SDoug Rabson rpcvers_t r_vers; 136dfdcada3SDoug Rabson char *r_netid; 137dfdcada3SDoug Rabson char *r_addr; 138dfdcada3SDoug Rabson char *r_owner; 139dfdcada3SDoug Rabson }; 140dfdcada3SDoug Rabson typedef struct rpcb rpcb; 141dfdcada3SDoug Rabson 142dfdcada3SDoug Rabson typedef rpcb RPCB; 143dfdcada3SDoug Rabson 144dfdcada3SDoug Rabson 145dfdcada3SDoug Rabson /* 146dfdcada3SDoug Rabson * A list of mappings 147dfdcada3SDoug Rabson * 148dfdcada3SDoug Rabson * Below are two definitions for the rpcblist structure. This is done because 149dfdcada3SDoug Rabson * xdr_rpcblist() is specified to take a struct rpcblist **, rather than a 150dfdcada3SDoug Rabson * struct rpcblist * that rpcgen would produce. One version of the rpcblist 151dfdcada3SDoug Rabson * structure (actually called rp__list) is used with rpcgen, and the other is 152dfdcada3SDoug Rabson * defined only in the header file for compatibility with the specified 153dfdcada3SDoug Rabson * interface. 154dfdcada3SDoug Rabson */ 155dfdcada3SDoug Rabson 156dfdcada3SDoug Rabson struct rp__list { 157dfdcada3SDoug Rabson rpcb rpcb_map; 158dfdcada3SDoug Rabson struct rp__list *rpcb_next; 159dfdcada3SDoug Rabson }; 160dfdcada3SDoug Rabson typedef struct rp__list rp__list; 161dfdcada3SDoug Rabson 162dfdcada3SDoug Rabson typedef rp__list *rpcblist_ptr; 163dfdcada3SDoug Rabson 164dfdcada3SDoug Rabson typedef struct rp__list rpcblist; 165dfdcada3SDoug Rabson typedef struct rp__list RPCBLIST; 166dfdcada3SDoug Rabson 167dfdcada3SDoug Rabson #ifndef __cplusplus 168dfdcada3SDoug Rabson struct rpcblist { 169dfdcada3SDoug Rabson RPCB rpcb_map; 170dfdcada3SDoug Rabson struct rpcblist *rpcb_next; 171dfdcada3SDoug Rabson }; 172dfdcada3SDoug Rabson #endif 173dfdcada3SDoug Rabson 174dfdcada3SDoug Rabson #ifdef __cplusplus 175dfdcada3SDoug Rabson extern "C" { 176dfdcada3SDoug Rabson #endif 177dfdcada3SDoug Rabson extern bool_t xdr_rpcblist(XDR *, rpcblist**); 178dfdcada3SDoug Rabson #ifdef __cplusplus 179dfdcada3SDoug Rabson } 180dfdcada3SDoug Rabson #endif 181dfdcada3SDoug Rabson 182dfdcada3SDoug Rabson 183dfdcada3SDoug Rabson /* 184dfdcada3SDoug Rabson * Arguments of remote calls 185dfdcada3SDoug Rabson */ 186dfdcada3SDoug Rabson 187dfdcada3SDoug Rabson struct rpcb_rmtcallargs { 188dfdcada3SDoug Rabson rpcprog_t prog; 189dfdcada3SDoug Rabson rpcvers_t vers; 190dfdcada3SDoug Rabson rpcproc_t proc; 191dfdcada3SDoug Rabson struct { 192dfdcada3SDoug Rabson u_int args_len; 193dfdcada3SDoug Rabson char *args_val; 194dfdcada3SDoug Rabson } args; 195dfdcada3SDoug Rabson }; 196dfdcada3SDoug Rabson typedef struct rpcb_rmtcallargs rpcb_rmtcallargs; 197dfdcada3SDoug Rabson 198dfdcada3SDoug Rabson /* 199dfdcada3SDoug Rabson * Client-side only representation of rpcb_rmtcallargs structure. 200dfdcada3SDoug Rabson * 201dfdcada3SDoug Rabson * The routine that XDRs the rpcb_rmtcallargs structure must deal with the 202dfdcada3SDoug Rabson * opaque arguments in the "args" structure. xdr_rpcb_rmtcallargs() needs to 203dfdcada3SDoug Rabson * be passed the XDR routine that knows the args' structure. This routine 204dfdcada3SDoug Rabson * doesn't need to go over-the-wire (and it wouldn't make sense anyway) since 205dfdcada3SDoug Rabson * the application being called already knows the args structure. So we use a 206dfdcada3SDoug Rabson * different "XDR" structure on the client side, r_rpcb_rmtcallargs, which 207dfdcada3SDoug Rabson * includes the args' XDR routine. 208dfdcada3SDoug Rabson */ 209dfdcada3SDoug Rabson struct r_rpcb_rmtcallargs { 210dfdcada3SDoug Rabson rpcprog_t prog; 211dfdcada3SDoug Rabson rpcvers_t vers; 212dfdcada3SDoug Rabson rpcproc_t proc; 213dfdcada3SDoug Rabson struct { 214dfdcada3SDoug Rabson u_int args_len; 215dfdcada3SDoug Rabson char *args_val; 216dfdcada3SDoug Rabson } args; 217dfdcada3SDoug Rabson xdrproc_t xdr_args; /* encodes args */ 218dfdcada3SDoug Rabson }; 219dfdcada3SDoug Rabson 220dfdcada3SDoug Rabson 221dfdcada3SDoug Rabson /* 222dfdcada3SDoug Rabson * Results of the remote call 223dfdcada3SDoug Rabson */ 224dfdcada3SDoug Rabson 225dfdcada3SDoug Rabson struct rpcb_rmtcallres { 226dfdcada3SDoug Rabson char *addr; 227dfdcada3SDoug Rabson struct { 228dfdcada3SDoug Rabson u_int results_len; 229dfdcada3SDoug Rabson char *results_val; 230dfdcada3SDoug Rabson } results; 231dfdcada3SDoug Rabson }; 232dfdcada3SDoug Rabson typedef struct rpcb_rmtcallres rpcb_rmtcallres; 233dfdcada3SDoug Rabson 234dfdcada3SDoug Rabson /* 235dfdcada3SDoug Rabson * Client-side only representation of rpcb_rmtcallres structure. 236dfdcada3SDoug Rabson */ 237dfdcada3SDoug Rabson struct r_rpcb_rmtcallres { 238dfdcada3SDoug Rabson char *addr; 239dfdcada3SDoug Rabson struct { 240dfdcada3SDoug Rabson uint32_t results_len; 241dfdcada3SDoug Rabson char *results_val; 242dfdcada3SDoug Rabson } results; 243dfdcada3SDoug Rabson xdrproc_t xdr_res; /* decodes results */ 244dfdcada3SDoug Rabson }; 245dfdcada3SDoug Rabson 246dfdcada3SDoug Rabson /* 247dfdcada3SDoug Rabson * rpcb_entry contains a merged address of a service on a particular 248dfdcada3SDoug Rabson * transport, plus associated netconfig information. A list of rpcb_entrys 249dfdcada3SDoug Rabson * is returned by RPCBPROC_GETADDRLIST. See netconfig.h for values used 250dfdcada3SDoug Rabson * in r_nc_* fields. 251dfdcada3SDoug Rabson */ 252dfdcada3SDoug Rabson 253dfdcada3SDoug Rabson struct rpcb_entry { 254dfdcada3SDoug Rabson char *r_maddr; 255dfdcada3SDoug Rabson char *r_nc_netid; 256dfdcada3SDoug Rabson u_int r_nc_semantics; 257dfdcada3SDoug Rabson char *r_nc_protofmly; 258dfdcada3SDoug Rabson char *r_nc_proto; 259dfdcada3SDoug Rabson }; 260dfdcada3SDoug Rabson typedef struct rpcb_entry rpcb_entry; 261dfdcada3SDoug Rabson 262dfdcada3SDoug Rabson /* 263dfdcada3SDoug Rabson * A list of addresses supported by a service. 264dfdcada3SDoug Rabson */ 265dfdcada3SDoug Rabson 266dfdcada3SDoug Rabson struct rpcb_entry_list { 267dfdcada3SDoug Rabson rpcb_entry rpcb_entry_map; 268dfdcada3SDoug Rabson struct rpcb_entry_list *rpcb_entry_next; 269dfdcada3SDoug Rabson }; 270dfdcada3SDoug Rabson typedef struct rpcb_entry_list rpcb_entry_list; 271dfdcada3SDoug Rabson 272dfdcada3SDoug Rabson typedef rpcb_entry_list *rpcb_entry_list_ptr; 273dfdcada3SDoug Rabson 274dfdcada3SDoug Rabson /* 275dfdcada3SDoug Rabson * rpcbind statistics 276dfdcada3SDoug Rabson */ 277dfdcada3SDoug Rabson 278dfdcada3SDoug Rabson #define rpcb_highproc_2 RPCBPROC_CALLIT 279dfdcada3SDoug Rabson #define rpcb_highproc_3 RPCBPROC_TADDR2UADDR 280dfdcada3SDoug Rabson #define rpcb_highproc_4 RPCBPROC_GETSTAT 281dfdcada3SDoug Rabson #define RPCBSTAT_HIGHPROC 13 282dfdcada3SDoug Rabson #define RPCBVERS_STAT 3 283dfdcada3SDoug Rabson #define RPCBVERS_4_STAT 2 284dfdcada3SDoug Rabson #define RPCBVERS_3_STAT 1 285dfdcada3SDoug Rabson #define RPCBVERS_2_STAT 0 286dfdcada3SDoug Rabson 287dfdcada3SDoug Rabson /* Link list of all the stats about getport and getaddr */ 288dfdcada3SDoug Rabson 289dfdcada3SDoug Rabson struct rpcbs_addrlist { 290dfdcada3SDoug Rabson rpcprog_t prog; 291dfdcada3SDoug Rabson rpcvers_t vers; 292dfdcada3SDoug Rabson int success; 293dfdcada3SDoug Rabson int failure; 294dfdcada3SDoug Rabson char *netid; 295dfdcada3SDoug Rabson struct rpcbs_addrlist *next; 296dfdcada3SDoug Rabson }; 297dfdcada3SDoug Rabson typedef struct rpcbs_addrlist rpcbs_addrlist; 298dfdcada3SDoug Rabson 299dfdcada3SDoug Rabson /* Link list of all the stats about rmtcall */ 300dfdcada3SDoug Rabson 301dfdcada3SDoug Rabson struct rpcbs_rmtcalllist { 302dfdcada3SDoug Rabson rpcprog_t prog; 303dfdcada3SDoug Rabson rpcvers_t vers; 304dfdcada3SDoug Rabson rpcproc_t proc; 305dfdcada3SDoug Rabson int success; 306dfdcada3SDoug Rabson int failure; 307dfdcada3SDoug Rabson int indirect; 308dfdcada3SDoug Rabson char *netid; 309dfdcada3SDoug Rabson struct rpcbs_rmtcalllist *next; 310dfdcada3SDoug Rabson }; 311dfdcada3SDoug Rabson typedef struct rpcbs_rmtcalllist rpcbs_rmtcalllist; 312dfdcada3SDoug Rabson 313dfdcada3SDoug Rabson typedef int rpcbs_proc[RPCBSTAT_HIGHPROC]; 314dfdcada3SDoug Rabson 315dfdcada3SDoug Rabson typedef rpcbs_addrlist *rpcbs_addrlist_ptr; 316dfdcada3SDoug Rabson 317dfdcada3SDoug Rabson typedef rpcbs_rmtcalllist *rpcbs_rmtcalllist_ptr; 318dfdcada3SDoug Rabson 319dfdcada3SDoug Rabson struct rpcb_stat { 320dfdcada3SDoug Rabson rpcbs_proc info; 321dfdcada3SDoug Rabson int setinfo; 322dfdcada3SDoug Rabson int unsetinfo; 323dfdcada3SDoug Rabson rpcbs_addrlist_ptr addrinfo; 324dfdcada3SDoug Rabson rpcbs_rmtcalllist_ptr rmtinfo; 325dfdcada3SDoug Rabson }; 326dfdcada3SDoug Rabson typedef struct rpcb_stat rpcb_stat; 327dfdcada3SDoug Rabson 328dfdcada3SDoug Rabson /* 329dfdcada3SDoug Rabson * One rpcb_stat structure is returned for each version of rpcbind 330dfdcada3SDoug Rabson * being monitored. 331dfdcada3SDoug Rabson */ 332dfdcada3SDoug Rabson 333dfdcada3SDoug Rabson typedef rpcb_stat rpcb_stat_byvers[RPCBVERS_STAT]; 334dfdcada3SDoug Rabson 335dfdcada3SDoug Rabson /* 336dfdcada3SDoug Rabson * We don't define netbuf in RPCL, since it would contain structure member 337dfdcada3SDoug Rabson * names that would conflict with the definition of struct netbuf in 338dfdcada3SDoug Rabson * <tiuser.h>. Instead we merely declare the XDR routine xdr_netbuf() here, 339dfdcada3SDoug Rabson * and implement it ourselves in rpc/rpcb_prot.c. 340dfdcada3SDoug Rabson */ 341dfdcada3SDoug Rabson #ifdef __cplusplus 342dfdcada3SDoug Rabson extern "C" bool_t xdr_netbuf(XDR *, struct netbuf *); 343dfdcada3SDoug Rabson 344dfdcada3SDoug Rabson #else /* __STDC__ */ 345dfdcada3SDoug Rabson extern bool_t xdr_netbuf(XDR *, struct netbuf *); 346dfdcada3SDoug Rabson 347dfdcada3SDoug Rabson #endif 348dfdcada3SDoug Rabson 349dfdcada3SDoug Rabson #define RPCBVERS_3 RPCBVERS 350dfdcada3SDoug Rabson #define RPCBVERS_4 RPCBVERS4 351dfdcada3SDoug Rabson 352dfdcada3SDoug Rabson #else /* ndef _KERNEL */ 353dfdcada3SDoug Rabson #ifdef __cplusplus 354dfdcada3SDoug Rabson extern "C" { 355dfdcada3SDoug Rabson #endif 356dfdcada3SDoug Rabson 357dfdcada3SDoug Rabson /* 358dfdcada3SDoug Rabson * A mapping of (program, version, network ID) to address 359dfdcada3SDoug Rabson */ 360dfdcada3SDoug Rabson struct rpcb { 361dfdcada3SDoug Rabson rpcprog_t r_prog; /* program number */ 362dfdcada3SDoug Rabson rpcvers_t r_vers; /* version number */ 363dfdcada3SDoug Rabson char *r_netid; /* network id */ 364dfdcada3SDoug Rabson char *r_addr; /* universal address */ 365dfdcada3SDoug Rabson char *r_owner; /* owner of the mapping */ 366dfdcada3SDoug Rabson }; 367dfdcada3SDoug Rabson typedef struct rpcb RPCB; 368dfdcada3SDoug Rabson 369dfdcada3SDoug Rabson /* 370dfdcada3SDoug Rabson * A list of mappings 371dfdcada3SDoug Rabson */ 372dfdcada3SDoug Rabson struct rpcblist { 373dfdcada3SDoug Rabson RPCB rpcb_map; 374dfdcada3SDoug Rabson struct rpcblist *rpcb_next; 375dfdcada3SDoug Rabson }; 376dfdcada3SDoug Rabson typedef struct rpcblist RPCBLIST; 377dfdcada3SDoug Rabson typedef struct rpcblist *rpcblist_ptr; 378dfdcada3SDoug Rabson 379dfdcada3SDoug Rabson /* 380dfdcada3SDoug Rabson * Remote calls arguments 381dfdcada3SDoug Rabson */ 382dfdcada3SDoug Rabson struct rpcb_rmtcallargs { 383dfdcada3SDoug Rabson rpcprog_t prog; /* program number */ 384dfdcada3SDoug Rabson rpcvers_t vers; /* version number */ 385dfdcada3SDoug Rabson rpcproc_t proc; /* procedure number */ 386dfdcada3SDoug Rabson uint32_t arglen; /* arg len */ 387dfdcada3SDoug Rabson caddr_t args_ptr; /* argument */ 388dfdcada3SDoug Rabson xdrproc_t xdr_args; /* XDR routine for argument */ 389dfdcada3SDoug Rabson }; 390dfdcada3SDoug Rabson typedef struct rpcb_rmtcallargs rpcb_rmtcallargs; 391dfdcada3SDoug Rabson 392dfdcada3SDoug Rabson /* 393dfdcada3SDoug Rabson * Remote calls results 394dfdcada3SDoug Rabson */ 395dfdcada3SDoug Rabson struct rpcb_rmtcallres { 396dfdcada3SDoug Rabson char *addr_ptr; /* remote universal address */ 397dfdcada3SDoug Rabson uint32_t resultslen; /* results length */ 398dfdcada3SDoug Rabson caddr_t results_ptr; /* results */ 399dfdcada3SDoug Rabson xdrproc_t xdr_results; /* XDR routine for result */ 400dfdcada3SDoug Rabson }; 401dfdcada3SDoug Rabson typedef struct rpcb_rmtcallres rpcb_rmtcallres; 402dfdcada3SDoug Rabson 403dfdcada3SDoug Rabson struct rpcb_entry { 404dfdcada3SDoug Rabson char *r_maddr; 405dfdcada3SDoug Rabson char *r_nc_netid; 406dfdcada3SDoug Rabson unsigned int r_nc_semantics; 407dfdcada3SDoug Rabson char *r_nc_protofmly; 408dfdcada3SDoug Rabson char *r_nc_proto; 409dfdcada3SDoug Rabson }; 410dfdcada3SDoug Rabson typedef struct rpcb_entry rpcb_entry; 411dfdcada3SDoug Rabson 412dfdcada3SDoug Rabson /* 413dfdcada3SDoug Rabson * A list of addresses supported by a service. 414dfdcada3SDoug Rabson */ 415dfdcada3SDoug Rabson 416dfdcada3SDoug Rabson struct rpcb_entry_list { 417dfdcada3SDoug Rabson rpcb_entry rpcb_entry_map; 418dfdcada3SDoug Rabson struct rpcb_entry_list *rpcb_entry_next; 419dfdcada3SDoug Rabson }; 420dfdcada3SDoug Rabson typedef struct rpcb_entry_list rpcb_entry_list; 421dfdcada3SDoug Rabson 422dfdcada3SDoug Rabson typedef rpcb_entry_list *rpcb_entry_list_ptr; 423dfdcada3SDoug Rabson 424dfdcada3SDoug Rabson /* 425dfdcada3SDoug Rabson * rpcbind statistics 426dfdcada3SDoug Rabson */ 427dfdcada3SDoug Rabson 428dfdcada3SDoug Rabson #define rpcb_highproc_2 RPCBPROC_CALLIT 429dfdcada3SDoug Rabson #define rpcb_highproc_3 RPCBPROC_TADDR2UADDR 430dfdcada3SDoug Rabson #define rpcb_highproc_4 RPCBPROC_GETSTAT 431dfdcada3SDoug Rabson #define RPCBSTAT_HIGHPROC 13 432dfdcada3SDoug Rabson #define RPCBVERS_STAT 3 433dfdcada3SDoug Rabson #define RPCBVERS_4_STAT 2 434dfdcada3SDoug Rabson #define RPCBVERS_3_STAT 1 435dfdcada3SDoug Rabson #define RPCBVERS_2_STAT 0 436dfdcada3SDoug Rabson 437dfdcada3SDoug Rabson /* Link list of all the stats about getport and getaddr */ 438dfdcada3SDoug Rabson 439dfdcada3SDoug Rabson struct rpcbs_addrlist { 440dfdcada3SDoug Rabson rpcprog_t prog; 441dfdcada3SDoug Rabson rpcvers_t vers; 442dfdcada3SDoug Rabson int success; 443dfdcada3SDoug Rabson int failure; 444dfdcada3SDoug Rabson char *netid; 445dfdcada3SDoug Rabson struct rpcbs_addrlist *next; 446dfdcada3SDoug Rabson }; 447dfdcada3SDoug Rabson typedef struct rpcbs_addrlist rpcbs_addrlist; 448dfdcada3SDoug Rabson 449dfdcada3SDoug Rabson /* Link list of all the stats about rmtcall */ 450dfdcada3SDoug Rabson 451dfdcada3SDoug Rabson struct rpcbs_rmtcalllist { 452dfdcada3SDoug Rabson rpcprog_t prog; 453dfdcada3SDoug Rabson rpcvers_t vers; 454dfdcada3SDoug Rabson rpcproc_t proc; 455dfdcada3SDoug Rabson int success; 456dfdcada3SDoug Rabson int failure; 457dfdcada3SDoug Rabson int indirect; 458dfdcada3SDoug Rabson char *netid; 459dfdcada3SDoug Rabson struct rpcbs_rmtcalllist *next; 460dfdcada3SDoug Rabson }; 461dfdcada3SDoug Rabson typedef struct rpcbs_rmtcalllist rpcbs_rmtcalllist; 462dfdcada3SDoug Rabson 463dfdcada3SDoug Rabson typedef int rpcbs_proc[RPCBSTAT_HIGHPROC]; 464dfdcada3SDoug Rabson 465dfdcada3SDoug Rabson typedef rpcbs_addrlist *rpcbs_addrlist_ptr; 466dfdcada3SDoug Rabson 467dfdcada3SDoug Rabson typedef rpcbs_rmtcalllist *rpcbs_rmtcalllist_ptr; 468dfdcada3SDoug Rabson 469dfdcada3SDoug Rabson struct rpcb_stat { 470dfdcada3SDoug Rabson rpcbs_proc info; 471dfdcada3SDoug Rabson int setinfo; 472dfdcada3SDoug Rabson int unsetinfo; 473dfdcada3SDoug Rabson rpcbs_addrlist_ptr addrinfo; 474dfdcada3SDoug Rabson rpcbs_rmtcalllist_ptr rmtinfo; 475dfdcada3SDoug Rabson }; 476dfdcada3SDoug Rabson typedef struct rpcb_stat rpcb_stat; 477dfdcada3SDoug Rabson 478dfdcada3SDoug Rabson /* 479dfdcada3SDoug Rabson * One rpcb_stat structure is returned for each version of rpcbind 480dfdcada3SDoug Rabson * being monitored. 481dfdcada3SDoug Rabson */ 482dfdcada3SDoug Rabson 483dfdcada3SDoug Rabson typedef rpcb_stat rpcb_stat_byvers[RPCBVERS_STAT]; 484dfdcada3SDoug Rabson 485dfdcada3SDoug Rabson #ifdef __cplusplus 486dfdcada3SDoug Rabson } 487dfdcada3SDoug Rabson #endif 488dfdcada3SDoug Rabson 489dfdcada3SDoug Rabson #endif /* ndef _KERNEL */ 490dfdcada3SDoug Rabson 491dfdcada3SDoug Rabson #define _PATH_RPCBINDSOCK "/var/run/rpcbind.sock" 492dfdcada3SDoug Rabson 493dfdcada3SDoug Rabson #define RPCBPROG ((unsigned long)(100000)) 494dfdcada3SDoug Rabson #define RPCBVERS ((unsigned long)(3)) 495dfdcada3SDoug Rabson 496dfdcada3SDoug Rabson extern void rpcbprog_3(struct svc_req *rqstp, SVCXPRT *transp); 497dfdcada3SDoug Rabson #define RPCBPROC_SET ((unsigned long)(1)) 498dfdcada3SDoug Rabson extern bool_t * rpcbproc_set_3(RPCB *, CLIENT *); 499dfdcada3SDoug Rabson extern bool_t * rpcbproc_set_3_svc(RPCB *, struct svc_req *); 500dfdcada3SDoug Rabson #define RPCBPROC_UNSET ((unsigned long)(2)) 501dfdcada3SDoug Rabson extern bool_t * rpcbproc_unset_3(RPCB *, CLIENT *); 502dfdcada3SDoug Rabson extern bool_t * rpcbproc_unset_3_svc(RPCB *, struct svc_req *); 503dfdcada3SDoug Rabson #define RPCBPROC_GETADDR ((unsigned long)(3)) 504dfdcada3SDoug Rabson extern char ** rpcbproc_getaddr_3(RPCB *, CLIENT *); 505dfdcada3SDoug Rabson extern char ** rpcbproc_getaddr_3_svc(RPCB *, struct svc_req *); 506dfdcada3SDoug Rabson #define RPCBPROC_DUMP ((unsigned long)(4)) 507dfdcada3SDoug Rabson extern rpcblist_ptr * rpcbproc_dump_3(void *, CLIENT *); 508dfdcada3SDoug Rabson extern rpcblist_ptr * rpcbproc_dump_3_svc(void *, struct svc_req *); 509dfdcada3SDoug Rabson #define RPCBPROC_CALLIT ((unsigned long)(5)) 510dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_callit_3(rpcb_rmtcallargs *, CLIENT *); 511dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_callit_3_svc(rpcb_rmtcallargs *, struct svc_req *); 512dfdcada3SDoug Rabson #define RPCBPROC_GETTIME ((unsigned long)(6)) 513dfdcada3SDoug Rabson extern u_int * rpcbproc_gettime_3(void *, CLIENT *); 514dfdcada3SDoug Rabson extern u_int * rpcbproc_gettime_3_svc(void *, struct svc_req *); 515dfdcada3SDoug Rabson #define RPCBPROC_UADDR2TADDR ((unsigned long)(7)) 516dfdcada3SDoug Rabson extern struct netbuf * rpcbproc_uaddr2taddr_3(char **, CLIENT *); 517dfdcada3SDoug Rabson extern struct netbuf * rpcbproc_uaddr2taddr_3_svc(char **, struct svc_req *); 518dfdcada3SDoug Rabson #define RPCBPROC_TADDR2UADDR ((unsigned long)(8)) 519dfdcada3SDoug Rabson extern char ** rpcbproc_taddr2uaddr_3(struct netbuf *, CLIENT *); 520dfdcada3SDoug Rabson extern char ** rpcbproc_taddr2uaddr_3_svc(struct netbuf *, struct svc_req *); 521dfdcada3SDoug Rabson extern int rpcbprog_3_freeresult(SVCXPRT *, xdrproc_t, caddr_t); 522dfdcada3SDoug Rabson #define RPCBVERS4 ((unsigned long)(4)) 523dfdcada3SDoug Rabson 524dfdcada3SDoug Rabson extern void rpcbprog_4(struct svc_req *rqstp, SVCXPRT *transp); 525dfdcada3SDoug Rabson extern bool_t * rpcbproc_set_4(RPCB *, CLIENT *); 526dfdcada3SDoug Rabson extern bool_t * rpcbproc_set_4_svc(RPCB *, struct svc_req *); 527dfdcada3SDoug Rabson extern bool_t * rpcbproc_unset_4(RPCB *, CLIENT *); 528dfdcada3SDoug Rabson extern bool_t * rpcbproc_unset_4_svc(RPCB *, struct svc_req *); 529dfdcada3SDoug Rabson extern char ** rpcbproc_getaddr_4(RPCB *, CLIENT *); 530dfdcada3SDoug Rabson extern char ** rpcbproc_getaddr_4_svc(RPCB *, struct svc_req *); 531dfdcada3SDoug Rabson extern rpcblist_ptr * rpcbproc_dump_4(void *, CLIENT *); 532dfdcada3SDoug Rabson extern rpcblist_ptr * rpcbproc_dump_4_svc(void *, struct svc_req *); 533dfdcada3SDoug Rabson #define RPCBPROC_BCAST ((unsigned long)(RPCBPROC_CALLIT)) 534dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_bcast_4(rpcb_rmtcallargs *, CLIENT *); 535dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_bcast_4_svc(rpcb_rmtcallargs *, struct svc_req *); 536dfdcada3SDoug Rabson extern u_int * rpcbproc_gettime_4(void *, CLIENT *); 537dfdcada3SDoug Rabson extern u_int * rpcbproc_gettime_4_svc(void *, struct svc_req *); 538dfdcada3SDoug Rabson extern struct netbuf * rpcbproc_uaddr2taddr_4(char **, CLIENT *); 539dfdcada3SDoug Rabson extern struct netbuf * rpcbproc_uaddr2taddr_4_svc(char **, struct svc_req *); 540dfdcada3SDoug Rabson extern char ** rpcbproc_taddr2uaddr_4(struct netbuf *, CLIENT *); 541dfdcada3SDoug Rabson extern char ** rpcbproc_taddr2uaddr_4_svc(struct netbuf *, struct svc_req *); 542dfdcada3SDoug Rabson #define RPCBPROC_GETVERSADDR ((unsigned long)(9)) 543dfdcada3SDoug Rabson extern char ** rpcbproc_getversaddr_4(RPCB *, CLIENT *); 544dfdcada3SDoug Rabson extern char ** rpcbproc_getversaddr_4_svc(RPCB *, struct svc_req *); 545dfdcada3SDoug Rabson #define RPCBPROC_INDIRECT ((unsigned long)(10)) 546dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_indirect_4(rpcb_rmtcallargs *, CLIENT *); 547dfdcada3SDoug Rabson extern rpcb_rmtcallres * rpcbproc_indirect_4_svc(rpcb_rmtcallargs *, struct svc_req *); 548dfdcada3SDoug Rabson #define RPCBPROC_GETADDRLIST ((unsigned long)(11)) 549dfdcada3SDoug Rabson extern rpcb_entry_list_ptr * rpcbproc_getaddrlist_4(RPCB *, CLIENT *); 550dfdcada3SDoug Rabson extern rpcb_entry_list_ptr * rpcbproc_getaddrlist_4_svc(RPCB *, struct svc_req *); 551dfdcada3SDoug Rabson #define RPCBPROC_GETSTAT ((unsigned long)(12)) 552dfdcada3SDoug Rabson extern rpcb_stat * rpcbproc_getstat_4(void *, CLIENT *); 553dfdcada3SDoug Rabson extern rpcb_stat * rpcbproc_getstat_4_svc(void *, struct svc_req *); 554dfdcada3SDoug Rabson extern int rpcbprog_4_freeresult(SVCXPRT *, xdrproc_t, caddr_t); 555dfdcada3SDoug Rabson 556dfdcada3SDoug Rabson /* the xdr functions */ 557dfdcada3SDoug Rabson extern bool_t xdr_rpcb(XDR *, RPCB *); 558dfdcada3SDoug Rabson #ifndef _KERNEL 559dfdcada3SDoug Rabson extern bool_t xdr_rp__list(XDR *, rp__list*); 560dfdcada3SDoug Rabson #endif 561dfdcada3SDoug Rabson extern bool_t xdr_rpcblist_ptr(XDR *, rpcblist_ptr*); 562dfdcada3SDoug Rabson extern bool_t xdr_rpcb_rmtcallargs(XDR *, rpcb_rmtcallargs*); 563dfdcada3SDoug Rabson extern bool_t xdr_rpcb_rmtcallres(XDR *, rpcb_rmtcallres*); 564dfdcada3SDoug Rabson extern bool_t xdr_rpcb_entry(XDR *, rpcb_entry*); 565dfdcada3SDoug Rabson extern bool_t xdr_rpcb_entry_list(XDR *, rpcb_entry_list*); 566dfdcada3SDoug Rabson extern bool_t xdr_rpcb_entry_list_ptr(XDR *, rpcb_entry_list_ptr*); 567dfdcada3SDoug Rabson extern bool_t xdr_rpcbs_addrlist(XDR *, rpcbs_addrlist*); 568dfdcada3SDoug Rabson extern bool_t xdr_rpcbs_rmtcalllist(XDR *, rpcbs_rmtcalllist*); 569dfdcada3SDoug Rabson extern bool_t xdr_rpcbs_proc(XDR *, rpcbs_proc); 570dfdcada3SDoug Rabson extern bool_t xdr_rpcbs_addrlist_ptr(XDR *, rpcbs_addrlist_ptr*); 571dfdcada3SDoug Rabson extern bool_t xdr_rpcbs_rmtcalllist_ptr(XDR *, rpcbs_rmtcalllist_ptr*); 572dfdcada3SDoug Rabson extern bool_t xdr_rpcb_stat(XDR *, rpcb_stat*); 573dfdcada3SDoug Rabson extern bool_t xdr_rpcb_stat_byvers(XDR *, rpcb_stat_byvers); 574dfdcada3SDoug Rabson 575dfdcada3SDoug Rabson #ifdef __cplusplus 576dfdcada3SDoug Rabson } 577dfdcada3SDoug Rabson #endif 578dfdcada3SDoug Rabson 579dfdcada3SDoug Rabson #endif /* !_RPCB_PROT_H_RPCGEN */ 580