diff options
author | Steven Whitehouse <swhiteho@redhat.com> | 2009-03-31 16:06:27 +0100 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2009-04-15 10:15:38 +0100 |
commit | 5cf32524de745c56e1411d63eccf23fef1709d73 (patch) | |
tree | 300c28954930875a4016d51fa7b7def93c7dc1bd | |
parent | 7fa5d20d1a5e60ef7e453993b67b26c87dc09f07 (diff) | |
download | op-kernel-dev-5cf32524de745c56e1411d63eccf23fef1709d73.zip op-kernel-dev-5cf32524de745c56e1411d63eccf23fef1709d73.tar.gz |
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>
-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 abd5429..1c70fa5 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); |