aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4
diff options
context:
space:
mode:
authorJan Kara <jack@suse.cz>2013-05-31 19:39:56 -0400
committerTheodore Ts'o <tytso@mit.edu>2013-05-31 19:39:56 -0400
commit8af8eecc1331dbf5e8c662022272cf667e213da5 (patch)
tree5018c3e8f6af0027254a8e9276503597fffb4fa9 /fs/ext4
parenta60697f411eb365fb09e639e6f183fe33d1eb796 (diff)
ext4: fix overflow when counting used blocks on 32-bit architectures
The arithmetics adding delalloc blocks to the number of used blocks in ext4_getattr() can easily overflow on 32-bit archs as we first multiply number of blocks by blocksize and then divide back by 512. Make the arithmetics more clever and also use proper type (unsigned long long instead of unsigned long). Signed-off-by: Jan Kara <jack@suse.cz> Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Diffstat (limited to 'fs/ext4')
-rw-r--r--fs/ext4/inode.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c
index 0fca5a8c6d3e..38f03dcdc8be 100644
--- a/fs/ext4/inode.c
+++ b/fs/ext4/inode.c
@@ -4702,7 +4702,7 @@ int ext4_getattr(struct vfsmount *mnt, struct dentry *dentry,
4702 struct kstat *stat) 4702 struct kstat *stat)
4703{ 4703{
4704 struct inode *inode; 4704 struct inode *inode;
4705 unsigned long delalloc_blocks; 4705 unsigned long long delalloc_blocks;
4706 4706
4707 inode = dentry->d_inode; 4707 inode = dentry->d_inode;
4708 generic_fillattr(inode, stat); 4708 generic_fillattr(inode, stat);
@@ -4720,7 +4720,7 @@ int ext4_getattr(struct vfsmount *mnt, struct dentry *dentry,
4720 delalloc_blocks = EXT4_C2B(EXT4_SB(inode->i_sb), 4720 delalloc_blocks = EXT4_C2B(EXT4_SB(inode->i_sb),
4721 EXT4_I(inode)->i_reserved_data_blocks); 4721 EXT4_I(inode)->i_reserved_data_blocks);
4722 4722
4723 stat->blocks += (delalloc_blocks << inode->i_sb->s_blocksize_bits)>>9; 4723 stat->blocks += delalloc_blocks << (inode->i_sb->s_blocksize_bits-9);
4724 return 0; 4724 return 0;
4725} 4725}
4726 4726