diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2009-05-08 16:05:57 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2009-05-09 10:51:34 -0400 |
commit | 2a32cebd6cbcc43996c3e2d114fa32ba1e71192a (patch) | |
tree | 0ad94849a7bc3e97cd19978005d1898c8bb44b36 /fs/afs | |
parent | f9dbd05bc97d1d4f17c2057612f6a8e4dbd039e0 (diff) |
Fix races around the access to ->s_options
Put generic_show_options read access to s_options under rcu_read_lock,
split save_mount_options() into "we are setting it the first time"
(uses in foo_fill_super()) and "we are relacing and freeing the old one",
synchronize_rcu() before kfree() in the latter.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/afs')
-rw-r--r-- | fs/afs/super.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/afs/super.c b/fs/afs/super.c index 2753f16dd315..76828e5f8a39 100644 --- a/fs/afs/super.c +++ b/fs/afs/super.c | |||
@@ -408,17 +408,17 @@ static int afs_get_sb(struct file_system_type *fs_type, | |||
408 | deactivate_locked_super(sb); | 408 | deactivate_locked_super(sb); |
409 | goto error; | 409 | goto error; |
410 | } | 410 | } |
411 | sb->s_options = new_opts; | 411 | save_mount_options(sb, new_opts); |
412 | sb->s_flags |= MS_ACTIVE; | 412 | sb->s_flags |= MS_ACTIVE; |
413 | } else { | 413 | } else { |
414 | _debug("reuse"); | 414 | _debug("reuse"); |
415 | kfree(new_opts); | ||
416 | ASSERTCMP(sb->s_flags, &, MS_ACTIVE); | 415 | ASSERTCMP(sb->s_flags, &, MS_ACTIVE); |
417 | } | 416 | } |
418 | 417 | ||
419 | simple_set_mnt(mnt, sb); | 418 | simple_set_mnt(mnt, sb); |
420 | afs_put_volume(params.volume); | 419 | afs_put_volume(params.volume); |
421 | afs_put_cell(params.cell); | 420 | afs_put_cell(params.cell); |
421 | kfree(new_opts); | ||
422 | _leave(" = 0 [%p]", sb); | 422 | _leave(" = 0 [%p]", sb); |
423 | return 0; | 423 | return 0; |
424 | 424 | ||