diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-04-01 13:58:42 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-04-01 13:58:42 -0400 |
| commit | 4fe70410d9a219dabb47328effccae7e7f2a6e26 (patch) | |
| tree | 7f36d6cd27333fa28447f06ce37a6fecceb42955 /fs/nfs/callback.c | |
| parent | 395d73413c5656c6d7706ae91dcb441f9b7e3074 (diff) | |
| parent | cc85906110e26fe8537c3bdbc08a74ae8110030b (diff) | |
Merge branch 'for-linus' of git://git.linux-nfs.org/projects/trondmy/nfs-2.6
* 'for-linus' of git://git.linux-nfs.org/projects/trondmy/nfs-2.6: (58 commits)
SUNRPC: Ensure IPV6_V6ONLY is set on the socket before binding to a port
NSM: Fix unaligned accesses in nsm_init_private()
NFS: Simplify logic to compare socket addresses in client.c
NFS: Start PF_INET6 callback listener only if IPv6 support is available
lockd: Start PF_INET6 listener only if IPv6 support is available
SUNRPC: Remove CONFIG_SUNRPC_REGISTER_V4
SUNRPC: rpcb_register() should handle errors silently
SUNRPC: Simplify kernel RPC service registration
SUNRPC: Simplify svc_unregister()
SUNRPC: Allow callers to pass rpcb_v4_register a NULL address
SUNRPC: rpcbind actually interprets r_owner string
SUNRPC: Clean up address type casts in rpcb_v4_register()
SUNRPC: Don't return EPROTONOSUPPORT in svc_register()'s helpers
SUNRPC: Use IPv4 loopback for registering AF_INET6 kernel RPC services
SUNRPC: Set IPV6ONLY flag on PF_INET6 RPC listener sockets
NFS: Revert creation of IPv6 listeners for lockd and NFSv4 callbacks
SUNRPC: Remove @family argument from svc_create() and svc_create_pooled()
SUNRPC: Change svc_create_xprt() to take a @family argument
SUNRPC: svc_setup_socket() gets protocol family from socket
SUNRPC: Pass a family argument to svc_register()
...
Diffstat (limited to 'fs/nfs/callback.c')
| -rw-r--r-- | fs/nfs/callback.c | 31 |
1 files changed, 16 insertions, 15 deletions
diff --git a/fs/nfs/callback.c b/fs/nfs/callback.c index 3e634f2a1083..a886e692ddd0 100644 --- a/fs/nfs/callback.c +++ b/fs/nfs/callback.c | |||
| @@ -38,19 +38,10 @@ static struct svc_program nfs4_callback_program; | |||
| 38 | 38 | ||
| 39 | unsigned int nfs_callback_set_tcpport; | 39 | unsigned int nfs_callback_set_tcpport; |
| 40 | unsigned short nfs_callback_tcpport; | 40 | unsigned short nfs_callback_tcpport; |
| 41 | unsigned short nfs_callback_tcpport6; | ||
| 41 | static const int nfs_set_port_min = 0; | 42 | static const int nfs_set_port_min = 0; |
| 42 | static const int nfs_set_port_max = 65535; | 43 | static const int nfs_set_port_max = 65535; |
| 43 | 44 | ||
| 44 | /* | ||
| 45 | * If the kernel has IPv6 support available, always listen for | ||
| 46 | * both AF_INET and AF_INET6 requests. | ||
| 47 | */ | ||
| 48 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) | ||
| 49 | static const sa_family_t nfs_callback_family = AF_INET6; | ||
| 50 | #else | ||
| 51 | static const sa_family_t nfs_callback_family = AF_INET; | ||
| 52 | #endif | ||
| 53 | |||
| 54 | static int param_set_port(const char *val, struct kernel_param *kp) | 45 | static int param_set_port(const char *val, struct kernel_param *kp) |
| 55 | { | 46 | { |
| 56 | char *endp; | 47 | char *endp; |
| @@ -116,19 +107,29 @@ int nfs_callback_up(void) | |||
| 116 | mutex_lock(&nfs_callback_mutex); | 107 | mutex_lock(&nfs_callback_mutex); |
| 117 | if (nfs_callback_info.users++ || nfs_callback_info.task != NULL) | 108 | if (nfs_callback_info.users++ || nfs_callback_info.task != NULL) |
| 118 | goto out; | 109 | goto out; |
| 119 | serv = svc_create(&nfs4_callback_program, NFS4_CALLBACK_BUFSIZE, | 110 | serv = svc_create(&nfs4_callback_program, NFS4_CALLBACK_BUFSIZE, NULL); |
| 120 | nfs_callback_family, NULL); | ||
| 121 | ret = -ENOMEM; | 111 | ret = -ENOMEM; |
| 122 | if (!serv) | 112 | if (!serv) |
| 123 | goto out_err; | 113 | goto out_err; |
| 124 | 114 | ||
| 125 | ret = svc_create_xprt(serv, "tcp", nfs_callback_set_tcpport, | 115 | ret = svc_create_xprt(serv, "tcp", PF_INET, |
| 126 | SVC_SOCK_ANONYMOUS); | 116 | nfs_callback_set_tcpport, SVC_SOCK_ANONYMOUS); |
| 127 | if (ret <= 0) | 117 | if (ret <= 0) |
| 128 | goto out_err; | 118 | goto out_err; |
| 129 | nfs_callback_tcpport = ret; | 119 | nfs_callback_tcpport = ret; |
| 130 | dprintk("NFS: Callback listener port = %u (af %u)\n", | 120 | dprintk("NFS: Callback listener port = %u (af %u)\n", |
| 131 | nfs_callback_tcpport, nfs_callback_family); | 121 | nfs_callback_tcpport, PF_INET); |
| 122 | |||
| 123 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) | ||
| 124 | ret = svc_create_xprt(serv, "tcp", PF_INET6, | ||
| 125 | nfs_callback_set_tcpport, SVC_SOCK_ANONYMOUS); | ||
| 126 | if (ret > 0) { | ||
| 127 | nfs_callback_tcpport6 = ret; | ||
| 128 | dprintk("NFS: Callback listener port = %u (af %u)\n", | ||
| 129 | nfs_callback_tcpport6, PF_INET6); | ||
| 130 | } else if (ret != -EAFNOSUPPORT) | ||
| 131 | goto out_err; | ||
| 132 | #endif /* defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) */ | ||
| 132 | 133 | ||
| 133 | nfs_callback_info.rqst = svc_prepare_thread(serv, &serv->sv_pools[0]); | 134 | nfs_callback_info.rqst = svc_prepare_thread(serv, &serv->sv_pools[0]); |
| 134 | if (IS_ERR(nfs_callback_info.rqst)) { | 135 | if (IS_ERR(nfs_callback_info.rqst)) { |
