From: Theodore Ts'o Date: Wed, 6 Jul 2011 00:35:46 +0000 (-0400) Subject: libext2fs: fix 64-bit support in ext2fs_bmap2() X-Git-Tag: v1.42-WIP-0916~48 X-Git-Url: https://git.whamcloud.com/?a=commitdiff_plain;h=062cc472e6cae60a1fa43976bcc6ff39f8351ccb;p=tools%2Fe2fsprogs.git libext2fs: fix 64-bit support in ext2fs_bmap2() Signed-off-by: "Theodore Ts'o" --- diff --git a/lib/ext2fs/bmap.c b/lib/ext2fs/bmap.c index fbcb375..90d9e72 100644 --- a/lib/ext2fs/bmap.c +++ b/lib/ext2fs/bmap.c @@ -135,6 +135,7 @@ errcode_t ext2fs_bmap2(ext2_filsys fs, ext2_ino_t ino, struct ext2_inode *inode, { struct ext2_inode inode_buf; ext2_extent_handle_t handle = 0; + blk64_t blk64; blk_t addr_per_block; blk_t b, blk32; char *buf = 0; @@ -186,11 +187,16 @@ errcode_t ext2fs_bmap2(ext2_filsys fs, ext2_ino_t ino, struct ext2_inode *inode, } got_block: if ((*phys_blk == 0) && (bmap_flags & BMAP_ALLOC)) { - retval = ext2fs_alloc_block(fs, b, block_buf, &b); + retval = ext2fs_bmap2(fs, ino, inode, block_buf, + 0, block-1, 0, &blk64); + if (retval) + blk64 = 0; + retval = ext2fs_alloc_block2(fs, blk64, block_buf, + &blk64); if (retval) goto done; retval = ext2fs_extent_set_bmap(handle, block, - (blk64_t) b, 0); + blk64, 0); if (retval) goto done; /* Update inode after setting extent */ @@ -198,7 +204,7 @@ errcode_t ext2fs_bmap2(ext2_filsys fs, ext2_ino_t ino, struct ext2_inode *inode, if (retval) return retval; blocks_alloc++; - *phys_blk = b; + *phys_blk = blk64; } retval = 0; goto done;