summaryrefslogtreecommitdiffstats
path: root/fs/affs
diff options
context:
space:
mode:
authorFabian Frederick <fabf@skynet.be>2017-04-15 02:54:36 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2017-04-26 23:54:05 -0400
commitf1bf90724de652efdf493ea877ee050e7e6091c4 (patch)
tree7ffddf20bfec0950cf22cbfd9b1b7fd7512a5ccf /fs/affs
parent4f7d029b9bf009fbee76bb10c0c4351a1870d2f3 (diff)
fs/affs: bugfix: make symbolic links work again
AFFS symbolic links were broken since kernel 2.6.29 Problem was bisected to the following commit ebd09abbd969 ("vfs: ensure page symlinks are NUL-terminated") commit 035146851cfa ("vfs: introduce helper function to safely NUL-terminate symlinks") AFFS wasn't setting inode size when reading symbolic link from disk or creating a new one. Result was zero allocation in pagecache. ln -s file symlink ls -lrt file symlink -> This patch adds inode isize information on inode get and symbolic link addition. Signed-off-by: Fabian Frederick <fabf@skynet.be> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/affs')
-rw-r--r--fs/affs/inode.c1
-rw-r--r--fs/affs/namei.c1
2 files changed, 2 insertions, 0 deletions
diff --git a/fs/affs/inode.c b/fs/affs/inode.c
index abcc59899229..fd4ef3c40e40 100644
--- a/fs/affs/inode.c
+++ b/fs/affs/inode.c
@@ -140,6 +140,7 @@ struct inode *affs_iget(struct super_block *sb, unsigned long ino)
140 inode->i_fop = &affs_file_operations; 140 inode->i_fop = &affs_file_operations;
141 break; 141 break;
142 case ST_SOFTLINK: 142 case ST_SOFTLINK:
143 inode->i_size = strlen((char *)AFFS_HEAD(bh)->table);
143 inode->i_mode |= S_IFLNK; 144 inode->i_mode |= S_IFLNK;
144 inode_nohighmem(inode); 145 inode_nohighmem(inode);
145 inode->i_op = &affs_symlink_inode_operations; 146 inode->i_op = &affs_symlink_inode_operations;
diff --git a/fs/affs/namei.c b/fs/affs/namei.c
index 96dd1d09a273..b02da4d421cc 100644
--- a/fs/affs/namei.c
+++ b/fs/affs/namei.c
@@ -365,6 +365,7 @@ affs_symlink(struct inode *dir, struct dentry *dentry, const char *symname)
365 symname++; 365 symname++;
366 } 366 }
367 *p = 0; 367 *p = 0;
368 inode->i_size = i + 1;
368 mark_buffer_dirty_inode(bh, inode); 369 mark_buffer_dirty_inode(bh, inode);
369 affs_brelse(bh); 370 affs_brelse(bh);
370 mark_inode_dirty(inode); 371 mark_inode_dirty(inode);