X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=portmap%2Flibnfs-raw-portmap.h;h=ae0d06789fe3588e74bcb1682999f62a8c3c56ae;hb=8e003243fbec4cff4af3e9ca01ea713065336970;hp=2a41831701b47390cab67474fd56b7e13d11614d;hpb=5245608a6587cf6b5279ffc4fde701d8dce23bf3;p=deb_libnfs.git diff --git a/portmap/libnfs-raw-portmap.h b/portmap/libnfs-raw-portmap.h index 2a41831..ae0d067 100644 --- a/portmap/libnfs-raw-portmap.h +++ b/portmap/libnfs-raw-portmap.h @@ -54,10 +54,10 @@ struct pmap2_dump_result { }; typedef struct pmap2_dump_result pmap2_dump_result; -struct pmap3_getaddr_result { +struct pmap3_string_result { char *addr; }; -typedef struct pmap3_getaddr_result pmap3_getaddr_result; +typedef struct pmap3_string_result pmap3_string_result; struct pmap3_mapping { u_int prog; @@ -79,6 +79,35 @@ struct pmap3_dump_result { }; typedef struct pmap3_dump_result pmap3_dump_result; +struct pmap3_call_args { + u_int prog; + u_int vers; + u_int proc; + struct { + u_int args_len; + char *args_val; + } args; +}; +typedef struct pmap3_call_args pmap3_call_args; + +struct pmap3_call_result { + u_int port; + struct { + u_int res_len; + char *res_val; + } res; +}; +typedef struct pmap3_call_result pmap3_call_result; + +struct pmap3_netbuf { + u_int maxlen; + struct { + u_int buf_len; + char *buf_val; + } buf; +}; +typedef struct pmap3_netbuf pmap3_netbuf; + #define PMAP_PROGRAM 100000 #define PMAP_V2 2 @@ -137,14 +166,23 @@ extern bool_t * pmap3_set_3_svc(pmap3_mapping *, struct svc_req *); extern bool_t * pmap3_unset_3(pmap3_mapping *, CLIENT *); extern bool_t * pmap3_unset_3_svc(pmap3_mapping *, struct svc_req *); #define PMAP3_GETADDR 3 -extern pmap3_getaddr_result * pmap3_getaddr_3(pmap3_mapping *, CLIENT *); -extern pmap3_getaddr_result * pmap3_getaddr_3_svc(pmap3_mapping *, struct svc_req *); +extern pmap3_string_result * pmap3_getaddr_3(pmap3_mapping *, CLIENT *); +extern pmap3_string_result * pmap3_getaddr_3_svc(pmap3_mapping *, struct svc_req *); #define PMAP3_DUMP 4 extern pmap3_dump_result * pmap3_dump_3(void *, CLIENT *); extern pmap3_dump_result * pmap3_dump_3_svc(void *, struct svc_req *); +#define PMAP3_CALLIT 5 +extern pmap3_call_result * pmap3_callit_3(pmap3_call_args *, CLIENT *); +extern pmap3_call_result * pmap3_callit_3_svc(pmap3_call_args *, struct svc_req *); #define PMAP3_GETTIME 6 extern u_int * pmap3_gettime_3(void *, CLIENT *); extern u_int * pmap3_gettime_3_svc(void *, struct svc_req *); +#define PMAP3_UADDR2TADDR 7 +extern pmap3_netbuf * pmap3_uaddr2taddr_3(char **, CLIENT *); +extern pmap3_netbuf * pmap3_uaddr2taddr_3_svc(char **, struct svc_req *); +#define PMAP3_TADDR2UADDR 8 +extern struct pmap3_string_result * pmap3_taddr2uaddr_3(pmap3_netbuf *, CLIENT *); +extern struct pmap3_string_result * pmap3_taddr2uaddr_3_svc(pmap3_netbuf *, struct svc_req *); extern int pmap_program_3_freeresult (SVCXPRT *, zdrproc_t, caddr_t); #else /* K&R C */ @@ -158,14 +196,23 @@ extern bool_t * pmap3_set_3_svc(); extern bool_t * pmap3_unset_3(); extern bool_t * pmap3_unset_3_svc(); #define PMAP3_GETADDR 3 -extern pmap3_getaddr_result * pmap3_getaddr_3(); -extern pmap3_getaddr_result * pmap3_getaddr_3_svc(); +extern pmap3_string_result * pmap3_getaddr_3(); +extern pmap3_string_result * pmap3_getaddr_3_svc(); #define PMAP3_DUMP 4 extern pmap3_dump_result * pmap3_dump_3(); extern pmap3_dump_result * pmap3_dump_3_svc(); +#define PMAP3_CALLIT 5 +extern pmap3_call_result * pmap3_callit_3(); +extern pmap3_call_result * pmap3_callit_3_svc(); #define PMAP3_GETTIME 6 extern u_int * pmap3_gettime_3(); extern u_int * pmap3_gettime_3_svc(); +#define PMAP3_UADDR2TADDR 7 +extern pmap3_netbuf * pmap3_uaddr2taddr_3(); +extern pmap3_netbuf * pmap3_uaddr2taddr_3_svc(); +#define PMAP3_TADDR2UADDR 8 +extern struct pmap3_string_result * pmap3_taddr2uaddr_3(); +extern struct pmap3_string_result * pmap3_taddr2uaddr_3_svc(); extern int pmap_program_3_freeresult (); #endif /* K&R C */ @@ -177,10 +224,13 @@ extern bool_t zdr_pmap2_call_args (ZDR *, pmap2_call_args*); extern bool_t zdr_pmap2_call_result (ZDR *, pmap2_call_result*); extern bool_t zdr_pmap2_mapping_list (ZDR *, pmap2_mapping_list*); extern bool_t zdr_pmap2_dump_result (ZDR *, pmap2_dump_result*); -extern bool_t zdr_pmap3_getaddr_result (ZDR *, pmap3_getaddr_result*); +extern bool_t zdr_pmap3_string_result (ZDR *, pmap3_string_result*); extern bool_t zdr_pmap3_mapping (ZDR *, pmap3_mapping*); extern bool_t zdr_pmap3_mapping_list (ZDR *, pmap3_mapping_list*); extern bool_t zdr_pmap3_dump_result (ZDR *, pmap3_dump_result*); +extern bool_t zdr_pmap3_call_args (ZDR *, pmap3_call_args*); +extern bool_t zdr_pmap3_call_result (ZDR *, pmap3_call_result*); +extern bool_t zdr_pmap3_netbuf (ZDR *, pmap3_netbuf*); #else /* K&R C */ extern bool_t zdr_pmap2_mapping (); @@ -188,10 +238,13 @@ extern bool_t zdr_pmap2_call_args (); extern bool_t zdr_pmap2_call_result (); extern bool_t zdr_pmap2_mapping_list (); extern bool_t zdr_pmap2_dump_result (); -extern bool_t zdr_pmap3_getaddr_result (); +extern bool_t zdr_pmap3_string_result (); extern bool_t zdr_pmap3_mapping (); extern bool_t zdr_pmap3_mapping_list (); extern bool_t zdr_pmap3_dump_result (); +extern bool_t zdr_pmap3_call_args (); +extern bool_t zdr_pmap3_call_result (); +extern bool_t zdr_pmap3_netbuf (); #endif /* K&R C */