mirror of
https://github.com/adulau/aha.git
synced 2025-01-01 05:36:24 +00:00
Btrfs: Add back file data checksumming
Signed-off-by: Chris Mason <chris.mason@oracle.com>
This commit is contained in:
parent
cf786e79e3
commit
ff79f8190b
6 changed files with 26 additions and 19 deletions
|
@ -594,6 +594,7 @@ struct btrfs_root *open_ctree(struct super_block *sb)
|
||||||
tree_root->nodesize = nodesize;
|
tree_root->nodesize = nodesize;
|
||||||
tree_root->leafsize = leafsize;
|
tree_root->leafsize = leafsize;
|
||||||
tree_root->sectorsize = sectorsize;
|
tree_root->sectorsize = sectorsize;
|
||||||
|
sb_set_blocksize(sb, sectorsize);
|
||||||
|
|
||||||
i_size_write(fs_info->btree_inode,
|
i_size_write(fs_info->btree_inode,
|
||||||
btrfs_super_total_bytes(disk_super));
|
btrfs_super_total_bytes(disk_super));
|
||||||
|
|
|
@ -58,4 +58,6 @@ int btrfs_buffer_defrag_done(struct extent_buffer *buf);
|
||||||
int btrfs_clear_buffer_defrag(struct extent_buffer *buf);
|
int btrfs_clear_buffer_defrag(struct extent_buffer *buf);
|
||||||
int btrfs_clear_buffer_defrag_done(struct extent_buffer *buf);
|
int btrfs_clear_buffer_defrag_done(struct extent_buffer *buf);
|
||||||
int btrfs_read_buffer(struct extent_buffer *buf);
|
int btrfs_read_buffer(struct extent_buffer *buf);
|
||||||
|
u32 btrfs_csum_data(struct btrfs_root *root, char *data, u32 seed, size_t len);
|
||||||
|
void btrfs_csum_final(u32 crc, char *result);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2031,6 +2031,7 @@ struct extent_buffer *alloc_extent_buffer(struct extent_map_tree *tree,
|
||||||
i = 1;
|
i = 1;
|
||||||
index++;
|
index++;
|
||||||
page_cache_get(page0);
|
page_cache_get(page0);
|
||||||
|
mark_page_accessed(page0);
|
||||||
set_page_extent_mapped(page0);
|
set_page_extent_mapped(page0);
|
||||||
set_page_private(page0, EXTENT_PAGE_PRIVATE_FIRST_PAGE |
|
set_page_private(page0, EXTENT_PAGE_PRIVATE_FIRST_PAGE |
|
||||||
len << 2);
|
len << 2);
|
||||||
|
@ -2049,6 +2050,7 @@ struct extent_buffer *alloc_extent_buffer(struct extent_map_tree *tree,
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
set_page_extent_mapped(p);
|
set_page_extent_mapped(p);
|
||||||
|
mark_page_accessed(p);
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
eb->first_page = p;
|
eb->first_page = p;
|
||||||
set_page_private(p, EXTENT_PAGE_PRIVATE_FIRST_PAGE |
|
set_page_private(p, EXTENT_PAGE_PRIVATE_FIRST_PAGE |
|
||||||
|
@ -2099,6 +2101,7 @@ struct extent_buffer *find_extent_buffer(struct extent_map_tree *tree,
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
set_page_extent_mapped(p);
|
set_page_extent_mapped(p);
|
||||||
|
mark_page_accessed(p);
|
||||||
|
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
eb->first_page = p;
|
eb->first_page = p;
|
||||||
|
|
|
@ -136,27 +136,27 @@ int btrfs_csum_file_block(struct btrfs_trans_handle *trans,
|
||||||
u64 objectid, u64 offset,
|
u64 objectid, u64 offset,
|
||||||
char *data, size_t len)
|
char *data, size_t len)
|
||||||
{
|
{
|
||||||
return 0;
|
|
||||||
#if 0
|
|
||||||
int ret;
|
int ret;
|
||||||
struct btrfs_key file_key;
|
struct btrfs_key file_key;
|
||||||
struct btrfs_key found_key;
|
struct btrfs_key found_key;
|
||||||
struct btrfs_path *path;
|
struct btrfs_path *path;
|
||||||
struct btrfs_csum_item *item;
|
struct btrfs_csum_item *item;
|
||||||
struct extent_buffer *leaf;
|
struct extent_buffer *leaf = NULL;
|
||||||
u64 csum_offset;
|
u64 csum_offset;
|
||||||
|
u32 csum_result = ~(u32)0;
|
||||||
|
|
||||||
path = btrfs_alloc_path();
|
path = btrfs_alloc_path();
|
||||||
BUG_ON(!path);
|
BUG_ON(!path);
|
||||||
|
|
||||||
file_key.objectid = objectid;
|
file_key.objectid = objectid;
|
||||||
file_key.offset = offset;
|
file_key.offset = offset;
|
||||||
file_key.flags = 0;
|
|
||||||
btrfs_set_key_type(&file_key, BTRFS_CSUM_ITEM_KEY);
|
btrfs_set_key_type(&file_key, BTRFS_CSUM_ITEM_KEY);
|
||||||
|
|
||||||
item = btrfs_lookup_csum(trans, root, path, objectid, offset, 1);
|
item = btrfs_lookup_csum(trans, root, path, objectid, offset, 1);
|
||||||
if (!IS_ERR(item))
|
if (!IS_ERR(item)) {
|
||||||
|
leaf = path->nodes[0];
|
||||||
goto found;
|
goto found;
|
||||||
|
}
|
||||||
ret = PTR_ERR(item);
|
ret = PTR_ERR(item);
|
||||||
if (ret == -EFBIG) {
|
if (ret == -EFBIG) {
|
||||||
u32 item_size;
|
u32 item_size;
|
||||||
|
@ -226,14 +226,15 @@ csum:
|
||||||
item = (struct btrfs_csum_item *)((unsigned char *)item +
|
item = (struct btrfs_csum_item *)((unsigned char *)item +
|
||||||
csum_offset * BTRFS_CRC32_SIZE);
|
csum_offset * BTRFS_CRC32_SIZE);
|
||||||
found:
|
found:
|
||||||
/* FIXME!!!!!!!!!!!! */
|
csum_result = btrfs_csum_data(root, data, csum_result, len);
|
||||||
ret = btrfs_csum_data(root, data, len, &item->csum);
|
btrfs_csum_final(csum_result, (char *)&csum_result);
|
||||||
|
write_extent_buffer(leaf, &csum_result, (unsigned long)item,
|
||||||
|
BTRFS_CRC32_SIZE);
|
||||||
btrfs_mark_buffer_dirty(path->nodes[0]);
|
btrfs_mark_buffer_dirty(path->nodes[0]);
|
||||||
fail:
|
fail:
|
||||||
btrfs_release_path(root, path);
|
btrfs_release_path(root, path);
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
return ret;
|
return ret;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int btrfs_csum_truncate(struct btrfs_trans_handle *trans,
|
int btrfs_csum_truncate(struct btrfs_trans_handle *trans,
|
||||||
|
|
|
@ -289,6 +289,7 @@ static int dirty_and_release_pages(struct btrfs_trans_handle *trans,
|
||||||
*/
|
*/
|
||||||
inline_size = end_pos;
|
inline_size = end_pos;
|
||||||
if (isize >= BTRFS_MAX_INLINE_DATA_SIZE(root) ||
|
if (isize >= BTRFS_MAX_INLINE_DATA_SIZE(root) ||
|
||||||
|
inline_size > 16384 ||
|
||||||
inline_size >= BTRFS_MAX_INLINE_DATA_SIZE(root)) {
|
inline_size >= BTRFS_MAX_INLINE_DATA_SIZE(root)) {
|
||||||
u64 last_end;
|
u64 last_end;
|
||||||
|
|
||||||
|
|
|
@ -135,7 +135,7 @@ int btrfs_readpage_io_hook(struct page *page, u64 start, u64 end)
|
||||||
struct extent_map_tree *em_tree = &BTRFS_I(inode)->extent_tree;
|
struct extent_map_tree *em_tree = &BTRFS_I(inode)->extent_tree;
|
||||||
struct btrfs_csum_item *item;
|
struct btrfs_csum_item *item;
|
||||||
struct btrfs_path *path = NULL;
|
struct btrfs_path *path = NULL;
|
||||||
u64 private;
|
u32 csum;
|
||||||
|
|
||||||
mutex_lock(&root->fs_info->fs_mutex);
|
mutex_lock(&root->fs_info->fs_mutex);
|
||||||
path = btrfs_alloc_path();
|
path = btrfs_alloc_path();
|
||||||
|
@ -145,11 +145,12 @@ int btrfs_readpage_io_hook(struct page *page, u64 start, u64 end)
|
||||||
/* a csum that isn't present is a preallocated region. */
|
/* a csum that isn't present is a preallocated region. */
|
||||||
if (ret == -ENOENT || ret == -EFBIG)
|
if (ret == -ENOENT || ret == -EFBIG)
|
||||||
ret = 0;
|
ret = 0;
|
||||||
private = 0;
|
csum = 0;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
memcpy((char *)&private, &item->csum, BTRFS_CRC32_SIZE);
|
read_extent_buffer(path->nodes[0], &csum, (unsigned long)item,
|
||||||
set_state_private(em_tree, start, private);
|
BTRFS_CRC32_SIZE);
|
||||||
|
set_state_private(em_tree, start, csum);
|
||||||
out:
|
out:
|
||||||
if (path)
|
if (path)
|
||||||
btrfs_free_path(path);
|
btrfs_free_path(path);
|
||||||
|
@ -165,21 +166,19 @@ int btrfs_readpage_end_io_hook(struct page *page, u64 start, u64 end)
|
||||||
char *kaddr;
|
char *kaddr;
|
||||||
u64 private;
|
u64 private;
|
||||||
int ret;
|
int ret;
|
||||||
|
struct btrfs_root *root = BTRFS_I(inode)->root;
|
||||||
|
u32 csum = ~(u32)0;
|
||||||
|
|
||||||
ret = get_state_private(em_tree, start, &private);
|
ret = get_state_private(em_tree, start, &private);
|
||||||
kaddr = kmap_atomic(page, KM_IRQ0);
|
kaddr = kmap_atomic(page, KM_IRQ0);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
goto zeroit;
|
goto zeroit;
|
||||||
}
|
}
|
||||||
/*
|
csum = btrfs_csum_data(root, kaddr + offset, csum, end - start + 1);
|
||||||
struct btrfs_root *root = BTRFS_I(inode)->root;
|
btrfs_csum_final(csum, (char *)&csum);
|
||||||
char csum[BTRFS_CRC32_SIZE];
|
if (csum != private) {
|
||||||
ret = btrfs_csum_data(root, kaddr + offset, end - start + 1, csum);
|
|
||||||
BUG_ON(ret);
|
|
||||||
if (memcmp(csum, &private, BTRFS_CRC32_SIZE)) {
|
|
||||||
goto zeroit;
|
goto zeroit;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
kunmap_atomic(kaddr, KM_IRQ0);
|
kunmap_atomic(kaddr, KM_IRQ0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue