lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Tue, 13 Nov 2007 13:32:19 -0500 From: Chuck Lever <chuck.lever@...cle.com> To: nfs@...ts.sourceforge.net Cc: netdev@...r.kernel.org Subject: [PATCH 15/25] NFS: Change nfs_get_client() to take (sockaddr *, len) Adjust arguments and callers of nfs_get_client() to pass a "struct sockaddr *" and length instead of "struct sockaddr_in *" to support non-IPv4 addresses. Signed-off-by: Chuck Lever <chuck.lever@...cle.com> Cc: Aurelien Charbon <aurelien.charbon@....bull.net> --- fs/nfs/client.c | 21 +++++++++++---------- 1 files changed, 11 insertions(+), 10 deletions(-) diff --git a/fs/nfs/client.c b/fs/nfs/client.c index 7b45ed0..f03a742 100644 --- a/fs/nfs/client.c +++ b/fs/nfs/client.c @@ -288,21 +288,21 @@ struct nfs_client *nfs_find_client(const struct sockaddr *addr, * - creates a new record if one doesn't yet exist */ static struct nfs_client *nfs_get_client(const char *hostname, - const struct sockaddr_in *addr, + const struct sockaddr *addr, + size_t addrlen, unsigned int nfsversion) { struct nfs_client *clp, *new = NULL; int error; - dprintk("--> nfs_get_client(%s,"NIPQUAD_FMT":%d,%u)\n", - hostname ?: "", NIPQUAD(addr->sin_addr), - addr->sin_port, nfsversion); + dprintk("--> nfs_get_client(%s,v%u)\n", + hostname ?: "", nfsversion); /* see if the client already exists */ do { spin_lock(&nfs_client_lock); - clp = __nfs_find_client((struct sockaddr *)addr, nfsversion, 1); + clp = __nfs_find_client(addr, nfsversion, 1); if (clp) goto found_client; if (new) @@ -310,9 +310,7 @@ static struct nfs_client *nfs_get_client(const char *hostname, spin_unlock(&nfs_client_lock); - new = nfs_alloc_client(hostname, - (const struct sockaddr *)addr, - sizeof(*addr), nfsversion); + new = nfs_alloc_client(hostname, addr, addrlen, nfsversion); } while (new); return ERR_PTR(-ENOMEM); @@ -588,7 +586,9 @@ static int nfs_init_server(struct nfs_server *server, /* Allocate or find a client reference we can use */ clp = nfs_get_client(data->nfs_server.hostname, - &data->nfs_server.address, nfsvers); + (struct sockaddr *)&data->nfs_server.address, + sizeof(data->nfs_server.address), + nfsvers); if (IS_ERR(clp)) { dprintk("<-- nfs_init_server() = error %ld\n", PTR_ERR(clp)); return PTR_ERR(clp); @@ -925,7 +925,8 @@ static int nfs4_set_client(struct nfs_server *server, dprintk("--> nfs4_set_client()\n"); /* Allocate or find a client reference we can use */ - clp = nfs_get_client(hostname, addr, 4); + clp = nfs_get_client(hostname, (struct sockaddr *)addr, + sizeof(*addr), 4); if (IS_ERR(clp)) { error = PTR_ERR(clp); goto error; - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists