[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20220712013632.7042-1-bingjingc@synology.com>
Date: Tue, 12 Jul 2022 09:36:30 +0800
From: bingjingc <bingjingc@...ology.com>
To: josef@...icpanda.com, dsterba@...e.com, clm@...com,
linux-btrfs@...r.kernel.org, linux-kernel@...r.kernel.org
Cc: fdmanana@...nel.org, bingjingc@...ology.com, robbieko@...ology.com,
bxxxjxxg@...il.com
Subject: [PATCH v2 0/2] btrfs: send: fix sending link commands for existing file paths
From: BingJing Chang <bingjingc@...ology.com>
There is a bug sending link commands for existing file paths. When we're
processing an inode, we go over all references. All the new file paths are
added to the "new_refs" list. And all the deleted file paths are added to
the "deleted_refs" list. In the end, when we finish processing the inode,
we iterate over all the items in the "new_refs" list and send link commands
for those file paths. After that, we go over all the items in the
"deleted_refs" list and send unlink commands for them. If there are
duplicated file paths in both lists, we will try to create them before we
remove them. Then the receiver gets an -EEXIST error when trying the link
operations.
BingJing Chang (2):
btrfs: send: introduce recorded_ref_alloc and recorded_ref_free
btrfs: send: fix sending link commands for existing file paths
fs/btrfs/send.c | 195 ++++++++++++++++++++++++++++++++++++++++++++----
1 file changed, 181 insertions(+), 14 deletions(-)
--
2.37.0
Powered by blists - more mailing lists