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