From: Mark Fasheh Date: Wed, 13 Jul 2011 17:59:59 +0000 (-0700) Subject: btrfs: don't BUG_ON allocation errors in btrfs_drop_snapshot X-Git-Tag: firefly_0821_release~3680^2~4365^2~55^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=38a1a919535742af677303271eb4ff731547b706;p=firefly-linux-kernel-4.4.55.git btrfs: don't BUG_ON allocation errors in btrfs_drop_snapshot In addition to properly handling allocation failure from btrfs_alloc_path, I also fixed up the kzalloc error handling code immediately below it. Signed-off-by: Mark Fasheh --- diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index f6af4236e59b..6bce721e7bbc 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -6272,10 +6272,14 @@ int btrfs_drop_snapshot(struct btrfs_root *root, int level; path = btrfs_alloc_path(); - BUG_ON(!path); + if (!path) + return -ENOMEM; wc = kzalloc(sizeof(*wc), GFP_NOFS); - BUG_ON(!wc); + if (!wc) { + btrfs_free_path(path); + return -ENOMEM; + } trans = btrfs_start_transaction(tree_root, 0); BUG_ON(IS_ERR(trans));