aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/ctree.c
diff options
context:
space:
mode:
authorFilipe David Borba Manana <fdmanana@gmail.com>2013-12-12 14:19:52 -0500
committerChris Mason <clm@fb.com>2014-01-28 16:19:56 -0500
commit783577663507411e36e459390ef056556e93ef29 (patch)
tree8cf25b7ff377d398569dc59e69984124900315f9 /fs/btrfs/ctree.c
parentf28491e0a6c46d99cbbef0f8ef7e314afa2359c8 (diff)
Btrfs: return immediately if tree log mod is not necessary
In ctree.c:tree_mod_log_set_node_key() we were calling __tree_mod_log_insert_key() even when the modification doesn't need to be logged. This would allocate a tree_mod_elem structure, fill it and pass it to __tree_mod_log_insert(), which would just acquire the tree mod log write lock and then free the tree_mod_elem structure and return (that is, a no-op). Therefore call tree_mod_log_insert() instead of __tree_mod_log_insert() which just returns immediately if the modification doesn't need to be logged (without allocating the structure, fill it, acquire write lock, free structure). Signed-off-by: Filipe David Borba Manana <fdmanana@gmail.com> Signed-off-by: Josef Bacik <jbacik@fb.com> Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'fs/btrfs/ctree.c')
-rw-r--r--fs/btrfs/ctree.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c
index a57507aa6702..59664f6cbc4e 100644
--- a/fs/btrfs/ctree.c
+++ b/fs/btrfs/ctree.c
@@ -771,7 +771,7 @@ tree_mod_log_set_node_key(struct btrfs_fs_info *fs_info,
771{ 771{
772 int ret; 772 int ret;
773 773
774 ret = __tree_mod_log_insert_key(fs_info, eb, slot, 774 ret = tree_mod_log_insert_key(fs_info, eb, slot,
775 MOD_LOG_KEY_REPLACE, 775 MOD_LOG_KEY_REPLACE,
776 atomic ? GFP_ATOMIC : GFP_NOFS); 776 atomic ? GFP_ATOMIC : GFP_NOFS);
777 BUG_ON(ret < 0); 777 BUG_ON(ret < 0);