X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=portmap%2Fportmap.c;h=431fb1560b9e0d94a636f779bfc07b24d447cab6;hb=41d82d7d825b9b4e73bb227f5b2fafa86067cba0;hp=69b8ad56e73ae534b15987ca6c412ea1478cfcbb;hpb=1896d37bfaae78bfa0e6ee3e3fb19b0a92bb1adb;p=deb_libnfs.git
diff --git a/portmap/portmap.c b/portmap/portmap.c
index 69b8ad5..431fb15 100644
--- a/portmap/portmap.c
+++ b/portmap/portmap.c
@@ -15,6 +15,10 @@
along with this program; if not, see .
*/
+#if defined(WIN32)
+#include
+#endif
+
#include
#include
#include
@@ -46,7 +50,7 @@ int rpc_pmap_null_async(struct rpc_context *rpc, rpc_cb cb, void *private_data)
int rpc_pmap_getport_async(struct rpc_context *rpc, int program, int version, rpc_cb cb, void *private_data)
{
struct rpc_pdu *pdu;
- struct mapping m;
+ struct pmap_mapping m;
pdu = rpc_allocate_pdu(rpc, PMAP_PROGRAM, PMAP_V2, PMAP_GETPORT, cb, private_data, (xdrproc_t)xdr_int, sizeof(uint32_t));
if (pdu == NULL) {
@@ -58,7 +62,7 @@ int rpc_pmap_getport_async(struct rpc_context *rpc, int program, int version, rp
m.vers = version;
m.prot = IPPROTO_TCP;
m.port = 0;
- if (xdr_mapping(&pdu->xdr, &m) == 0) {
+ if (xdr_pmap_mapping(&pdu->xdr, &m) == 0) {
rpc_set_error(rpc, "XDR error: Failed to encode data for portmap/getport call");
rpc_free_pdu(rpc, pdu);
return -1;
@@ -72,3 +76,34 @@ int rpc_pmap_getport_async(struct rpc_context *rpc, int program, int version, rp
return 0;
}
+
+int rpc_pmap_callit_async(struct rpc_context *rpc, int program, int version, int procedure, const char *data, int datalen, rpc_cb cb, void *private_data)
+{
+ struct rpc_pdu *pdu;
+ struct pmap_call_args ca;
+
+ pdu = rpc_allocate_pdu(rpc, PMAP_PROGRAM, PMAP_V2, PMAP_CALLIT, cb, private_data, (xdrproc_t)xdr_pmap_call_result, sizeof(pmap_call_result));
+ if (pdu == NULL) {
+ rpc_set_error(rpc, "Out of memory. Failed to allocate pdu for portmap/callit call");
+ return -1;
+ }
+
+ ca.prog = program;
+ ca.vers = version;
+ ca.proc = procedure;
+ ca.args.args_len = datalen;
+ ca.args.args_val = data;
+
+ if (xdr_pmap_call_args(&pdu->xdr, &ca) == 0) {
+ rpc_set_error(rpc, "XDR error: Failed to encode data for portmap/callit call");
+ rpc_free_pdu(rpc, pdu);
+ return -1;
+ }
+
+ if (rpc_queue_pdu(rpc, pdu) != 0) {
+ rpc_set_error(rpc, "Failed to queue portmap/callit pdu: %s", rpc_get_error(rpc));
+ return -1;
+ }
+
+ return 0;
+}