diff options
author | Christoph Hellwig <hch@lst.de> | 2016-10-02 18:46:04 -0400 |
---|---|---|
committer | Dave Chinner <david@fromorbit.com> | 2016-10-02 18:46:04 -0400 |
commit | d5bfccdf38d094f2b15fae8b361d7bd47f2509d6 (patch) | |
tree | 37d47bc6f016d5312faa9ccbd56da082b9835a75 | |
parent | 25f4e70291a309749a93b30ffa58d2eac9f200f8 (diff) |
ext2: fix possible integer truncation in ext2_iomap_begin
For 32-bit architectures we need to cast first_block to u64 before
shifting it left.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reported-by: Jan Kara <jack@suse.cz>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
-rw-r--r-- | fs/ext2/inode.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/ext2/inode.c b/fs/ext2/inode.c index aae5f61f980b..c7dbb4661119 100644 --- a/fs/ext2/inode.c +++ b/fs/ext2/inode.c | |||
@@ -806,7 +806,7 @@ static int ext2_iomap_begin(struct inode *inode, loff_t offset, loff_t length, | |||
806 | 806 | ||
807 | iomap->flags = 0; | 807 | iomap->flags = 0; |
808 | iomap->bdev = inode->i_sb->s_bdev; | 808 | iomap->bdev = inode->i_sb->s_bdev; |
809 | iomap->offset = first_block << blkbits; | 809 | iomap->offset = (u64)first_block << blkbits; |
810 | 810 | ||
811 | if (ret == 0) { | 811 | if (ret == 0) { |
812 | iomap->type = IOMAP_HOLE; | 812 | iomap->type = IOMAP_HOLE; |