diff options
| author | Linus Torvalds <[email protected]> | 2008-01-30 19:54:24 +1100 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2008-01-30 19:54:24 +1100 | 
| commit | 85004cc367abc000aa36c0d0e270ab609a68b0cb (patch) | |
| tree | 5739aae778d67b6d119fe5c668313fc2823e9836 /fs/nfs/idmap.c | |
| parent | 149a051f82d2b3860fe32fa182dbc83a66274894 (diff) | |
| parent | 3fbd67ad61f6d5a09ea717b56c50bc5c3d8042a8 (diff) | |
Merge git://git.linux-nfs.org/pub/linux/nfs-2.6
* git://git.linux-nfs.org/pub/linux/nfs-2.6: (118 commits)
  NFSv4: Iterate through all nfs_clients when the server recalls a delegation
  NFSv4: Deal more correctly with duplicate delegations
  NFS: Fix a potential race between umount and nfs_access_cache_shrinker()
  NFS: Add an asynchronous delegreturn operation for use in nfs_clear_inode
  nfs: convert NFS_*(inode) helpers to static inline
  nfs: obliterate NFS_FLAGS macro
  NFS: Address memory leaks in the NFS client mount option parser
  nfs4: allow nfsv4 acls on non-regular-files
  NFS: Optimise away the sigmask code in aio/dio reads and writes
  SUNRPC: Don't bother changing the sigmask for asynchronous RPC calls
  SUNRPC: rpcb_getport_sync() passes incorrect address size to rpc_create()
  SUNRPC: Clean up block comment preceding rpcb_getport_sync()
  SUNRPC: Use appropriate argument types in rpcb client
  SUNRPC: rpcb_getport_sync() should use built-in hostname generator
  SUNRPC: Clean up functions that free address_strings array
  NFS: NFS version number is unsigned
  NLM: Fix a bogus 'return' in nlmclnt_rpc_release
  NLM: Introduce an arguments structure for nlmclnt_init()
  NLM/NFS: Use cached nlm_host when calling nlmclnt_proc()
  NFS: Invoke nlmclnt_init during NFS mount processing
  ...
