diff options
| author | Ingo Molnar <mingo@elte.hu> | 2010-08-31 03:45:21 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-08-31 03:45:46 -0400 |
| commit | daab7fc734a53fdeaf844b7c03053118ad1769da (patch) | |
| tree | 575deb3cdcc6dda562acaed6f7c29bc81ae01cf2 /fs/nfs/callback_proc.c | |
| parent | 774ea0bcb27f57b6fd521b3b6c43237782fed4b9 (diff) | |
| parent | 2bfc96a127bc1cc94d26bfaa40159966064f9c8c (diff) | |
Merge commit 'v2.6.36-rc3' into x86/memblock
Conflicts:
arch/x86/kernel/trampoline.c
mm/memblock.c
Merge reason: Resolve the conflicts, update to latest upstream.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'fs/nfs/callback_proc.c')
| -rw-r--r-- | fs/nfs/callback_proc.c | 19 |
1 files changed, 4 insertions, 15 deletions
diff --git a/fs/nfs/callback_proc.c b/fs/nfs/callback_proc.c index a08770a7e857..930d10fecdaf 100644 --- a/fs/nfs/callback_proc.c +++ b/fs/nfs/callback_proc.c | |||
| @@ -37,8 +37,8 @@ __be32 nfs4_callback_getattr(struct cb_getattrargs *args, struct cb_getattrres * | |||
| 37 | if (inode == NULL) | 37 | if (inode == NULL) |
| 38 | goto out_putclient; | 38 | goto out_putclient; |
| 39 | nfsi = NFS_I(inode); | 39 | nfsi = NFS_I(inode); |
| 40 | down_read(&nfsi->rwsem); | 40 | rcu_read_lock(); |
| 41 | delegation = nfsi->delegation; | 41 | delegation = rcu_dereference(nfsi->delegation); |
| 42 | if (delegation == NULL || (delegation->type & FMODE_WRITE) == 0) | 42 | if (delegation == NULL || (delegation->type & FMODE_WRITE) == 0) |
| 43 | goto out_iput; | 43 | goto out_iput; |
| 44 | res->size = i_size_read(inode); | 44 | res->size = i_size_read(inode); |
| @@ -53,7 +53,7 @@ __be32 nfs4_callback_getattr(struct cb_getattrargs *args, struct cb_getattrres * | |||
| 53 | args->bitmap[1]; | 53 | args->bitmap[1]; |
| 54 | res->status = 0; | 54 | res->status = 0; |
| 55 | out_iput: | 55 | out_iput: |
| 56 | up_read(&nfsi->rwsem); | 56 | rcu_read_unlock(); |
| 57 | iput(inode); | 57 | iput(inode); |
| 58 | out_putclient: | 58 | out_putclient: |
| 59 | nfs_put_client(clp); | 59 | nfs_put_client(clp); |
| @@ -62,16 +62,6 @@ out: | |||
| 62 | return res->status; | 62 | return res->status; |
| 63 | } | 63 | } |
| 64 | 64 | ||
| 65 | static int (*nfs_validate_delegation_stateid(struct nfs_client *clp))(struct nfs_delegation *, const nfs4_stateid *) | ||
| 66 | { | ||
| 67 | #if defined(CONFIG_NFS_V4_1) | ||
| 68 | if (clp->cl_minorversion > 0) | ||
| 69 | return nfs41_validate_delegation_stateid; | ||
| 70 | #endif | ||
| 71 | return nfs4_validate_delegation_stateid; | ||
| 72 | } | ||
| 73 | |||
| 74 | |||
| 75 | __be32 nfs4_callback_recall(struct cb_recallargs *args, void *dummy) | 65 | __be32 nfs4_callback_recall(struct cb_recallargs *args, void *dummy) |
| 76 | { | 66 | { |
| 77 | struct nfs_client *clp; | 67 | struct nfs_client *clp; |
| @@ -92,8 +82,7 @@ __be32 nfs4_callback_recall(struct cb_recallargs *args, void *dummy) | |||
| 92 | inode = nfs_delegation_find_inode(clp, &args->fh); | 82 | inode = nfs_delegation_find_inode(clp, &args->fh); |
| 93 | if (inode != NULL) { | 83 | if (inode != NULL) { |
| 94 | /* Set up a helper thread to actually return the delegation */ | 84 | /* Set up a helper thread to actually return the delegation */ |
| 95 | switch (nfs_async_inode_return_delegation(inode, &args->stateid, | 85 | switch (nfs_async_inode_return_delegation(inode, &args->stateid)) { |
| 96 | nfs_validate_delegation_stateid(clp))) { | ||
| 97 | case 0: | 86 | case 0: |
| 98 | res = 0; | 87 | res = 0; |
| 99 | break; | 88 | break; |
