X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=support%2Fnfs%2Frpcmisc.c;h=b73187a488474c9acab462f0774bf1a65d689b17;hp=dab2be8693e58c641e31232e6e1458508c1e348f;hb=fe34ff0312c7c22554087ecd78bbbeadb38ce195;hpb=6e419afa493acc1c88fbc4d1a27bfb1784c1297a diff --git a/support/nfs/rpcmisc.c b/support/nfs/rpcmisc.c index dab2be8..b73187a 100644 --- a/support/nfs/rpcmisc.c +++ b/support/nfs/rpcmisc.c @@ -37,8 +37,6 @@ #define socklen_t int #endif -static int makesock(int port, int proto); - #define _RPCSVC_CLOSEDOWN 120 int _rpcpmstart = 0; int _rpcfdtype = 0; @@ -69,6 +67,46 @@ closedown(int sig) (void) alarm(_RPCSVC_CLOSEDOWN); } +/* + * Create listener socket for a given port + * + * Return an open network socket on success; otherwise return -1 + * if some error occurs. + */ +static int +makesock(int port, int proto) +{ + struct sockaddr_in sin; + int sock, sock_type, val; + + sock_type = (proto == IPPROTO_UDP) ? SOCK_DGRAM : SOCK_STREAM; + sock = socket(AF_INET, sock_type, proto); + if (sock < 0) { + xlog(L_FATAL, "Could not make a socket: %s", + strerror(errno)); + return -1; + } + memset((char *) &sin, 0, sizeof(sin)); + sin.sin_family = AF_INET; + sin.sin_addr.s_addr = htonl(INADDR_ANY); + sin.sin_port = htons(port); + + val = 1; + if (proto == IPPROTO_TCP) + if (setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, + &val, sizeof(val)) < 0) + xlog(L_ERROR, "setsockopt failed: %s", + strerror(errno)); + + if (bind(sock, (struct sockaddr *) &sin, sizeof(sin)) == -1) { + xlog(L_FATAL, "Could not bind name to socket: %s", + strerror(errno)); + return -1; + } + + return sock; +} + void rpc_init(char *name, int prog, int vers, void (*dispatch)(struct svc_req *, register SVCXPRT *), @@ -116,7 +154,7 @@ rpc_init(char *name, int prog, int vers, sock = makesock(defport, IPPROTO_UDP); } if (sock == RPC_ANYSOCK) - sock = svcudp_socket (prog, 1); + sock = svcudp_socket (prog); transp = svcudp_create(sock); if (transp == NULL) { xlog(L_FATAL, "cannot create udp service."); @@ -162,43 +200,3 @@ rpc_init(char *name, int prog, int vers, alarm(_RPCSVC_CLOSEDOWN); } } - -/* - * Create listener socket for a given port - * - * Return an open network socket on success; otherwise return -1 - * if some error occurs. - */ -static int -makesock(int port, int proto) -{ - struct sockaddr_in sin; - int sock, sock_type, val; - - sock_type = (proto == IPPROTO_UDP) ? SOCK_DGRAM : SOCK_STREAM; - sock = socket(AF_INET, sock_type, proto); - if (sock < 0) { - xlog(L_FATAL, "Could not make a socket: %s", - strerror(errno)); - return -1; - } - memset((char *) &sin, 0, sizeof(sin)); - sin.sin_family = AF_INET; - sin.sin_addr.s_addr = htonl(INADDR_ANY); - sin.sin_port = htons(port); - - val = 1; - if (proto == IPPROTO_TCP) - if (setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, - &val, sizeof(val)) < 0) - xlog(L_ERROR, "setsockopt failed: %s", - strerror(errno)); - - if (bind(sock, (struct sockaddr *) &sin, sizeof(sin)) == -1) { - xlog(L_FATAL, "Could not bind name to socket: %s", - strerror(errno)); - return -1; - } - - return sock; -}