summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2007-07-28 17:50:45 -0400
committerNeil Brown <neilb@suse.de>2007-07-30 16:12:53 +1000
commit12e990f4b07172c693203ffd1e12d0518cacb9e6 (patch)
treeb6dd92cb0e07f0fd3cae0dd0a451c28856a058ad
parent56a4a153c8559efe6e090e99eaf190d530299de2 (diff)
downloadnfs-utils-12e990f4b07172c693203ffd1e12d0518cacb9e6.tar.gz
nfs-utils-12e990f4b07172c693203ffd1e12d0518cacb9e6.tar.xz
nfs-utils-12e990f4b07172c693203ffd1e12d0518cacb9e6.zip
libnfs.a: move get_socket() function to utils/mount/network.c
Now we can address the real problem: that get_socket() depends on the global variable "verbose" which is only available in the mount command. Move get_socket() into utils/mount/network.c, and make it static. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Neil Brown <neilb@suse.de>
-rw-r--r--support/include/conn.h2
-rw-r--r--support/nfs/conn.c78
-rw-r--r--utils/mount/network.c73
3 files changed, 73 insertions, 80 deletions
diff --git a/support/include/conn.h b/support/include/conn.h
index ee1b686..2b1f07d 100644
--- a/support/include/conn.h
+++ b/support/include/conn.h
@@ -28,7 +28,5 @@ typedef struct {
static const struct timeval TIMEOUT = { 20, 0 };
static const struct timeval RETRY_TIMEOUT = { 3, 0 };
-int get_socket(struct sockaddr_in *, u_int, int, int);
-
#endif /* _CONN_H */
diff --git a/support/nfs/conn.c b/support/nfs/conn.c
index d153aa2..db9185d 100644
--- a/support/nfs/conn.c
+++ b/support/nfs/conn.c
@@ -19,81 +19,3 @@
#include "conn.h"
-#if SIZEOF_SOCKLEN_T - 0 == 0
-#define socklen_t int
-#endif
-
-extern int verbose;
-
-/*
- * Create a socket that is locally bound to a
- * reserve or non-reserve port. For any failures,
- * RPC_ANYSOCK is returned which will cause
- * the RPC code to create the socket instead.
- */
-int get_socket(struct sockaddr_in *saddr, u_int p_prot, int resvp, int conn)
-{
- int so, cc, type;
- struct sockaddr_in laddr;
- socklen_t namelen = sizeof(laddr);
-
- type = (p_prot == IPPROTO_UDP ? SOCK_DGRAM : SOCK_STREAM);
- if ((so = socket (AF_INET, type, p_prot)) < 0) {
- rpc_createerr.cf_stat = RPC_SYSTEMERROR;
- rpc_createerr.cf_error.re_errno = errno;
- if (verbose) {
- fprintf(stderr,
- "mount: Unable to create %s socket: errno %d (%s)\n",
- p_prot == IPPROTO_UDP ? "UDP" : "TCP",
- errno, strerror(errno));
- }
- return RPC_ANYSOCK;
- }
- laddr.sin_family = AF_INET;
- laddr.sin_port = 0;
- laddr.sin_addr.s_addr = htonl(INADDR_ANY);
- if (resvp) {
- if (bindresvport(so, &laddr) < 0) {
- rpc_createerr.cf_stat = RPC_SYSTEMERROR;
- rpc_createerr.cf_error.re_errno = errno;
- if (verbose) {
- fprintf(stderr,
- "mount: Unable to bindresvport %s socket: errno %d (%s)\n",
- p_prot == IPPROTO_UDP ? "UDP" : "TCP",
- errno, strerror(errno));
- }
- close(so);
- return RPC_ANYSOCK;
- }
- } else {
- cc = bind(so, (struct sockaddr *)&laddr, namelen);
- if (cc < 0) {
- rpc_createerr.cf_stat = RPC_SYSTEMERROR;
- rpc_createerr.cf_error.re_errno = errno;
- if (verbose) {
- fprintf(stderr,
- "mount: Unable to bind to %s socket: errno %d (%s)\n",
- p_prot == IPPROTO_UDP ? "UDP" : "TCP",
- errno, strerror(errno));
- }
- close(so);
- return RPC_ANYSOCK;
- }
- }
- if (type == SOCK_STREAM || (conn && type == SOCK_DGRAM)) {
- cc = connect(so, (struct sockaddr *)saddr, namelen);
- if (cc < 0) {
- rpc_createerr.cf_stat = RPC_SYSTEMERROR;
- rpc_createerr.cf_error.re_errno = errno;
- if (verbose) {
- fprintf(stderr,
- "mount: Unable to connect to %s:%d, errno %d (%s)\n",
- inet_ntoa(saddr->sin_addr), ntohs(saddr->sin_port),
- errno, strerror(errno));
- }
- close(so);
- return RPC_ANYSOCK;
- }
- }
- return so;
-}
diff --git a/utils/mount/network.c b/utils/mount/network.c
index a5b0b71..4831990 100644
--- a/utils/mount/network.c
+++ b/utils/mount/network.c
@@ -159,6 +159,79 @@ int nfs_gethostbyname(const char *hostname, struct sockaddr_in *saddr)
}
/*
+ * Create a socket that is locally bound to a reserved or non-reserved
+ * port. For any failures, RPC_ANYSOCK is returned which will cause
+ * the RPC code to create the socket instead.
+ */
+static int get_socket(struct sockaddr_in *saddr, unsigned int p_prot,
+ int resvp, int conn)
+{
+ int so, cc, type;
+ struct sockaddr_in laddr;
+ socklen_t namelen = sizeof(laddr);
+
+ type = (p_prot == IPPROTO_UDP ? SOCK_DGRAM : SOCK_STREAM);
+ if ((so = socket (AF_INET, type, p_prot)) < 0) {
+ rpc_createerr.cf_stat = RPC_SYSTEMERROR;
+ rpc_createerr.cf_error.re_errno = errno;
+ if (verbose) {
+ fprintf(stderr,
+ "mount: Unable to create %s socket: errno %d (%s)\n",
+ p_prot == IPPROTO_UDP ? "UDP" : "TCP",
+ errno, strerror(errno));
+ }
+ return RPC_ANYSOCK;
+ }
+ laddr.sin_family = AF_INET;
+ laddr.sin_port = 0;
+ laddr.sin_addr.s_addr = htonl(INADDR_ANY);
+ if (resvp) {
+ if (bindresvport(so, &laddr) < 0) {
+ rpc_createerr.cf_stat = RPC_SYSTEMERROR;
+ rpc_createerr.cf_error.re_errno = errno;
+ if (verbose) {
+ fprintf(stderr,
+ "mount: Unable to bindresvport %s socket: errno %d (%s)\n",
+ p_prot == IPPROTO_UDP ? "UDP" : "TCP",
+ errno, strerror(errno));
+ }
+ close(so);
+ return RPC_ANYSOCK;
+ }
+ } else {
+ cc = bind(so, (struct sockaddr *)&laddr, namelen);
+ if (cc < 0) {
+ rpc_createerr.cf_stat = RPC_SYSTEMERROR;
+ rpc_createerr.cf_error.re_errno = errno;
+ if (verbose) {
+ fprintf(stderr,
+ "mount: Unable to bind to %s socket: errno %d (%s)\n",
+ p_prot == IPPROTO_UDP ? "UDP" : "TCP",
+ errno, strerror(errno));
+ }
+ close(so);
+ return RPC_ANYSOCK;
+ }
+ }
+ if (type == SOCK_STREAM || (conn && type == SOCK_DGRAM)) {
+ cc = connect(so, (struct sockaddr *)saddr, namelen);
+ if (cc < 0) {
+ rpc_createerr.cf_stat = RPC_SYSTEMERROR;
+ rpc_createerr.cf_error.re_errno = errno;
+ if (verbose) {
+ fprintf(stderr,
+ "mount: Unable to connect to %s:%d, errno %d (%s)\n",
+ inet_ntoa(saddr->sin_addr), ntohs(saddr->sin_port),
+ errno, strerror(errno));
+ }
+ close(so);
+ return RPC_ANYSOCK;
+ }
+ }
+ return so;
+}
+
+/*
* getport() is very similar to pmap_getport() with the exception that
* this version tries to use an ephemeral port, since reserved ports are
* not needed for GETPORT queries. This conserves the very limited