summaryrefslogtreecommitdiffstats
path: root/fs/ceph/inode.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@fusionio.com>2013-09-11 11:57:23 -0400
committerChris Mason <chris.mason@fusionio.com>2013-09-21 11:05:25 -0400
commitdd8e721773fdab5ccc7fde44ec57e30b563243b2 (patch)
treecb008cbc777277de5f08b45d26141a1562b4f728 /fs/ceph/inode.c
parenta5874ce6ce4a3e4fc3db254ccf6d59d8501a56d8 (diff)
downloadop-kernel-dev-dd8e721773fdab5ccc7fde44ec57e30b563243b2.zip
op-kernel-dev-dd8e721773fdab5ccc7fde44ec57e30b563243b2.tar.gz
Btrfs: replay dir_index items before other items
A user reported a bug where his log would not replay because he was getting -EEXIST back. This was because he had a file moved into a directory that was logged. What happens is the file had a lower inode number, and so it is processed first when replaying the log, and so we add the inode ref in for the directory it was moved to. But then we process the directories DIR_INDEX item and try to add the inode ref for that inode and it fails because we already added it when we replayed the inode. To solve this problem we need to just process any DIR_INDEX items we have in the log first so this all is taken care of, and then we can replay the rest of the items. With this patch my reproducer can remount the file system properly instead of erroring out. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/ceph/inode.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud