Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753754AbdHUMlK (ORCPT ); Mon, 21 Aug 2017 08:41:10 -0400 Received: from mout.web.de ([212.227.15.4]:57784 "EHLO mout.web.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753243AbdHUMlI (ORCPT ); Mon, 21 Aug 2017 08:41:08 -0400 Subject: [PATCH 3/5] btrfs: Use common error handling code in btrfs_update_root() From: SF Markus Elfring To: linux-btrfs@vger.kernel.org, Chris Mason , David Sterba , Josef Bacik Cc: LKML , kernel-janitors@vger.kernel.org References: <1e8e1da2-a9e3-9dc7-6ffe-6c32f8464337@users.sourceforge.net> Message-ID: <287b99e6-6562-ea64-e763-6a6808fee12a@users.sourceforge.net> Date: Mon, 21 Aug 2017 14:40:28 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <1e8e1da2-a9e3-9dc7-6ffe-6c32f8464337@users.sourceforge.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit X-Provags-ID: V03:K0:xndmxOsDor43gh0bDR4leoI9bYFZ/6iJHp8EqRS2bWo517JH0is Y7YAUoK05gKfoMOPB+2uHw0wPlhWohI+aiwy5swCE1egCXdQ/qeff1amcBk+v/Ie1uiH5WP aaDLjWcjlv9jKTnk6d2Nqv7HE5FM0XL7wnyDQjgMA0NxPvp6CAW1xuuRFUGvP+gLkbLW7in UZOXx9Ws2rQsZLcGmuC8A== X-UI-Out-Filterresults: notjunk:1;V01:K0:9jMn5FpuBXU=:GLNeMvNCRBPRZ+baz9VFsJ 492TDhTlA2lH+aLZq42+TLydNzYnSh1f1jI4oneNmkT0q1Nkf6nOOAvJ3GyjUn2CLbl1Z1UqM uSyHPpQMxCgo7oMqX/gCGTuFz/PwKF+WCWwYbikMCn0nqBXkYOnPcX1zsu06hIrl3vhHkJPLw G1UyK+rcWmVLjTE/vzSKeo7M8kDTk5j9l9XhhMsWQJyxTSrFvtLGAW1xwk4wL5Qs4qNFeDOHw eM3g8/CcGaQr0bA7FgDmX8jkdguivvymwYKtymusTkdWgF55LhcvenvhixbiSXKZUNg4E6xgl ynJtcjbTOFPFzc/bH/1knHpXryV2pV0ZsUowo116fz0OhxM3k+YFQSDEJgGeR/1cZxMl8e7To V/XWYtGLHtK3XdYnRs52xS397BBN09zRBrOWhBtDF9v9YSqYQPZZMgMzmoqUg3NAEM40LTALa Y0cgUYPF5D1159pS1xuLGRibwAXP015sh+sotJ4ge/noxSPRD6yTH/1QBYg0aVV5KZeWX75A6 nYk66T81aqd8PcMzNknAvt+19UM0HJn6OfHsJ16eVA/jMFzwFw785DFTT0M83WE90iiZqU6MO +E55ioBAcnxx5z8djpA0ERTwq8SwM/Um/dNnbDufmxUx7vl1urCkh0MrjwWbe/YTbNiA9rqqI gISprbswAlYQ8Q1ZjRphfCbMMqHbdvPAtUwYFu1w2t6Dc7GuIDpdr3V1eBshrzgbC02teMwOh mnHffkOm2UnmmJZ+M39+fgkeJaTLTX8jWToUDX6Mhw5vV9UVfK712uES8qqrYWVx35ECaGxEv DI4u2rWuVsll+Ggq1JN4VvMii0cXyldgm25ocjibhpMVTPBvSHjijQQUvw8r2ZLWIqvJBXM Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2032 Lines: 72 From: Markus Elfring Date: Mon, 21 Aug 2017 13:10:15 +0200 Add a jump target so that a bit of exception handling can be better reused at the end of this function. This issue was detected by using the Coccinelle software. Signed-off-by: Markus Elfring --- fs/btrfs/root-tree.c | 27 +++++++++++---------------- 1 file changed, 11 insertions(+), 16 deletions(-) diff --git a/fs/btrfs/root-tree.c b/fs/btrfs/root-tree.c index 5b488af6f25e..bc497ba9d9d1 100644 --- a/fs/btrfs/root-tree.c +++ b/fs/btrfs/root-tree.c @@ -145,10 +145,8 @@ int btrfs_update_root(struct btrfs_trans_handle *trans, struct btrfs_root return -ENOMEM; ret = btrfs_search_slot(trans, root, key, path, 0, 1); - if (ret < 0) { - btrfs_abort_transaction(trans, ret); - goto out; - } + if (ret < 0) + goto abort_transaction; if (ret != 0) { btrfs_print_leaf(path->nodes[0]); @@ -171,23 +169,17 @@ int btrfs_update_root(struct btrfs_trans_handle *trans, struct btrfs_root btrfs_release_path(path); ret = btrfs_search_slot(trans, root, key, path, -1, 1); - if (ret < 0) { - btrfs_abort_transaction(trans, ret); - goto out; - } + if (ret < 0) + goto abort_transaction; ret = btrfs_del_item(trans, root, path); - if (ret < 0) { - btrfs_abort_transaction(trans, ret); - goto out; - } + if (ret < 0) + goto abort_transaction; btrfs_release_path(path); ret = btrfs_insert_empty_item(trans, root, path, key, sizeof(*item)); - if (ret < 0) { - btrfs_abort_transaction(trans, ret); - goto out; - } + if (ret < 0) + goto abort_transaction; l = path->nodes[0]; slot = path->slots[0]; ptr = btrfs_item_ptr_offset(l, slot); @@ -204,6 +196,9 @@ int btrfs_update_root(struct btrfs_trans_handle *trans, struct btrfs_root out: btrfs_free_path(path); return ret; +abort_transaction: + btrfs_abort_transaction(trans, ret); + goto out; } int btrfs_insert_root(struct btrfs_trans_handle *trans, struct btrfs_root *root, -- 2.14.0