diff options
| author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-23 16:58:40 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-23 16:58:40 -0700 | 
| commit | 9f261e011340bcd22c1dd48b465153bd78caa8c8 (patch) | |
| tree | b1c266ea746a0e8591e6af781aef22854e652ff9 /fs/nfs/nfs3proc.c | |
| parent | a4c12d6c5dde48c69464baf7c703e425ee511433 (diff) | |
| parent | 026ed5c9185dcc4b2df92e98c3d61a01cea19cbf (diff) | |
Merge git://git.linux-nfs.org/pub/linux/nfs-2.6
* git://git.linux-nfs.org/pub/linux/nfs-2.6: (74 commits)
  NFS: unmark NFS direct I/O as experimental
  NFS: add comments clarifying the use of nfs_post_op_update()
  NFSv4: rpc_mkpipe creating socket inodes w/out sk buffers
  NFS: Use SEEK_END instead of hardcoded value
  NFSv4: When mounting with a port=0 argument, substitute port=2049
  NFSv4: Poll more aggressively when handling NFS4ERR_DELAY
  NFSv4: Handle the condition NFS4ERR_FILE_OPEN
  NFSv4: Retry lease recovery if it failed during a synchronous operation.
  NFS: Don't invalidate the symlink we just stuffed into the cache
  NFS: Make read() return an ESTALE if the file has been deleted
  NFSv4: It's perfectly legal for clp to be NULL here....
  NFS: nfs_lookup - don't hash dentry when optimising away the lookup
  SUNRPC: Fix Oops in pmap_getport_done
  SUNRPC: Add refcounting to the struct rpc_xprt
  SUNRPC: Clean up soft task error handling
  SUNRPC: Handle ENETUNREACH, EHOSTUNREACH and EHOSTDOWN socket errors
  SUNRPC: rpc_delay() should not clobber the rpc_task->tk_status
  Fix a referral error Oops
  NFS: NFS_ROOT should use the new rpc_create API
  NFS: Fix up compiler warnings on 64-bit platforms in client.c
  ...
Manually resolved conflict in net/sunrpc/xprtsock.c
Diffstat (limited to 'fs/nfs/nfs3proc.c')
| -rw-r--r-- | fs/nfs/nfs3proc.c | 42 | 
1 files changed, 24 insertions, 18 deletions
| diff --git a/fs/nfs/nfs3proc.c b/fs/nfs/nfs3proc.c index 7143b1f82cea..f8688eaa0001 100644 --- a/fs/nfs/nfs3proc.c +++ b/fs/nfs/nfs3proc.c @@ -81,7 +81,7 @@ do_proc_get_root(struct rpc_clnt *client, struct nfs_fh *fhandle,  }  /* - * Bare-bones access to getattr: this is for nfs_read_super. + * Bare-bones access to getattr: this is for nfs_get_root/nfs_get_sb   */  static int  nfs3_proc_get_root(struct nfs_server *server, struct nfs_fh *fhandle, @@ -90,8 +90,8 @@ nfs3_proc_get_root(struct nfs_server *server, struct nfs_fh *fhandle,  	int	status;  	status = do_proc_get_root(server->client, fhandle, info); -	if (status && server->client_sys != server->client) -		status = do_proc_get_root(server->client_sys, fhandle, info); +	if (status && server->nfs_client->cl_rpcclient != server->client) +		status = do_proc_get_root(server->nfs_client->cl_rpcclient, fhandle, info);  	return status;  } @@ -544,23 +544,23 @@ nfs3_proc_link(struct inode *inode, struct inode *dir, struct qstr *name)  }  static int -nfs3_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path, -		  struct iattr *sattr, struct nfs_fh *fhandle, -		  struct nfs_fattr *fattr) +nfs3_proc_symlink(struct inode *dir, struct dentry *dentry, struct page *page, +		  unsigned int len, struct iattr *sattr)  { -	struct nfs_fattr	dir_attr; +	struct nfs_fh fhandle; +	struct nfs_fattr fattr, dir_attr;  	struct nfs3_symlinkargs	arg = {  		.fromfh		= NFS_FH(dir), -		.fromname	= name->name, -		.fromlen	= name->len, -		.topath		= path->name, -		.tolen		= path->len, +		.fromname	= dentry->d_name.name, +		.fromlen	= dentry->d_name.len, +		.pages		= &page, +		.pathlen	= len,  		.sattr		= sattr  	};  	struct nfs3_diropres	res = {  		.dir_attr	= &dir_attr, -		.fh		= fhandle, -		.fattr		= fattr +		.fh		= &fhandle, +		.fattr		= &fattr  	};  	struct rpc_message msg = {  		.rpc_proc	= &nfs3_procedures[NFS3PROC_SYMLINK], @@ -569,13 +569,19 @@ nfs3_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path,  	};  	int			status; -	if (path->len > NFS3_MAXPATHLEN) +	if (len > NFS3_MAXPATHLEN)  		return -ENAMETOOLONG; -	dprintk("NFS call  symlink %s -> %s\n", name->name, path->name); + +	dprintk("NFS call  symlink %s\n", dentry->d_name.name); +  	nfs_fattr_init(&dir_attr); -	nfs_fattr_init(fattr); +	nfs_fattr_init(&fattr);  	status = rpc_call_sync(NFS_CLIENT(dir), &msg, 0);  	nfs_post_op_update_inode(dir, &dir_attr); +	if (status != 0) +		goto out; +	status = nfs_instantiate(dentry, &fhandle, &fattr); +out:  	dprintk("NFS reply symlink: %d\n", status);  	return status;  } @@ -785,7 +791,7 @@ nfs3_proc_fsinfo(struct nfs_server *server, struct nfs_fh *fhandle,  	dprintk("NFS call  fsinfo\n");  	nfs_fattr_init(info->fattr); -	status = rpc_call_sync(server->client_sys, &msg, 0); +	status = rpc_call_sync(server->nfs_client->cl_rpcclient, &msg, 0);  	dprintk("NFS reply fsinfo: %d\n", status);  	return status;  } @@ -886,7 +892,7 @@ nfs3_proc_lock(struct file *filp, int cmd, struct file_lock *fl)  	return nlmclnt_proc(filp->f_dentry->d_inode, cmd, fl);  } -struct nfs_rpc_ops	nfs_v3_clientops = { +const struct nfs_rpc_ops nfs_v3_clientops = {  	.version	= 3,			/* protocol version */  	.dentry_ops	= &nfs_dentry_operations,  	.dir_inode_ops	= &nfs3_dir_inode_operations, | 
