diff options
Diffstat (limited to 'fs/ext4/inode.c')
-rw-r--r-- | fs/ext4/inode.c | 200 |
1 files changed, 103 insertions, 97 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 5f927f6a1289..8d0908afbd5b 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -81,7 +81,7 @@ static int ext4_inode_is_fast_symlink(struct inode *inode) | |||
81 | * If the handle isn't valid we're not journaling so there's nothing to do. | 81 | * If the handle isn't valid we're not journaling so there's nothing to do. |
82 | */ | 82 | */ |
83 | int ext4_forget(handle_t *handle, int is_metadata, struct inode *inode, | 83 | int ext4_forget(handle_t *handle, int is_metadata, struct inode *inode, |
84 | struct buffer_head *bh, ext4_fsblk_t blocknr) | 84 | struct buffer_head *bh, ext4_fsblk_t blocknr) |
85 | { | 85 | { |
86 | int err; | 86 | int err; |
87 | 87 | ||
@@ -332,8 +332,8 @@ static inline void add_chain(Indirect *p, struct buffer_head *bh, __le32 *v) | |||
332 | */ | 332 | */ |
333 | 333 | ||
334 | static int ext4_block_to_path(struct inode *inode, | 334 | static int ext4_block_to_path(struct inode *inode, |
335 | ext4_lblk_t i_block, | 335 | ext4_lblk_t i_block, |
336 | ext4_lblk_t offsets[4], int *boundary) | 336 | ext4_lblk_t offsets[4], int *boundary) |
337 | { | 337 | { |
338 | int ptrs = EXT4_ADDR_PER_BLOCK(inode->i_sb); | 338 | int ptrs = EXT4_ADDR_PER_BLOCK(inode->i_sb); |
339 | int ptrs_bits = EXT4_ADDR_PER_BLOCK_BITS(inode->i_sb); | 339 | int ptrs_bits = EXT4_ADDR_PER_BLOCK_BITS(inode->i_sb); |
@@ -365,9 +365,9 @@ static int ext4_block_to_path(struct inode *inode, | |||
365 | final = ptrs; | 365 | final = ptrs; |
366 | } else { | 366 | } else { |
367 | ext4_warning(inode->i_sb, "ext4_block_to_path", | 367 | ext4_warning(inode->i_sb, "ext4_block_to_path", |
368 | "block %lu > max in inode %lu", | 368 | "block %lu > max in inode %lu", |
369 | i_block + direct_blocks + | 369 | i_block + direct_blocks + |
370 | indirect_blocks + double_blocks, inode->i_ino); | 370 | indirect_blocks + double_blocks, inode->i_ino); |
371 | } | 371 | } |
372 | if (boundary) | 372 | if (boundary) |
373 | *boundary = final - 1 - (i_block & (ptrs - 1)); | 373 | *boundary = final - 1 - (i_block & (ptrs - 1)); |
@@ -382,25 +382,25 @@ static int __ext4_check_blockref(const char *function, struct inode *inode, | |||
382 | 382 | ||
383 | while (bref < p+max) { | 383 | while (bref < p+max) { |
384 | blk = le32_to_cpu(*bref++); | 384 | blk = le32_to_cpu(*bref++); |
385 | if (blk && | 385 | if (blk && |
386 | unlikely(!ext4_data_block_valid(EXT4_SB(inode->i_sb), | 386 | unlikely(!ext4_data_block_valid(EXT4_SB(inode->i_sb), |
387 | blk, 1))) { | 387 | blk, 1))) { |
388 | ext4_error(inode->i_sb, function, | 388 | ext4_error(inode->i_sb, function, |
389 | "invalid block reference %u " | 389 | "invalid block reference %u " |
390 | "in inode #%lu", blk, inode->i_ino); | 390 | "in inode #%lu", blk, inode->i_ino); |
391 | return -EIO; | 391 | return -EIO; |
392 | } | 392 | } |
393 | } | 393 | } |
394 | return 0; | 394 | return 0; |
395 | } | 395 | } |
396 | 396 | ||
397 | 397 | ||
398 | #define ext4_check_indirect_blockref(inode, bh) \ | 398 | #define ext4_check_indirect_blockref(inode, bh) \ |
399 | __ext4_check_blockref(__func__, inode, (__le32 *)(bh)->b_data, \ | 399 | __ext4_check_blockref(__func__, inode, (__le32 *)(bh)->b_data, \ |
400 | EXT4_ADDR_PER_BLOCK((inode)->i_sb)) | 400 | EXT4_ADDR_PER_BLOCK((inode)->i_sb)) |
401 | 401 | ||
402 | #define ext4_check_inode_blockref(inode) \ | 402 | #define ext4_check_inode_blockref(inode) \ |
403 | __ext4_check_blockref(__func__, inode, EXT4_I(inode)->i_data, \ | 403 | __ext4_check_blockref(__func__, inode, EXT4_I(inode)->i_data, \ |
404 | EXT4_NDIR_BLOCKS) | 404 | EXT4_NDIR_BLOCKS) |
405 | 405 | ||
406 | /** | 406 | /** |
@@ -450,7 +450,7 @@ static Indirect *ext4_get_branch(struct inode *inode, int depth, | |||
450 | bh = sb_getblk(sb, le32_to_cpu(p->key)); | 450 | bh = sb_getblk(sb, le32_to_cpu(p->key)); |
451 | if (unlikely(!bh)) | 451 | if (unlikely(!bh)) |
452 | goto failure; | 452 | goto failure; |
453 | 453 | ||
454 | if (!bh_uptodate_or_lock(bh)) { | 454 | if (!bh_uptodate_or_lock(bh)) { |
455 | if (bh_submit_read(bh) < 0) { | 455 | if (bh_submit_read(bh) < 0) { |
456 | put_bh(bh); | 456 | put_bh(bh); |
@@ -462,7 +462,7 @@ static Indirect *ext4_get_branch(struct inode *inode, int depth, | |||
462 | goto failure; | 462 | goto failure; |
463 | } | 463 | } |
464 | } | 464 | } |
465 | 465 | ||
466 | add_chain(++p, bh, (__le32 *)bh->b_data + *++offsets); | 466 | add_chain(++p, bh, (__le32 *)bh->b_data + *++offsets); |
467 | /* Reader: end */ | 467 | /* Reader: end */ |
468 | if (!p->key) | 468 | if (!p->key) |
@@ -555,7 +555,7 @@ static ext4_fsblk_t ext4_find_near(struct inode *inode, Indirect *ind) | |||
555 | * returns it. | 555 | * returns it. |
556 | */ | 556 | */ |
557 | static ext4_fsblk_t ext4_find_goal(struct inode *inode, ext4_lblk_t block, | 557 | static ext4_fsblk_t ext4_find_goal(struct inode *inode, ext4_lblk_t block, |
558 | Indirect *partial) | 558 | Indirect *partial) |
559 | { | 559 | { |
560 | /* | 560 | /* |
561 | * XXX need to get goal block from mballoc's data structures | 561 | * XXX need to get goal block from mballoc's data structures |
@@ -577,7 +577,7 @@ static ext4_fsblk_t ext4_find_goal(struct inode *inode, ext4_lblk_t block, | |||
577 | * direct and indirect blocks. | 577 | * direct and indirect blocks. |
578 | */ | 578 | */ |
579 | static int ext4_blks_to_allocate(Indirect *branch, int k, unsigned int blks, | 579 | static int ext4_blks_to_allocate(Indirect *branch, int k, unsigned int blks, |
580 | int blocks_to_boundary) | 580 | int blocks_to_boundary) |
581 | { | 581 | { |
582 | unsigned int count = 0; | 582 | unsigned int count = 0; |
583 | 583 | ||
@@ -613,9 +613,9 @@ static int ext4_blks_to_allocate(Indirect *branch, int k, unsigned int blks, | |||
613 | * direct blocks | 613 | * direct blocks |
614 | */ | 614 | */ |
615 | static int ext4_alloc_blocks(handle_t *handle, struct inode *inode, | 615 | static int ext4_alloc_blocks(handle_t *handle, struct inode *inode, |
616 | ext4_lblk_t iblock, ext4_fsblk_t goal, | 616 | ext4_lblk_t iblock, ext4_fsblk_t goal, |
617 | int indirect_blks, int blks, | 617 | int indirect_blks, int blks, |
618 | ext4_fsblk_t new_blocks[4], int *err) | 618 | ext4_fsblk_t new_blocks[4], int *err) |
619 | { | 619 | { |
620 | struct ext4_allocation_request ar; | 620 | struct ext4_allocation_request ar; |
621 | int target, i; | 621 | int target, i; |
@@ -686,10 +686,10 @@ static int ext4_alloc_blocks(handle_t *handle, struct inode *inode, | |||
686 | } | 686 | } |
687 | if (!*err) { | 687 | if (!*err) { |
688 | if (target == blks) { | 688 | if (target == blks) { |
689 | /* | 689 | /* |
690 | * save the new block number | 690 | * save the new block number |
691 | * for the first direct block | 691 | * for the first direct block |
692 | */ | 692 | */ |
693 | new_blocks[index] = current_block; | 693 | new_blocks[index] = current_block; |
694 | } | 694 | } |
695 | blk_allocated += ar.len; | 695 | blk_allocated += ar.len; |
@@ -731,9 +731,9 @@ failed_out: | |||
731 | * as described above and return 0. | 731 | * as described above and return 0. |
732 | */ | 732 | */ |
733 | static int ext4_alloc_branch(handle_t *handle, struct inode *inode, | 733 | static int ext4_alloc_branch(handle_t *handle, struct inode *inode, |
734 | ext4_lblk_t iblock, int indirect_blks, | 734 | ext4_lblk_t iblock, int indirect_blks, |
735 | int *blks, ext4_fsblk_t goal, | 735 | int *blks, ext4_fsblk_t goal, |
736 | ext4_lblk_t *offsets, Indirect *branch) | 736 | ext4_lblk_t *offsets, Indirect *branch) |
737 | { | 737 | { |
738 | int blocksize = inode->i_sb->s_blocksize; | 738 | int blocksize = inode->i_sb->s_blocksize; |
739 | int i, n = 0; | 739 | int i, n = 0; |
@@ -780,7 +780,7 @@ static int ext4_alloc_branch(handle_t *handle, struct inode *inode, | |||
780 | * the chain to point to the new allocated | 780 | * the chain to point to the new allocated |
781 | * data blocks numbers | 781 | * data blocks numbers |
782 | */ | 782 | */ |
783 | for (i=1; i < num; i++) | 783 | for (i = 1; i < num; i++) |
784 | *(branch[n].p + i) = cpu_to_le32(++current_block); | 784 | *(branch[n].p + i) = cpu_to_le32(++current_block); |
785 | } | 785 | } |
786 | BUFFER_TRACE(bh, "marking uptodate"); | 786 | BUFFER_TRACE(bh, "marking uptodate"); |
@@ -823,7 +823,8 @@ failed: | |||
823 | * chain to new block and return 0. | 823 | * chain to new block and return 0. |
824 | */ | 824 | */ |
825 | static int ext4_splice_branch(handle_t *handle, struct inode *inode, | 825 | static int ext4_splice_branch(handle_t *handle, struct inode *inode, |
826 | ext4_lblk_t block, Indirect *where, int num, int blks) | 826 | ext4_lblk_t block, Indirect *where, int num, |
827 | int blks) | ||
827 | { | 828 | { |
828 | int i; | 829 | int i; |
829 | int err = 0; | 830 | int err = 0; |
@@ -924,9 +925,9 @@ err_out: | |||
924 | * blocks. | 925 | * blocks. |
925 | */ | 926 | */ |
926 | static int ext4_ind_get_blocks(handle_t *handle, struct inode *inode, | 927 | static int ext4_ind_get_blocks(handle_t *handle, struct inode *inode, |
927 | ext4_lblk_t iblock, unsigned int maxblocks, | 928 | ext4_lblk_t iblock, unsigned int maxblocks, |
928 | struct buffer_head *bh_result, | 929 | struct buffer_head *bh_result, |
929 | int flags) | 930 | int flags) |
930 | { | 931 | { |
931 | int err = -EIO; | 932 | int err = -EIO; |
932 | ext4_lblk_t offsets[4]; | 933 | ext4_lblk_t offsets[4]; |
@@ -942,7 +943,7 @@ static int ext4_ind_get_blocks(handle_t *handle, struct inode *inode, | |||
942 | J_ASSERT(!(EXT4_I(inode)->i_flags & EXT4_EXTENTS_FL)); | 943 | J_ASSERT(!(EXT4_I(inode)->i_flags & EXT4_EXTENTS_FL)); |
943 | J_ASSERT(handle != NULL || (flags & EXT4_GET_BLOCKS_CREATE) == 0); | 944 | J_ASSERT(handle != NULL || (flags & EXT4_GET_BLOCKS_CREATE) == 0); |
944 | depth = ext4_block_to_path(inode, iblock, offsets, | 945 | depth = ext4_block_to_path(inode, iblock, offsets, |
945 | &blocks_to_boundary); | 946 | &blocks_to_boundary); |
946 | 947 | ||
947 | if (depth == 0) | 948 | if (depth == 0) |
948 | goto out; | 949 | goto out; |
@@ -990,8 +991,8 @@ static int ext4_ind_get_blocks(handle_t *handle, struct inode *inode, | |||
990 | * Block out ext4_truncate while we alter the tree | 991 | * Block out ext4_truncate while we alter the tree |
991 | */ | 992 | */ |
992 | err = ext4_alloc_branch(handle, inode, iblock, indirect_blks, | 993 | err = ext4_alloc_branch(handle, inode, iblock, indirect_blks, |
993 | &count, goal, | 994 | &count, goal, |
994 | offsets + (partial - chain), partial); | 995 | offsets + (partial - chain), partial); |
995 | 996 | ||
996 | /* | 997 | /* |
997 | * The ext4_splice_branch call will free and forget any buffers | 998 | * The ext4_splice_branch call will free and forget any buffers |
@@ -1002,8 +1003,8 @@ static int ext4_ind_get_blocks(handle_t *handle, struct inode *inode, | |||
1002 | */ | 1003 | */ |
1003 | if (!err) | 1004 | if (!err) |
1004 | err = ext4_splice_branch(handle, inode, iblock, | 1005 | err = ext4_splice_branch(handle, inode, iblock, |
1005 | partial, indirect_blks, count); | 1006 | partial, indirect_blks, count); |
1006 | else | 1007 | else |
1007 | goto cleanup; | 1008 | goto cleanup; |
1008 | 1009 | ||
1009 | set_buffer_new(bh_result); | 1010 | set_buffer_new(bh_result); |
@@ -1175,7 +1176,7 @@ int ext4_get_blocks(handle_t *handle, struct inode *inode, sector_t block, | |||
1175 | up_read((&EXT4_I(inode)->i_data_sem)); | 1176 | up_read((&EXT4_I(inode)->i_data_sem)); |
1176 | 1177 | ||
1177 | if (retval > 0 && buffer_mapped(bh)) { | 1178 | if (retval > 0 && buffer_mapped(bh)) { |
1178 | int ret = check_block_validity(inode, block, | 1179 | int ret = check_block_validity(inode, block, |
1179 | bh->b_blocknr, retval); | 1180 | bh->b_blocknr, retval); |
1180 | if (ret != 0) | 1181 | if (ret != 0) |
1181 | return ret; | 1182 | return ret; |
@@ -1257,7 +1258,7 @@ int ext4_get_blocks(handle_t *handle, struct inode *inode, sector_t block, | |||
1257 | 1258 | ||
1258 | up_write((&EXT4_I(inode)->i_data_sem)); | 1259 | up_write((&EXT4_I(inode)->i_data_sem)); |
1259 | if (retval > 0 && buffer_mapped(bh)) { | 1260 | if (retval > 0 && buffer_mapped(bh)) { |
1260 | int ret = check_block_validity(inode, block, | 1261 | int ret = check_block_validity(inode, block, |
1261 | bh->b_blocknr, retval); | 1262 | bh->b_blocknr, retval); |
1262 | if (ret != 0) | 1263 | if (ret != 0) |
1263 | return ret; | 1264 | return ret; |
@@ -1408,8 +1409,7 @@ static int walk_page_buffers(handle_t *handle, | |||
1408 | 1409 | ||
1409 | for (bh = head, block_start = 0; | 1410 | for (bh = head, block_start = 0; |
1410 | ret == 0 && (bh != head || !block_start); | 1411 | ret == 0 && (bh != head || !block_start); |
1411 | block_start = block_end, bh = next) | 1412 | block_start = block_end, bh = next) { |
1412 | { | ||
1413 | next = bh->b_this_page; | 1413 | next = bh->b_this_page; |
1414 | block_end = block_start + blocksize; | 1414 | block_end = block_start + blocksize; |
1415 | if (block_end <= from || block_start >= to) { | 1415 | if (block_end <= from || block_start >= to) { |
@@ -1450,7 +1450,7 @@ static int walk_page_buffers(handle_t *handle, | |||
1450 | * write. | 1450 | * write. |
1451 | */ | 1451 | */ |
1452 | static int do_journal_get_write_access(handle_t *handle, | 1452 | static int do_journal_get_write_access(handle_t *handle, |
1453 | struct buffer_head *bh) | 1453 | struct buffer_head *bh) |
1454 | { | 1454 | { |
1455 | if (!buffer_mapped(bh) || buffer_freed(bh)) | 1455 | if (!buffer_mapped(bh) || buffer_freed(bh)) |
1456 | return 0; | 1456 | return 0; |
@@ -1458,15 +1458,15 @@ static int do_journal_get_write_access(handle_t *handle, | |||
1458 | } | 1458 | } |
1459 | 1459 | ||
1460 | static int ext4_write_begin(struct file *file, struct address_space *mapping, | 1460 | static int ext4_write_begin(struct file *file, struct address_space *mapping, |
1461 | loff_t pos, unsigned len, unsigned flags, | 1461 | loff_t pos, unsigned len, unsigned flags, |
1462 | struct page **pagep, void **fsdata) | 1462 | struct page **pagep, void **fsdata) |
1463 | { | 1463 | { |
1464 | struct inode *inode = mapping->host; | 1464 | struct inode *inode = mapping->host; |
1465 | int ret, needed_blocks; | 1465 | int ret, needed_blocks; |
1466 | handle_t *handle; | 1466 | handle_t *handle; |
1467 | int retries = 0; | 1467 | int retries = 0; |
1468 | struct page *page; | 1468 | struct page *page; |
1469 | pgoff_t index; | 1469 | pgoff_t index; |
1470 | unsigned from, to; | 1470 | unsigned from, to; |
1471 | 1471 | ||
1472 | trace_ext4_write_begin(inode, pos, len, flags); | 1472 | trace_ext4_write_begin(inode, pos, len, flags); |
@@ -1475,7 +1475,7 @@ static int ext4_write_begin(struct file *file, struct address_space *mapping, | |||
1475 | * we allocate blocks but write fails for some reason | 1475 | * we allocate blocks but write fails for some reason |
1476 | */ | 1476 | */ |
1477 | needed_blocks = ext4_writepage_trans_blocks(inode) + 1; | 1477 | needed_blocks = ext4_writepage_trans_blocks(inode) + 1; |
1478 | index = pos >> PAGE_CACHE_SHIFT; | 1478 | index = pos >> PAGE_CACHE_SHIFT; |
1479 | from = pos & (PAGE_CACHE_SIZE - 1); | 1479 | from = pos & (PAGE_CACHE_SIZE - 1); |
1480 | to = from + len; | 1480 | to = from + len; |
1481 | 1481 | ||
@@ -1523,7 +1523,7 @@ retry: | |||
1523 | ext4_journal_stop(handle); | 1523 | ext4_journal_stop(handle); |
1524 | if (pos + len > inode->i_size) { | 1524 | if (pos + len > inode->i_size) { |
1525 | vmtruncate(inode, inode->i_size); | 1525 | vmtruncate(inode, inode->i_size); |
1526 | /* | 1526 | /* |
1527 | * If vmtruncate failed early the inode might | 1527 | * If vmtruncate failed early the inode might |
1528 | * still be on the orphan list; we need to | 1528 | * still be on the orphan list; we need to |
1529 | * make sure the inode is removed from the | 1529 | * make sure the inode is removed from the |
@@ -1550,9 +1550,9 @@ static int write_end_fn(handle_t *handle, struct buffer_head *bh) | |||
1550 | } | 1550 | } |
1551 | 1551 | ||
1552 | static int ext4_generic_write_end(struct file *file, | 1552 | static int ext4_generic_write_end(struct file *file, |
1553 | struct address_space *mapping, | 1553 | struct address_space *mapping, |
1554 | loff_t pos, unsigned len, unsigned copied, | 1554 | loff_t pos, unsigned len, unsigned copied, |
1555 | struct page *page, void *fsdata) | 1555 | struct page *page, void *fsdata) |
1556 | { | 1556 | { |
1557 | int i_size_changed = 0; | 1557 | int i_size_changed = 0; |
1558 | struct inode *inode = mapping->host; | 1558 | struct inode *inode = mapping->host; |
@@ -1603,9 +1603,9 @@ static int ext4_generic_write_end(struct file *file, | |||
1603 | * buffers are managed internally. | 1603 | * buffers are managed internally. |
1604 | */ | 1604 | */ |
1605 | static int ext4_ordered_write_end(struct file *file, | 1605 | static int ext4_ordered_write_end(struct file *file, |
1606 | struct address_space *mapping, | 1606 | struct address_space *mapping, |
1607 | loff_t pos, unsigned len, unsigned copied, | 1607 | loff_t pos, unsigned len, unsigned copied, |
1608 | struct page *page, void *fsdata) | 1608 | struct page *page, void *fsdata) |
1609 | { | 1609 | { |
1610 | handle_t *handle = ext4_journal_current_handle(); | 1610 | handle_t *handle = ext4_journal_current_handle(); |
1611 | struct inode *inode = mapping->host; | 1611 | struct inode *inode = mapping->host; |
@@ -1633,7 +1633,7 @@ static int ext4_ordered_write_end(struct file *file, | |||
1633 | 1633 | ||
1634 | if (pos + len > inode->i_size) { | 1634 | if (pos + len > inode->i_size) { |
1635 | vmtruncate(inode, inode->i_size); | 1635 | vmtruncate(inode, inode->i_size); |
1636 | /* | 1636 | /* |
1637 | * If vmtruncate failed early the inode might still be | 1637 | * If vmtruncate failed early the inode might still be |
1638 | * on the orphan list; we need to make sure the inode | 1638 | * on the orphan list; we need to make sure the inode |
1639 | * is removed from the orphan list in that case. | 1639 | * is removed from the orphan list in that case. |
@@ -1647,9 +1647,9 @@ static int ext4_ordered_write_end(struct file *file, | |||
1647 | } | 1647 | } |
1648 | 1648 | ||
1649 | static int ext4_writeback_write_end(struct file *file, | 1649 | static int ext4_writeback_write_end(struct file *file, |
1650 | struct address_space *mapping, | 1650 | struct address_space *mapping, |
1651 | loff_t pos, unsigned len, unsigned copied, | 1651 | loff_t pos, unsigned len, unsigned copied, |
1652 | struct page *page, void *fsdata) | 1652 | struct page *page, void *fsdata) |
1653 | { | 1653 | { |
1654 | handle_t *handle = ext4_journal_current_handle(); | 1654 | handle_t *handle = ext4_journal_current_handle(); |
1655 | struct inode *inode = mapping->host; | 1655 | struct inode *inode = mapping->host; |
@@ -1675,7 +1675,7 @@ static int ext4_writeback_write_end(struct file *file, | |||
1675 | 1675 | ||
1676 | if (pos + len > inode->i_size) { | 1676 | if (pos + len > inode->i_size) { |
1677 | vmtruncate(inode, inode->i_size); | 1677 | vmtruncate(inode, inode->i_size); |
1678 | /* | 1678 | /* |
1679 | * If vmtruncate failed early the inode might still be | 1679 | * If vmtruncate failed early the inode might still be |
1680 | * on the orphan list; we need to make sure the inode | 1680 | * on the orphan list; we need to make sure the inode |
1681 | * is removed from the orphan list in that case. | 1681 | * is removed from the orphan list in that case. |
@@ -1688,9 +1688,9 @@ static int ext4_writeback_write_end(struct file *file, | |||
1688 | } | 1688 | } |
1689 | 1689 | ||
1690 | static int ext4_journalled_write_end(struct file *file, | 1690 | static int ext4_journalled_write_end(struct file *file, |
1691 | struct address_space *mapping, | 1691 | struct address_space *mapping, |
1692 | loff_t pos, unsigned len, unsigned copied, | 1692 | loff_t pos, unsigned len, unsigned copied, |
1693 | struct page *page, void *fsdata) | 1693 | struct page *page, void *fsdata) |
1694 | { | 1694 | { |
1695 | handle_t *handle = ext4_journal_current_handle(); | 1695 | handle_t *handle = ext4_journal_current_handle(); |
1696 | struct inode *inode = mapping->host; | 1696 | struct inode *inode = mapping->host; |
@@ -1738,7 +1738,7 @@ static int ext4_journalled_write_end(struct file *file, | |||
1738 | ret = ret2; | 1738 | ret = ret2; |
1739 | if (pos + len > inode->i_size) { | 1739 | if (pos + len > inode->i_size) { |
1740 | vmtruncate(inode, inode->i_size); | 1740 | vmtruncate(inode, inode->i_size); |
1741 | /* | 1741 | /* |
1742 | * If vmtruncate failed early the inode might still be | 1742 | * If vmtruncate failed early the inode might still be |
1743 | * on the orphan list; we need to make sure the inode | 1743 | * on the orphan list; we need to make sure the inode |
1744 | * is removed from the orphan list in that case. | 1744 | * is removed from the orphan list in that case. |
@@ -1845,7 +1845,7 @@ static void ext4_da_release_space(struct inode *inode, int to_free) | |||
1845 | } | 1845 | } |
1846 | 1846 | ||
1847 | static void ext4_da_page_release_reservation(struct page *page, | 1847 | static void ext4_da_page_release_reservation(struct page *page, |
1848 | unsigned long offset) | 1848 | unsigned long offset) |
1849 | { | 1849 | { |
1850 | int to_release = 0; | 1850 | int to_release = 0; |
1851 | struct buffer_head *head, *bh; | 1851 | struct buffer_head *head, *bh; |
@@ -2854,8 +2854,8 @@ static int ext4_nonda_switch(struct super_block *sb) | |||
2854 | } | 2854 | } |
2855 | 2855 | ||
2856 | static int ext4_da_write_begin(struct file *file, struct address_space *mapping, | 2856 | static int ext4_da_write_begin(struct file *file, struct address_space *mapping, |
2857 | loff_t pos, unsigned len, unsigned flags, | 2857 | loff_t pos, unsigned len, unsigned flags, |
2858 | struct page **pagep, void **fsdata) | 2858 | struct page **pagep, void **fsdata) |
2859 | { | 2859 | { |
2860 | int ret, retries = 0; | 2860 | int ret, retries = 0; |
2861 | struct page *page; | 2861 | struct page *page; |
@@ -2925,7 +2925,7 @@ out: | |||
2925 | * when write to the end of file but not require block allocation | 2925 | * when write to the end of file but not require block allocation |
2926 | */ | 2926 | */ |
2927 | static int ext4_da_should_update_i_disksize(struct page *page, | 2927 | static int ext4_da_should_update_i_disksize(struct page *page, |
2928 | unsigned long offset) | 2928 | unsigned long offset) |
2929 | { | 2929 | { |
2930 | struct buffer_head *bh; | 2930 | struct buffer_head *bh; |
2931 | struct inode *inode = page->mapping->host; | 2931 | struct inode *inode = page->mapping->host; |
@@ -2944,9 +2944,9 @@ static int ext4_da_should_update_i_disksize(struct page *page, | |||
2944 | } | 2944 | } |
2945 | 2945 | ||
2946 | static int ext4_da_write_end(struct file *file, | 2946 | static int ext4_da_write_end(struct file *file, |
2947 | struct address_space *mapping, | 2947 | struct address_space *mapping, |
2948 | loff_t pos, unsigned len, unsigned copied, | 2948 | loff_t pos, unsigned len, unsigned copied, |
2949 | struct page *page, void *fsdata) | 2949 | struct page *page, void *fsdata) |
2950 | { | 2950 | { |
2951 | struct inode *inode = mapping->host; | 2951 | struct inode *inode = mapping->host; |
2952 | int ret = 0, ret2; | 2952 | int ret = 0, ret2; |
@@ -3044,7 +3044,7 @@ int ext4_alloc_da_blocks(struct inode *inode) | |||
3044 | * not strictly speaking necessary (and for users of | 3044 | * not strictly speaking necessary (and for users of |
3045 | * laptop_mode, not even desirable). However, to do otherwise | 3045 | * laptop_mode, not even desirable). However, to do otherwise |
3046 | * would require replicating code paths in: | 3046 | * would require replicating code paths in: |
3047 | * | 3047 | * |
3048 | * ext4_da_writepages() -> | 3048 | * ext4_da_writepages() -> |
3049 | * write_cache_pages() ---> (via passed in callback function) | 3049 | * write_cache_pages() ---> (via passed in callback function) |
3050 | * __mpage_da_writepage() --> | 3050 | * __mpage_da_writepage() --> |
@@ -3064,7 +3064,7 @@ int ext4_alloc_da_blocks(struct inode *inode) | |||
3064 | * write out the pages, but rather only collect contiguous | 3064 | * write out the pages, but rather only collect contiguous |
3065 | * logical block extents, call the multi-block allocator, and | 3065 | * logical block extents, call the multi-block allocator, and |
3066 | * then update the buffer heads with the block allocations. | 3066 | * then update the buffer heads with the block allocations. |
3067 | * | 3067 | * |
3068 | * For now, though, we'll cheat by calling filemap_flush(), | 3068 | * For now, though, we'll cheat by calling filemap_flush(), |
3069 | * which will map the blocks, and start the I/O, but not | 3069 | * which will map the blocks, and start the I/O, but not |
3070 | * actually wait for the I/O to complete. | 3070 | * actually wait for the I/O to complete. |
@@ -3200,7 +3200,7 @@ static int bput_one(handle_t *handle, struct buffer_head *bh) | |||
3200 | * | 3200 | * |
3201 | */ | 3201 | */ |
3202 | static int __ext4_normal_writepage(struct page *page, | 3202 | static int __ext4_normal_writepage(struct page *page, |
3203 | struct writeback_control *wbc) | 3203 | struct writeback_control *wbc) |
3204 | { | 3204 | { |
3205 | struct inode *inode = page->mapping->host; | 3205 | struct inode *inode = page->mapping->host; |
3206 | 3206 | ||
@@ -3212,7 +3212,7 @@ static int __ext4_normal_writepage(struct page *page, | |||
3212 | } | 3212 | } |
3213 | 3213 | ||
3214 | static int ext4_normal_writepage(struct page *page, | 3214 | static int ext4_normal_writepage(struct page *page, |
3215 | struct writeback_control *wbc) | 3215 | struct writeback_control *wbc) |
3216 | { | 3216 | { |
3217 | struct inode *inode = page->mapping->host; | 3217 | struct inode *inode = page->mapping->host; |
3218 | loff_t size = i_size_read(inode); | 3218 | loff_t size = i_size_read(inode); |
@@ -3248,7 +3248,7 @@ static int ext4_normal_writepage(struct page *page, | |||
3248 | } | 3248 | } |
3249 | 3249 | ||
3250 | static int __ext4_journalled_writepage(struct page *page, | 3250 | static int __ext4_journalled_writepage(struct page *page, |
3251 | struct writeback_control *wbc) | 3251 | struct writeback_control *wbc) |
3252 | { | 3252 | { |
3253 | struct address_space *mapping = page->mapping; | 3253 | struct address_space *mapping = page->mapping; |
3254 | struct inode *inode = mapping->host; | 3254 | struct inode *inode = mapping->host; |
@@ -3298,7 +3298,7 @@ out: | |||
3298 | } | 3298 | } |
3299 | 3299 | ||
3300 | static int ext4_journalled_writepage(struct page *page, | 3300 | static int ext4_journalled_writepage(struct page *page, |
3301 | struct writeback_control *wbc) | 3301 | struct writeback_control *wbc) |
3302 | { | 3302 | { |
3303 | struct inode *inode = page->mapping->host; | 3303 | struct inode *inode = page->mapping->host; |
3304 | loff_t size = i_size_read(inode); | 3304 | loff_t size = i_size_read(inode); |
@@ -3401,8 +3401,8 @@ static int ext4_releasepage(struct page *page, gfp_t wait) | |||
3401 | * VFS code falls back into buffered path in that case so we are safe. | 3401 | * VFS code falls back into buffered path in that case so we are safe. |
3402 | */ | 3402 | */ |
3403 | static ssize_t ext4_direct_IO(int rw, struct kiocb *iocb, | 3403 | static ssize_t ext4_direct_IO(int rw, struct kiocb *iocb, |
3404 | const struct iovec *iov, loff_t offset, | 3404 | const struct iovec *iov, loff_t offset, |
3405 | unsigned long nr_segs) | 3405 | unsigned long nr_segs) |
3406 | { | 3406 | { |
3407 | struct file *file = iocb->ki_filp; | 3407 | struct file *file = iocb->ki_filp; |
3408 | struct inode *inode = file->f_mapping->host; | 3408 | struct inode *inode = file->f_mapping->host; |
@@ -3722,7 +3722,8 @@ static inline int all_zeroes(__le32 *p, __le32 *q) | |||
3722 | * (no partially truncated stuff there). */ | 3722 | * (no partially truncated stuff there). */ |
3723 | 3723 | ||
3724 | static Indirect *ext4_find_shared(struct inode *inode, int depth, | 3724 | static Indirect *ext4_find_shared(struct inode *inode, int depth, |
3725 | ext4_lblk_t offsets[4], Indirect chain[4], __le32 *top) | 3725 | ext4_lblk_t offsets[4], Indirect chain[4], |
3726 | __le32 *top) | ||
3726 | { | 3727 | { |
3727 | Indirect *partial, *p; | 3728 | Indirect *partial, *p; |
3728 | int k, err; | 3729 | int k, err; |
@@ -3778,8 +3779,10 @@ no_top: | |||
3778 | * than `count' because there can be holes in there. | 3779 | * than `count' because there can be holes in there. |
3779 | */ | 3780 | */ |
3780 | static void ext4_clear_blocks(handle_t *handle, struct inode *inode, | 3781 | static void ext4_clear_blocks(handle_t *handle, struct inode *inode, |
3781 | struct buffer_head *bh, ext4_fsblk_t block_to_free, | 3782 | struct buffer_head *bh, |
3782 | unsigned long count, __le32 *first, __le32 *last) | 3783 | ext4_fsblk_t block_to_free, |
3784 | unsigned long count, __le32 *first, | ||
3785 | __le32 *last) | ||
3783 | { | 3786 | { |
3784 | __le32 *p; | 3787 | __le32 *p; |
3785 | if (try_to_extend_transaction(handle, inode)) { | 3788 | if (try_to_extend_transaction(handle, inode)) { |
@@ -3796,10 +3799,11 @@ static void ext4_clear_blocks(handle_t *handle, struct inode *inode, | |||
3796 | } | 3799 | } |
3797 | 3800 | ||
3798 | /* | 3801 | /* |
3799 | * Any buffers which are on the journal will be in memory. We find | 3802 | * Any buffers which are on the journal will be in memory. We |
3800 | * them on the hash table so jbd2_journal_revoke() will run jbd2_journal_forget() | 3803 | * find them on the hash table so jbd2_journal_revoke() will |
3801 | * on them. We've already detached each block from the file, so | 3804 | * run jbd2_journal_forget() on them. We've already detached |
3802 | * bforget() in jbd2_journal_forget() should be safe. | 3805 | * each block from the file, so bforget() in |
3806 | * jbd2_journal_forget() should be safe. | ||
3803 | * | 3807 | * |
3804 | * AKPM: turn on bforget in jbd2_journal_forget()!!! | 3808 | * AKPM: turn on bforget in jbd2_journal_forget()!!! |
3805 | */ | 3809 | */ |
@@ -4171,7 +4175,7 @@ void ext4_truncate(struct inode *inode) | |||
4171 | (__le32*)partial->bh->b_data+addr_per_block, | 4175 | (__le32*)partial->bh->b_data+addr_per_block, |
4172 | (chain+n-1) - partial); | 4176 | (chain+n-1) - partial); |
4173 | BUFFER_TRACE(partial->bh, "call brelse"); | 4177 | BUFFER_TRACE(partial->bh, "call brelse"); |
4174 | brelse (partial->bh); | 4178 | brelse(partial->bh); |
4175 | partial--; | 4179 | partial--; |
4176 | } | 4180 | } |
4177 | do_indirects: | 4181 | do_indirects: |
@@ -4412,8 +4416,9 @@ void ext4_get_inode_flags(struct ext4_inode_info *ei) | |||
4412 | if (flags & S_DIRSYNC) | 4416 | if (flags & S_DIRSYNC) |
4413 | ei->i_flags |= EXT4_DIRSYNC_FL; | 4417 | ei->i_flags |= EXT4_DIRSYNC_FL; |
4414 | } | 4418 | } |
4419 | |||
4415 | static blkcnt_t ext4_inode_blocks(struct ext4_inode *raw_inode, | 4420 | static blkcnt_t ext4_inode_blocks(struct ext4_inode *raw_inode, |
4416 | struct ext4_inode_info *ei) | 4421 | struct ext4_inode_info *ei) |
4417 | { | 4422 | { |
4418 | blkcnt_t i_blocks ; | 4423 | blkcnt_t i_blocks ; |
4419 | struct inode *inode = &(ei->vfs_inode); | 4424 | struct inode *inode = &(ei->vfs_inode); |
@@ -4528,7 +4533,7 @@ struct inode *ext4_iget(struct super_block *sb, unsigned long ino) | |||
4528 | EXT4_GOOD_OLD_INODE_SIZE + | 4533 | EXT4_GOOD_OLD_INODE_SIZE + |
4529 | ei->i_extra_isize; | 4534 | ei->i_extra_isize; |
4530 | if (*magic == cpu_to_le32(EXT4_XATTR_MAGIC)) | 4535 | if (*magic == cpu_to_le32(EXT4_XATTR_MAGIC)) |
4531 | ei->i_state |= EXT4_STATE_XATTR; | 4536 | ei->i_state |= EXT4_STATE_XATTR; |
4532 | } | 4537 | } |
4533 | } else | 4538 | } else |
4534 | ei->i_extra_isize = 0; | 4539 | ei->i_extra_isize = 0; |
@@ -4547,7 +4552,7 @@ struct inode *ext4_iget(struct super_block *sb, unsigned long ino) | |||
4547 | 4552 | ||
4548 | ret = 0; | 4553 | ret = 0; |
4549 | if (ei->i_file_acl && | 4554 | if (ei->i_file_acl && |
4550 | ((ei->i_file_acl < | 4555 | ((ei->i_file_acl < |
4551 | (le32_to_cpu(EXT4_SB(sb)->s_es->s_first_data_block) + | 4556 | (le32_to_cpu(EXT4_SB(sb)->s_es->s_first_data_block) + |
4552 | EXT4_SB(sb)->s_gdb_count)) || | 4557 | EXT4_SB(sb)->s_gdb_count)) || |
4553 | (ei->i_file_acl >= ext4_blocks_count(EXT4_SB(sb)->s_es)))) { | 4558 | (ei->i_file_acl >= ext4_blocks_count(EXT4_SB(sb)->s_es)))) { |
@@ -4562,15 +4567,15 @@ struct inode *ext4_iget(struct super_block *sb, unsigned long ino) | |||
4562 | !ext4_inode_is_fast_symlink(inode))) | 4567 | !ext4_inode_is_fast_symlink(inode))) |
4563 | /* Validate extent which is part of inode */ | 4568 | /* Validate extent which is part of inode */ |
4564 | ret = ext4_ext_check_inode(inode); | 4569 | ret = ext4_ext_check_inode(inode); |
4565 | } else if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || | 4570 | } else if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
4566 | (S_ISLNK(inode->i_mode) && | 4571 | (S_ISLNK(inode->i_mode) && |
4567 | !ext4_inode_is_fast_symlink(inode))) { | 4572 | !ext4_inode_is_fast_symlink(inode))) { |
4568 | /* Validate block references which are part of inode */ | 4573 | /* Validate block references which are part of inode */ |
4569 | ret = ext4_check_inode_blockref(inode); | 4574 | ret = ext4_check_inode_blockref(inode); |
4570 | } | 4575 | } |
4571 | if (ret) { | 4576 | if (ret) { |
4572 | brelse(bh); | 4577 | brelse(bh); |
4573 | goto bad_inode; | 4578 | goto bad_inode; |
4574 | } | 4579 | } |
4575 | 4580 | ||
4576 | if (S_ISREG(inode->i_mode)) { | 4581 | if (S_ISREG(inode->i_mode)) { |
@@ -4601,7 +4606,7 @@ struct inode *ext4_iget(struct super_block *sb, unsigned long ino) | |||
4601 | } else { | 4606 | } else { |
4602 | brelse(bh); | 4607 | brelse(bh); |
4603 | ret = -EIO; | 4608 | ret = -EIO; |
4604 | ext4_error(inode->i_sb, __func__, | 4609 | ext4_error(inode->i_sb, __func__, |
4605 | "bogus i_mode (%o) for inode=%lu", | 4610 | "bogus i_mode (%o) for inode=%lu", |
4606 | inode->i_mode, inode->i_ino); | 4611 | inode->i_mode, inode->i_ino); |
4607 | goto bad_inode; | 4612 | goto bad_inode; |
@@ -4754,8 +4759,9 @@ static int ext4_do_update_inode(handle_t *handle, | |||
4754 | cpu_to_le32(new_encode_dev(inode->i_rdev)); | 4759 | cpu_to_le32(new_encode_dev(inode->i_rdev)); |
4755 | raw_inode->i_block[2] = 0; | 4760 | raw_inode->i_block[2] = 0; |
4756 | } | 4761 | } |
4757 | } else for (block = 0; block < EXT4_N_BLOCKS; block++) | 4762 | } else |
4758 | raw_inode->i_block[block] = ei->i_data[block]; | 4763 | for (block = 0; block < EXT4_N_BLOCKS; block++) |
4764 | raw_inode->i_block[block] = ei->i_data[block]; | ||
4759 | 4765 | ||
4760 | raw_inode->i_disk_version = cpu_to_le32(inode->i_version); | 4766 | raw_inode->i_disk_version = cpu_to_le32(inode->i_version); |
4761 | if (ei->i_extra_isize) { | 4767 | if (ei->i_extra_isize) { |
@@ -5109,7 +5115,7 @@ int ext4_chunk_trans_blocks(struct inode *inode, int nrblocks) | |||
5109 | * Give this, we know that the caller already has write access to iloc->bh. | 5115 | * Give this, we know that the caller already has write access to iloc->bh. |
5110 | */ | 5116 | */ |
5111 | int ext4_mark_iloc_dirty(handle_t *handle, | 5117 | int ext4_mark_iloc_dirty(handle_t *handle, |
5112 | struct inode *inode, struct ext4_iloc *iloc) | 5118 | struct inode *inode, struct ext4_iloc *iloc) |
5113 | { | 5119 | { |
5114 | int err = 0; | 5120 | int err = 0; |
5115 | 5121 | ||