summaryrefslogtreecommitdiffstats
path: root/fs
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
parentf4b9aa8d3b877d0a6044a6d6d9a44b29cab9e265 (diff)
downloadkernel-crypto-9773a788681db1f5c2701b7433737fdca61a14ba.tar.gz
kernel-crypto-9773a788681db1f5c2701b7433737fdca61a14ba.tar.xz
kernel-crypto-9773a788681db1f5c2701b7433737fdca61a14ba.zip
Btrfs: byte offsets for file keys
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/ctree.h2
-rw-r--r--fs/btrfs/file-item.c5
-rw-r--r--fs/btrfs/super.c7
3 files changed, 9 insertions, 5 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h
index c3fa12a6b59..1897f3a65b4 100644
--- a/fs/btrfs/ctree.h
+++ b/fs/btrfs/ctree.h
@@ -899,5 +899,5 @@ int btrfs_alloc_file_extent(struct btrfs_trans_handle *trans,
int btrfs_lookup_file_extent(struct btrfs_trans_handle *trans,
struct btrfs_root *root,
struct btrfs_path *path, u64 objectid,
- u64 blocknr, u64 num_blocks, int mod);
+ u64 blocknr, int mod);
#endif
diff --git a/fs/btrfs/file-item.c b/fs/btrfs/file-item.c
index 09de270c5a5..5230a44cb19 100644
--- a/fs/btrfs/file-item.c
+++ b/fs/btrfs/file-item.c
@@ -26,6 +26,7 @@ int btrfs_alloc_file_extent(struct btrfs_trans_handle *trans,
ret = btrfs_insert_empty_item(trans, root, &path, &file_key,
sizeof(*item));
+ BUG_ON(ret);
item = btrfs_item_ptr(btrfs_buffer_leaf(path.nodes[0]), path.slots[0],
struct btrfs_file_extent_item);
btrfs_set_file_extent_disk_blocknr(item, ins.objectid);
@@ -42,7 +43,7 @@ int btrfs_alloc_file_extent(struct btrfs_trans_handle *trans,
int btrfs_lookup_file_extent(struct btrfs_trans_handle *trans,
struct btrfs_root *root,
struct btrfs_path *path, u64 objectid,
- u64 blocknr, u64 num_blocks, int mod)
+ u64 offset, int mod)
{
int ret;
struct btrfs_key file_key;
@@ -50,7 +51,7 @@ int btrfs_lookup_file_extent(struct btrfs_trans_handle *trans,
int cow = mod != 0;
file_key.objectid = objectid;
- file_key.offset = blocknr;
+ file_key.offset = offset;
file_key.flags = 0;
btrfs_set_key_type(&file_key, BTRFS_EXTENT_DATA_KEY);
ret = btrfs_search_slot(trans, root, &file_key, path, ins_len, cow);
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,
ret = btrfs_lookup_file_extent(trans, root, &path,
- inode->i_ino, iblock, 1, 0);
+ inode->i_ino,
+ iblock << inode->i_blkbits, 0);
if (ret < 0) {
btrfs_release_path(root, &path);
err = ret;
@@ -737,6 +738,7 @@ static int btrfs_get_block(struct inode *inode, sector_t iblock,
}
extent_start = btrfs_disk_key_offset(&leaf->items[path.slots[0]].key);
+ extent_start = extent_start >> inode->i_blkbits;
extent_start += btrfs_file_extent_offset(item);
extent_end = extent_start + btrfs_file_extent_num_blocks(item);
btrfs_release_path(root, &path);
@@ -751,7 +753,8 @@ allocate:
err = 0;
goto out;
}
- ret = btrfs_alloc_file_extent(trans, root, objectid, iblock,
+ ret = btrfs_alloc_file_extent(trans, root, objectid,
+ iblock << inode->i_blkbits,
1, extent_end, &blocknr);
if (ret) {
err = ret;