diff options
| -rw-r--r-- | fs/ocfs2/inode.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/fs/ocfs2/inode.c b/fs/ocfs2/inode.c index 278a223aae14..ab207901d32a 100644 --- a/fs/ocfs2/inode.c +++ b/fs/ocfs2/inode.c | |||
| @@ -891,6 +891,21 @@ static int ocfs2_query_inode_wipe(struct inode *inode, | |||
| 891 | /* Do some basic inode verification... */ | 891 | /* Do some basic inode verification... */ |
| 892 | di = (struct ocfs2_dinode *) di_bh->b_data; | 892 | di = (struct ocfs2_dinode *) di_bh->b_data; |
| 893 | if (!(di->i_flags & cpu_to_le32(OCFS2_ORPHANED_FL))) { | 893 | if (!(di->i_flags & cpu_to_le32(OCFS2_ORPHANED_FL))) { |
| 894 | /* | ||
| 895 | * Inodes in the orphan dir must have ORPHANED_FL. The only | ||
| 896 | * inodes that come back out of the orphan dir are reflink | ||
| 897 | * targets. A reflink target may be moved out of the orphan | ||
| 898 | * dir between the time we scan the directory and the time we | ||
| 899 | * process it. This would lead to HAS_REFCOUNT_FL being set but | ||
| 900 | * ORPHANED_FL not. | ||
| 901 | */ | ||
| 902 | if (di->i_dyn_features & cpu_to_le16(OCFS2_HAS_REFCOUNT_FL)) { | ||
| 903 | mlog(0, "Reflinked inode %llu is no longer orphaned. " | ||
| 904 | "it shouldn't be deleted\n", | ||
| 905 | (unsigned long long)oi->ip_blkno); | ||
| 906 | goto bail; | ||
| 907 | } | ||
| 908 | |||
| 894 | /* for lack of a better error? */ | 909 | /* for lack of a better error? */ |
| 895 | status = -EEXIST; | 910 | status = -EEXIST; |
| 896 | mlog(ML_ERROR, | 911 | mlog(ML_ERROR, |
