summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuan-Chun Wu <409411716@gms.tku.edu.tw>2025-08-27 00:17:41 +0800
committerAndrew Morton <akpm@linux-foundation.org>2025-09-13 17:32:53 -0700
commit3e3f55f8b73fa0e5c4df50f8b6c001f0a1f18adf (patch)
tree34f3f2cab1d68544221918a817377e04ae38aaee
parent3d5f4f15b778d6da9760d54455cc256ecf924c0a (diff)
btree: simplify merge logic by using btree_last() return value
Previously btree_merge() called btree_last() only to test existence, then performed an extra btree_lookup() to fetch the value. This patch changes it to directly use the value returned by btree_last(), avoiding redundant lookups and simplifying the merge loop. Link: https://lkml.kernel.org/r/20250826161741.686704-1-409411716@gms.tku.edu.tw Signed-off-by: Guan-Chun Wu <409411716@gms.tku.edu.tw> Cc: Kuan-Wei Chiu <visitorckw@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
-rw-r--r--lib/btree.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/btree.c b/lib/btree.c
index bb81d3393ac5..9c80c0c7bba8 100644
--- a/lib/btree.c
+++ b/lib/btree.c
@@ -653,9 +653,9 @@ int btree_merge(struct btree_head *target, struct btree_head *victim,
* walks to remove a single object from the victim.
*/
for (;;) {
- if (!btree_last(victim, geo, key))
+ val = btree_last(victim, geo, key);
+ if (!val)
break;
- val = btree_lookup(victim, geo, key);
err = btree_insert(target, geo, key, val, gfp);
if (err)
return err;