aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/ext4/extents.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c
index 06ce8e87731e..e41be1866d7d 100644
--- a/fs/ext4/extents.c
+++ b/fs/ext4/extents.c
@@ -477,13 +477,12 @@ ext4_ext_find_extent(struct inode *inode, int block, struct ext4_ext_path *path)
477 477
478 /* account possible depth increase */ 478 /* account possible depth increase */
479 if (!path) { 479 if (!path) {
480 path = kmalloc(sizeof(struct ext4_ext_path) * (depth + 2), 480 path = kzalloc(sizeof(struct ext4_ext_path) * (depth + 2),
481 GFP_NOFS); 481 GFP_NOFS);
482 if (!path) 482 if (!path)
483 return ERR_PTR(-ENOMEM); 483 return ERR_PTR(-ENOMEM);
484 alloc = 1; 484 alloc = 1;
485 } 485 }
486 memset(path, 0, sizeof(struct ext4_ext_path) * (depth + 1));
487 path[0].p_hdr = eh; 486 path[0].p_hdr = eh;
488 487
489 /* walk through the tree */ 488 /* walk through the tree */
@@ -643,10 +642,9 @@ static int ext4_ext_split(handle_t *handle, struct inode *inode,
643 * We need this to handle errors and free blocks 642 * We need this to handle errors and free blocks
644 * upon them. 643 * upon them.
645 */ 644 */
646 ablocks = kmalloc(sizeof(ext4_fsblk_t) * depth, GFP_NOFS); 645 ablocks = kzalloc(sizeof(ext4_fsblk_t) * depth, GFP_NOFS);
647 if (!ablocks) 646 if (!ablocks)
648 return -ENOMEM; 647 return -ENOMEM;
649 memset(ablocks, 0, sizeof(ext4_fsblk_t) * depth);
650 648
651 /* allocate all needed blocks */ 649 /* allocate all needed blocks */
652 ext_debug("allocate %d blocks for indexes/leaf\n", depth - at); 650 ext_debug("allocate %d blocks for indexes/leaf\n", depth - at);
@@ -1773,12 +1771,11 @@ int ext4_ext_remove_space(struct inode *inode, unsigned long start)
1773 * We start scanning from right side, freeing all the blocks 1771 * We start scanning from right side, freeing all the blocks
1774 * after i_size and walking into the tree depth-wise. 1772 * after i_size and walking into the tree depth-wise.
1775 */ 1773 */
1776 path = kmalloc(sizeof(struct ext4_ext_path) * (depth + 1), GFP_KERNEL); 1774 path = kzalloc(sizeof(struct ext4_ext_path) * (depth + 1), GFP_KERNEL);
1777 if (path == NULL) { 1775 if (path == NULL) {
1778 ext4_journal_stop(handle); 1776 ext4_journal_stop(handle);
1779 return -ENOMEM; 1777 return -ENOMEM;
1780 } 1778 }
1781 memset(path, 0, sizeof(struct ext4_ext_path) * (depth + 1));
1782 path[0].p_hdr = ext_inode_hdr(inode); 1779 path[0].p_hdr = ext_inode_hdr(inode);
1783 if (ext4_ext_check_header(__FUNCTION__, inode, path[0].p_hdr)) { 1780 if (ext4_ext_check_header(__FUNCTION__, inode, path[0].p_hdr)) {
1784 err = -EIO; 1781 err = -EIO;