1dfdcada3SDoug Rabson /* $NetBSD: pmap_prot.h,v 1.8 2000/06/02 22:57:55 fvdl Exp $ */ 2dfdcada3SDoug Rabson 3*2e322d37SHiroki Sato /*- 4*2e322d37SHiroki Sato * Copyright (c) 2009, Sun Microsystems, Inc. 5*2e322d37SHiroki Sato * All rights reserved. 6dfdcada3SDoug Rabson * 7*2e322d37SHiroki Sato * Redistribution and use in source and binary forms, with or without 8*2e322d37SHiroki Sato * modification, are permitted provided that the following conditions are met: 9*2e322d37SHiroki Sato * - Redistributions of source code must retain the above copyright notice, 10*2e322d37SHiroki Sato * this list of conditions and the following disclaimer. 11*2e322d37SHiroki Sato * - Redistributions in binary form must reproduce the above copyright notice, 12*2e322d37SHiroki Sato * this list of conditions and the following disclaimer in the documentation 13*2e322d37SHiroki Sato * and/or other materials provided with the distribution. 14*2e322d37SHiroki Sato * - Neither the name of Sun Microsystems, Inc. nor the names of its 15*2e322d37SHiroki Sato * contributors may be used to endorse or promote products derived 16*2e322d37SHiroki Sato * from this software without specific prior written permission. 17dfdcada3SDoug Rabson * 18*2e322d37SHiroki Sato * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 19*2e322d37SHiroki Sato * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20*2e322d37SHiroki Sato * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21*2e322d37SHiroki Sato * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 22*2e322d37SHiroki Sato * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23*2e322d37SHiroki Sato * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24*2e322d37SHiroki Sato * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25*2e322d37SHiroki Sato * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26*2e322d37SHiroki Sato * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27*2e322d37SHiroki Sato * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28*2e322d37SHiroki Sato * POSSIBILITY OF SUCH DAMAGE. 29dfdcada3SDoug Rabson * 30dfdcada3SDoug Rabson * from: @(#)pmap_prot.h 1.14 88/02/08 SMI 31dfdcada3SDoug Rabson * from: @(#)pmap_prot.h 2.1 88/07/29 4.0 RPCSRC 32dfdcada3SDoug Rabson * $FreeBSD$ 33dfdcada3SDoug Rabson */ 34dfdcada3SDoug Rabson 35dfdcada3SDoug Rabson /* 36dfdcada3SDoug Rabson * pmap_prot.h 37dfdcada3SDoug Rabson * Protocol for the local binder service, or pmap. 38dfdcada3SDoug Rabson * 39dfdcada3SDoug Rabson * Copyright (C) 1984, Sun Microsystems, Inc. 40dfdcada3SDoug Rabson * 41dfdcada3SDoug Rabson * The following procedures are supported by the protocol: 42dfdcada3SDoug Rabson * 43dfdcada3SDoug Rabson * PMAPPROC_NULL() returns () 44dfdcada3SDoug Rabson * takes nothing, returns nothing 45dfdcada3SDoug Rabson * 4671066861SDoug Rabson * PMAPPROC_SET(struct portmap) returns (bool_t) 47dfdcada3SDoug Rabson * TRUE is success, FALSE is failure. Registers the tuple 48dfdcada3SDoug Rabson * [prog, vers, prot, port]. 49dfdcada3SDoug Rabson * 5071066861SDoug Rabson * PMAPPROC_UNSET(struct portmap) returns (bool_t) 51dfdcada3SDoug Rabson * TRUE is success, FALSE is failure. Un-registers pair 52dfdcada3SDoug Rabson * [prog, vers]. prot and port are ignored. 53dfdcada3SDoug Rabson * 5471066861SDoug Rabson * PMAPPROC_GETPORT(struct portmap) returns (long unsigned). 55dfdcada3SDoug Rabson * 0 is failure. Otherwise returns the port number where the pair 56dfdcada3SDoug Rabson * [prog, vers] is registered. It may lie! 57dfdcada3SDoug Rabson * 58dfdcada3SDoug Rabson * PMAPPROC_DUMP() RETURNS (struct pmaplist *) 59dfdcada3SDoug Rabson * 60dfdcada3SDoug Rabson * PMAPPROC_CALLIT(unsigned, unsigned, unsigned, string<>) 61dfdcada3SDoug Rabson * RETURNS (port, string<>); 62dfdcada3SDoug Rabson * usage: encapsulatedresults = PMAPPROC_CALLIT(prog, vers, proc, encapsulatedargs); 63dfdcada3SDoug Rabson * Calls the procedure on the local machine. If it is not registered, 64dfdcada3SDoug Rabson * this procedure is quite; ie it does not return error information!!! 65dfdcada3SDoug Rabson * This procedure only is supported on rpc/udp and calls via 66dfdcada3SDoug Rabson * rpc/udp. This routine only passes null authentication parameters. 67dfdcada3SDoug Rabson * This file has no interface to xdr routines for PMAPPROC_CALLIT. 68dfdcada3SDoug Rabson * 69dfdcada3SDoug Rabson * The service supports remote procedure calls on udp/ip or tcp/ip socket 111. 70dfdcada3SDoug Rabson */ 71dfdcada3SDoug Rabson 72dfdcada3SDoug Rabson #ifndef _RPC_PMAP_PROT_H 73dfdcada3SDoug Rabson #define _RPC_PMAP_PROT_H 74dfdcada3SDoug Rabson #include <sys/cdefs.h> 75dfdcada3SDoug Rabson 76dfdcada3SDoug Rabson #define PMAPPORT ((u_short)111) 77dfdcada3SDoug Rabson #define PMAPPROG ((u_long)100000) 78dfdcada3SDoug Rabson #define PMAPVERS ((u_long)2) 79dfdcada3SDoug Rabson #define PMAPVERS_PROTO ((u_long)2) 80dfdcada3SDoug Rabson #define PMAPVERS_ORIG ((u_long)1) 81dfdcada3SDoug Rabson #define PMAPPROC_NULL ((u_long)0) 82dfdcada3SDoug Rabson #define PMAPPROC_SET ((u_long)1) 83dfdcada3SDoug Rabson #define PMAPPROC_UNSET ((u_long)2) 84dfdcada3SDoug Rabson #define PMAPPROC_GETPORT ((u_long)3) 85dfdcada3SDoug Rabson #define PMAPPROC_DUMP ((u_long)4) 86dfdcada3SDoug Rabson #define PMAPPROC_CALLIT ((u_long)5) 87dfdcada3SDoug Rabson 8871066861SDoug Rabson struct portmap { 89dfdcada3SDoug Rabson long unsigned pm_prog; 90dfdcada3SDoug Rabson long unsigned pm_vers; 91dfdcada3SDoug Rabson long unsigned pm_prot; 92dfdcada3SDoug Rabson long unsigned pm_port; 93dfdcada3SDoug Rabson }; 94dfdcada3SDoug Rabson 95dfdcada3SDoug Rabson struct pmaplist { 9671066861SDoug Rabson struct portmap pml_map; 97dfdcada3SDoug Rabson struct pmaplist *pml_next; 98dfdcada3SDoug Rabson }; 99dfdcada3SDoug Rabson 100dfdcada3SDoug Rabson __BEGIN_DECLS 10171066861SDoug Rabson extern bool_t xdr_portmap(XDR *, struct portmap *); 102dfdcada3SDoug Rabson extern bool_t xdr_pmaplist(XDR *, struct pmaplist **); 103dfdcada3SDoug Rabson extern bool_t xdr_pmaplist_ptr(XDR *, struct pmaplist *); 104dfdcada3SDoug Rabson __END_DECLS 105dfdcada3SDoug Rabson 106dfdcada3SDoug Rabson #endif /* !_RPC_PMAP_PROT_H */ 107