summaryrefslogtreecommitdiff
path: root/fs/btrfs/inode.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2007-09-20 14:14:42 -0400
committerChris Mason <chris.mason@oracle.com>2008-09-25 11:03:56 -0400
commit50b78c24d594e6985f36a9a8d8e2fb74e1664e90 (patch)
tree531ae4659fc4b5a6fb4f15c0349210afdb26ecbb /fs/btrfs/inode.c
parentb3cfa35a493866cffd00952438b6c77364d42d3c (diff)
downloadlwn-50b78c24d594e6985f36a9a8d8e2fb74e1664e90.tar.gz
lwn-50b78c24d594e6985f36a9a8d8e2fb74e1664e90.zip
btrfs_get_extent should treat inline extents as though they hold a whole block
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/inode.c')
-rw-r--r--fs/btrfs/inode.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index 0df325f89d62..b03d40a907ca 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -1505,13 +1505,13 @@ again:
size = btrfs_file_extent_inline_len(leaf->items +
path->slots[0]);
- extent_end = extent_start + size;
+ extent_end = extent_start | ((u64)root->blocksize - 1);
if (start < extent_start || start >= extent_end) {
em->start = start;
if (start < extent_start) {
if (end < extent_start)
goto not_found;
- em->end = extent_end - 1;
+ em->end = extent_end;
} else {
em->end = end;
}
@@ -1520,17 +1520,19 @@ again:
em->block_start = EXTENT_MAP_INLINE;
em->block_end = EXTENT_MAP_INLINE;
em->start = extent_start;
- em->end = extent_end - 1;
+ em->end = extent_end;
if (!page) {
goto insert;
}
ptr = btrfs_file_extent_inline_start(item);
map = kmap(page);
memcpy(map + page_offset, ptr, size);
- flush_dcache_page(result->b_page);
+ memset(map + page_offset + size, 0,
+ root->blocksize - (page_offset + size));
+ flush_dcache_page(page);
kunmap(page);
set_extent_uptodate(em_tree, extent_start,
- extent_end - 1, GFP_NOFS);
+ extent_end, GFP_NOFS);
goto insert;
} else {
printk("unkknown found_type %d\n", found_type);