From b2708e37256f76fec0e9922c6d334840dcb2565b Mon Sep 17 00:00:00 2001 From: Christoph Hellwig Date: Wed, 16 Feb 2011 09:34:17 +0100 Subject: [PATCH] --- yaml --- r: 255100 b: refs/heads/master c: bf1a1b31fa3ea24e3a90821d69a5c3da066f7d6c h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/fs/hfsplus/extents.c | 9 ++++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 4859b25be030..58a486fd8d2e 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 2b4f9ca8a575ce6d7ddb59d668e2be250bf86a8f +refs/heads/master: bf1a1b31fa3ea24e3a90821d69a5c3da066f7d6c diff --git a/trunk/fs/hfsplus/extents.c b/trunk/fs/hfsplus/extents.c index b1991a2a08e0..b9c1a4b5ba89 100644 --- a/trunk/fs/hfsplus/extents.c +++ b/trunk/fs/hfsplus/extents.c @@ -209,6 +209,7 @@ int hfsplus_get_block(struct inode *inode, sector_t iblock, struct hfsplus_inode_info *hip = HFSPLUS_I(inode); int res = -EIO; u32 ablock, dblock, mask; + sector_t sector; int was_dirty = 0; int shift; @@ -255,10 +256,12 @@ int hfsplus_get_block(struct inode *inode, sector_t iblock, done: dprint(DBG_EXTENT, "get_block(%lu): %llu - %u\n", inode->i_ino, (long long)iblock, dblock); + mask = (1 << sbi->fs_shift) - 1; - map_bh(bh_result, sb, - (dblock << sbi->fs_shift) + sbi->blockoffset + - (iblock & mask)); + sector = ((sector_t)dblock << sbi->fs_shift) + + sbi->blockoffset + (iblock & mask); + map_bh(bh_result, sb, sector); + if (create) { set_buffer_new(bh_result); hip->phys_size += sb->s_blocksize;