aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/super.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2007-03-27 11:26:26 -0400
committerDavid Woodhouse <dwmw2@hera.kernel.org>2007-03-27 11:26:26 -0400
commit9773a788681db1f5c2701b7433737fdca61a14ba (patch)
tree9d5f79f7a0e3b0f5e89509b42a3d8134364bed32 /fs/btrfs/super.c
parentf4b9aa8d3b877d0a6044a6d6d9a44b29cab9e265 (diff)
Btrfs: byte offsets for file keys
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/super.c')
-rw-r--r--fs/btrfs/super.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index fd3d9d616ff..f2f08189903 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -697,7 +697,8 @@ static int btrfs_get_block(struct inode *inode, sector_t iblock,
697 697
698 698
699 ret = btrfs_lookup_file_extent(trans, root, &path, 699 ret = btrfs_lookup_file_extent(trans, root, &path,
700 inode->i_ino, iblock, 1, 0); 700 inode->i_ino,
701 iblock << inode->i_blkbits, 0);
701 if (ret < 0) { 702 if (ret < 0) {
702 btrfs_release_path(root, &path); 703 btrfs_release_path(root, &path);
703 err = ret; 704 err = ret;
@@ -737,6 +738,7 @@ static int btrfs_get_block(struct inode *inode, sector_t iblock,
737 } 738 }
738 739
739 extent_start = btrfs_disk_key_offset(&leaf->items[path.slots[0]].key); 740 extent_start = btrfs_disk_key_offset(&leaf->items[path.slots[0]].key);
741 extent_start = extent_start >> inode->i_blkbits;
740 extent_start += btrfs_file_extent_offset(item); 742 extent_start += btrfs_file_extent_offset(item);
741 extent_end = extent_start + btrfs_file_extent_num_blocks(item); 743 extent_end = extent_start + btrfs_file_extent_num_blocks(item);
742 btrfs_release_path(root, &path); 744 btrfs_release_path(root, &path);
@@ -751,7 +753,8 @@ allocate:
751 err = 0; 753 err = 0;
752 goto out; 754 goto out;
753 } 755 }
754 ret = btrfs_alloc_file_extent(trans, root, objectid, iblock, 756 ret = btrfs_alloc_file_extent(trans, root, objectid,
757 iblock << inode->i_blkbits,
755 1, extent_end, &blocknr); 758 1, extent_end, &blocknr);
756 if (ret) { 759 if (ret) {
757 err = ret; 760 err = ret;