diff options
| author | Benny Halevy <bhalevy@panasas.com> | 2010-07-14 15:43:57 -0400 |
|---|---|---|
| committer | Boaz Harrosh <bharrosh@panasas.com> | 2011-05-29 13:54:36 -0400 |
| commit | 8a1636c459cb7a4b32ba4024cd1b2ba21fba6aed (patch) | |
| tree | f9c46f272b98ceb65f997f226d47da68c6fcac6b | |
| parent | cbe8260369c9f88eafa035cd327dc3e02fad528c (diff) | |
pnfs: layoutret_on_setattr
With the objects layout security model, we have object capabilities
that are associated with the layout and we anticipate that the server
will issue a cb_layoutrecall for any setattr that changes security
related attributes (user/group/mode/acl) or truncates the file.
Therefore, the layout is returned before issuing the setattr to avoid
the anticipated cb_layoutrecall.
Signed-off-by: Benny Halevy <bhalevy@panasas.com>
| -rw-r--r-- | fs/nfs/nfs4proc.c | 3 | ||||
| -rw-r--r-- | fs/nfs/objlayout/objio_osd.c | 1 | ||||
| -rw-r--r-- | fs/nfs/pnfs.h | 22 |
3 files changed, 26 insertions, 0 deletions
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 5b4124e4c22f..57340096c737 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c | |||
| @@ -2361,6 +2361,9 @@ nfs4_proc_setattr(struct dentry *dentry, struct nfs_fattr *fattr, | |||
| 2361 | struct nfs4_state *state = NULL; | 2361 | struct nfs4_state *state = NULL; |
| 2362 | int status; | 2362 | int status; |
| 2363 | 2363 | ||
| 2364 | if (pnfs_ld_layoutret_on_setattr(inode)) | ||
| 2365 | pnfs_return_layout(inode); | ||
| 2366 | |||
| 2364 | nfs_fattr_init(fattr); | 2367 | nfs_fattr_init(fattr); |
| 2365 | 2368 | ||
| 2366 | /* Search for an existing open(O_WRITE) file */ | 2369 | /* Search for an existing open(O_WRITE) file */ |
diff --git a/fs/nfs/objlayout/objio_osd.c b/fs/nfs/objlayout/objio_osd.c index cc92d3b3dc3a..4e8de3ec9a63 100644 --- a/fs/nfs/objlayout/objio_osd.c +++ b/fs/nfs/objlayout/objio_osd.c | |||
| @@ -964,6 +964,7 @@ objlayout_pg_test(struct nfs_pageio_descriptor *pgio, struct nfs_page *prev, | |||
| 964 | static struct pnfs_layoutdriver_type objlayout_type = { | 964 | static struct pnfs_layoutdriver_type objlayout_type = { |
| 965 | .id = LAYOUT_OSD2_OBJECTS, | 965 | .id = LAYOUT_OSD2_OBJECTS, |
| 966 | .name = "LAYOUT_OSD2_OBJECTS", | 966 | .name = "LAYOUT_OSD2_OBJECTS", |
| 967 | .flags = PNFS_LAYOUTRET_ON_SETATTR, | ||
| 967 | 968 | ||
| 968 | .alloc_layout_hdr = objlayout_alloc_layout_hdr, | 969 | .alloc_layout_hdr = objlayout_alloc_layout_hdr, |
| 969 | .free_layout_hdr = objlayout_free_layout_hdr, | 970 | .free_layout_hdr = objlayout_free_layout_hdr, |
diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h index c34f7a0e3bc2..af3967a893a1 100644 --- a/fs/nfs/pnfs.h +++ b/fs/nfs/pnfs.h | |||
| @@ -65,6 +65,11 @@ enum { | |||
| 65 | NFS_LAYOUT_DESTROYED, /* no new use of layout allowed */ | 65 | NFS_LAYOUT_DESTROYED, /* no new use of layout allowed */ |
| 66 | }; | 66 | }; |
| 67 | 67 | ||
| 68 | enum layoutdriver_policy_flags { | ||
| 69 | /* Should the pNFS client commit and return the layout upon a setattr */ | ||
| 70 | PNFS_LAYOUTRET_ON_SETATTR = 1 << 0, | ||
| 71 | }; | ||
| 72 | |||
| 68 | struct nfs4_deviceid_node; | 73 | struct nfs4_deviceid_node; |
| 69 | 74 | ||
| 70 | /* Per-layout driver specific registration structure */ | 75 | /* Per-layout driver specific registration structure */ |
| @@ -73,6 +78,7 @@ struct pnfs_layoutdriver_type { | |||
| 73 | const u32 id; | 78 | const u32 id; |
| 74 | const char *name; | 79 | const char *name; |
| 75 | struct module *owner; | 80 | struct module *owner; |
| 81 | unsigned flags; | ||
| 76 | 82 | ||
| 77 | struct pnfs_layout_hdr * (*alloc_layout_hdr) (struct inode *inode, gfp_t gfp_flags); | 83 | struct pnfs_layout_hdr * (*alloc_layout_hdr) (struct inode *inode, gfp_t gfp_flags); |
| 78 | void (*free_layout_hdr) (struct pnfs_layout_hdr *); | 84 | void (*free_layout_hdr) (struct pnfs_layout_hdr *); |
| @@ -258,6 +264,16 @@ static inline void pnfs_clear_request_commit(struct nfs_page *req) | |||
| 258 | put_lseg(req->wb_commit_lseg); | 264 | put_lseg(req->wb_commit_lseg); |
| 259 | } | 265 | } |
| 260 | 266 | ||
| 267 | /* Should the pNFS client commit and return the layout upon a setattr */ | ||
| 268 | static inline bool | ||
| 269 | pnfs_ld_layoutret_on_setattr(struct inode *inode) | ||
| 270 | { | ||
| 271 | if (!pnfs_enabled_sb(NFS_SERVER(inode))) | ||
| 272 | return false; | ||
| 273 | return NFS_SERVER(inode)->pnfs_curr_ld->flags & | ||
| 274 | PNFS_LAYOUTRET_ON_SETATTR; | ||
| 275 | } | ||
| 276 | |||
| 261 | static inline int pnfs_return_layout(struct inode *ino) | 277 | static inline int pnfs_return_layout(struct inode *ino) |
| 262 | { | 278 | { |
| 263 | struct nfs_inode *nfsi = NFS_I(ino); | 279 | struct nfs_inode *nfsi = NFS_I(ino); |
| @@ -317,6 +333,12 @@ static inline int pnfs_return_layout(struct inode *ino) | |||
| 317 | } | 333 | } |
| 318 | 334 | ||
| 319 | static inline bool | 335 | static inline bool |
| 336 | pnfs_ld_layoutret_on_setattr(struct inode *inode) | ||
| 337 | { | ||
| 338 | return false; | ||
| 339 | } | ||
| 340 | |||
| 341 | static inline bool | ||
| 320 | pnfs_roc(struct inode *ino) | 342 | pnfs_roc(struct inode *ino) |
| 321 | { | 343 | { |
| 322 | return false; | 344 | return false; |
