diff options
author | Steven Whitehouse <swhiteho@redhat.com> | 2009-03-31 17:06:27 +0200 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2009-04-15 11:15:38 +0200 |
commit | 5cf32524de745c56e1411d63eccf23fef1709d73 (patch) | |
tree | 300c28954930875a4016d51fa7b7def93c7dc1bd /fs/gfs2 | |
parent | GFS2: Make quotad's waiting interruptible (diff) | |
download | linux-5cf32524de745c56e1411d63eccf23fef1709d73.tar.xz linux-5cf32524de745c56e1411d63eccf23fef1709d73.zip |
GFS2: Fix symlink creation race
In certain cases symlinks can appear to have zero size if a lookup
on the inode occurs within a certain (very short) time after the
symlink has been created. The symlink is correctly created on disk
but appears to have zero size when stat()ed. This patch closes the
race and prevents incorrect sizes appearing.
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Diffstat (limited to 'fs/gfs2')
-rw-r--r-- | fs/gfs2/ops_inode.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/gfs2/ops_inode.c b/fs/gfs2/ops_inode.c index abd5429ae285..1c70fa5168d6 100644 --- a/fs/gfs2/ops_inode.c +++ b/fs/gfs2/ops_inode.c @@ -371,6 +371,7 @@ static int gfs2_symlink(struct inode *dir, struct dentry *dentry, ip = ghs[1].gh_gl->gl_object; ip->i_disksize = size; + i_size_write(inode, size); error = gfs2_meta_inode_buffer(ip, &dibh); |