Diffstat (limited to 'fs/nfs/idmap.c')
| -rw-r--r-- | fs/nfs/idmap.c | 99 | 
1 files changed, 49 insertions, 50 deletions
| diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c index d11eb055265c..8ae5dba2d4e5 100644 --- a/fs/nfs/idmap.c +++ b/fs/nfs/idmap.c @@ -72,39 +72,39 @@ module_param_call(idmap_cache_timeout, param_set_idmap_timeout, param_get_int,  		 &nfs_idmap_cache_timeout, 0644);  struct idmap_hashent { -	unsigned long ih_expires; -	__u32 ih_id; -	int ih_namelen; -	char ih_name[IDMAP_NAMESZ]; +	unsigned long		ih_expires; +	__u32			ih_id; +	size_t			ih_namelen; +	char			ih_name[IDMAP_NAMESZ];  };  struct idmap_hashtable { -	__u8 h_type; -	struct idmap_hashent h_entries[IDMAP_HASH_SZ]; +	__u8			h_type; +	struct idmap_hashent	h_entries[IDMAP_HASH_SZ];  };  struct idmap { -	struct dentry        *idmap_dentry; -	wait_queue_head_t     idmap_wq; -	struct idmap_msg      idmap_im; -	struct mutex          idmap_lock;    /* Serializes upcalls */ -	struct mutex          idmap_im_lock; /* Protects the hashtable */ -	struct idmap_hashtable idmap_user_hash; -	struct idmap_hashtable idmap_group_hash; +	struct dentry		*idmap_dentry; +	wait_queue_head_t	idmap_wq; +	struct idmap_msg	idmap_im; +	struct mutex		idmap_lock;	/* Serializes upcalls */ +	struct mutex		idmap_im_lock;	/* Protects the hashtable */ +	struct idmap_hashtable	idmap_user_hash; +	struct idmap_hashtable	idmap_group_hash;  }; -static ssize_t   idmap_pipe_upcall(struct file *, struct rpc_pipe_msg *, -		     char __user *, size_t); -static ssize_t   idmap_pipe_downcall(struct file *, const char __user *, -		     size_t); -static void      idmap_pipe_destroy_msg(struct rpc_pipe_msg *); +static ssize_t idmap_pipe_upcall(struct file *, struct rpc_pipe_msg *, +				 char __user *, size_t); +static ssize_t idmap_pipe_downcall(struct file *, const char __user *, +				   size_t); +static void idmap_pipe_destroy_msg(struct rpc_pipe_msg *);  static unsigned int fnvhash32(const void *, size_t);  static struct rpc_pipe_ops idmap_upcall_ops = { -        .upcall         = idmap_pipe_upcall, -        .downcall       = idmap_pipe_downcall, -        .destroy_msg    = idmap_pipe_destroy_msg, +	.upcall		= idmap_pipe_upcall, +	.downcall	= idmap_pipe_downcall, +	.destroy_msg	= idmap_pipe_destroy_msg,  };  int @@ -115,19 +115,20 @@ nfs_idmap_new(struct nfs_client *clp)  	BUG_ON(clp->cl_idmap != NULL); -        if ((idmap = kzalloc(sizeof(*idmap), GFP_KERNEL)) == NULL) -                return -ENOMEM; +	idmap = kzalloc(sizeof(*idmap), GFP_KERNEL); +	if (idmap == NULL) +		return -ENOMEM; -        idmap->idmap_dentry = rpc_mkpipe(clp->cl_rpcclient->cl_dentry, "idmap", -	    idmap, &idmap_upcall_ops, 0); -        if (IS_ERR(idmap->idmap_dentry)) { +	idmap->idmap_dentry = rpc_mkpipe(clp->cl_rpcclient->cl_dentry, "idmap", +					 idmap, &idmap_upcall_ops, 0); +	if (IS_ERR(idmap->idmap_dentry)) {  		error = PTR_ERR(idmap->idmap_dentry);  		kfree(idmap);  		return error;  	} -        mutex_init(&idmap->idmap_lock); -        mutex_init(&idmap->idmap_im_lock); +	mutex_init(&idmap->idmap_lock); +	mutex_init(&idmap->idmap_im_lock);  	init_waitqueue_head(&idmap->idmap_wq);  	idmap->idmap_user_hash.h_type = IDMAP_TYPE_USER;  	idmap->idmap_group_hash.h_type = IDMAP_TYPE_GROUP; @@ -192,7 +193,7 @@ idmap_lookup_id(struct idmap_hashtable *h, __u32 id)   * pretty trivial.   */  static inline struct idmap_hashent * -idmap_alloc_name(struct idmap_hashtable *h, char *name, unsigned len) +idmap_alloc_name(struct idmap_hashtable *h, char *name, size_t len)  {  	return idmap_name_hash(h, name, len);  } @@ -285,7 +286,7 @@ nfs_idmap_id(struct idmap *idmap, struct idmap_hashtable *h,  	memset(im, 0, sizeof(*im));  	mutex_unlock(&idmap->idmap_im_lock);  	mutex_unlock(&idmap->idmap_lock); -	return (ret); +	return ret;  }  /* @@ -354,42 +355,40 @@ nfs_idmap_name(struct idmap *idmap, struct idmap_hashtable *h,  /* RPC pipefs upcall/downcall routines */  static ssize_t  idmap_pipe_upcall(struct file *filp, struct rpc_pipe_msg *msg, -    char __user *dst, size_t buflen) +		  char __user *dst, size_t buflen)  { -        char *data = (char *)msg->data + msg->copied; -        ssize_t mlen = msg->len - msg->copied; -        ssize_t left; - -        if (mlen > buflen) -                mlen = buflen; - -        left = copy_to_user(dst, data, mlen); -	if (left < 0) { -		msg->errno = left; -		return left; +	char *data = (char *)msg->data + msg->copied; +	size_t mlen = min(msg->len, buflen); +	unsigned long left; + +	left = copy_to_user(dst, data, mlen); +	if (left == mlen) { +		msg->errno = -EFAULT; +		return -EFAULT;  	} +  	mlen -= left;  	msg->copied += mlen;  	msg->errno = 0; -        return mlen; +	return mlen;  }  static ssize_t  idmap_pipe_downcall(struct file *filp, const char __user *src, size_t mlen)  { -        struct rpc_inode *rpci = RPC_I(filp->f_path.dentry->d_inode); +	struct rpc_inode *rpci = RPC_I(filp->f_path.dentry->d_inode);  	struct idmap *idmap = (struct idmap *)rpci->private;  	struct idmap_msg im_in, *im = &idmap->idmap_im;  	struct idmap_hashtable *h;  	struct idmap_hashent *he = NULL; -	int namelen_in; +	size_t namelen_in;  	int ret; -        if (mlen != sizeof(im_in)) -                return (-ENOSPC); +	if (mlen != sizeof(im_in)) +		return -ENOSPC; -        if (copy_from_user(&im_in, src, mlen) != 0) -		return (-EFAULT); +	if (copy_from_user(&im_in, src, mlen) != 0) +		return -EFAULT;  	mutex_lock(&idmap->idmap_im_lock); @@ -487,7 +486,7 @@ static unsigned int fnvhash32(const void *buf, size_t buflen)  		hash ^= (unsigned int)*p;  	} -	return (hash); +	return hash;  }  int nfs_map_name_to_uid(struct nfs_client *clp, const char *name, size_t namelen, __u32 *uid) |