[Ocfs2-devel] [patch 07/28] ocfs2: fix a tiny case that inode can not removed.

jiangyiwen jiangyiwen at huawei.com
Mon Aug 31 00:28:54 PDT 2015


On 2015/8/29 7:26, Mark Fasheh wrote:
> On Wed, Aug 26, 2015 at 03:11:37PM -0700, Andrew Morton wrote:
>> From: jiangyiwen <jiangyiwen at huawei.com>
>> Subject: ocfs2: fix a tiny case that inode can not removed.
>>
>> When running dirop_fileop_racer we found a case that inode
>> can not removed.
>>
>> 2 nodes, say Node A and Node B, mount the same ocfs2 volume. Create
>> two dirs /race/1/ and /race/2/ in the filesystem.
>>
>> Node A                            Node B
>> rm -r /race/2/
>>                                   mv /race/1/ /race/2/
>> call ocfs2_unlink(), get
>> the EX mode of /race/2/
>>                                   wait for B unlock /race/2/
>> decrease i_nlink of /race/2/ to 0,
>> and add inode of /race/2/ into
>> orphan dir, unlock /race/2/
>>                                   got EX mode of /race/2/. because
>>                                   /race/1/ is dir, so inc i_nlink
>>                                   of /race/2/ and update into disk,
>>                                   unlock /race/2/
>> because i_nlink of /race/2/
>> is not zero, this inode will
>> always remain in orphan dir
>>
>> This patch fixes this case by test whether i_nlink of new dir is zero.
> 
> 
> Good catch, thanks for this.
> 
> 
>> diff -puN fs/ocfs2/namei.c~ocfs2-fix-a-tiny-case-that-inode-can-not-removed fs/ocfs2/namei.c
>> --- a/fs/ocfs2/namei.c~ocfs2-fix-a-tiny-case-that-inode-can-not-removed
>> +++ a/fs/ocfs2/namei.c
>> @@ -1284,6 +1284,15 @@ static int ocfs2_rename(struct inode *ol
>>  	}
>>  	parents_locked = 1;
>>  
>> +	if (!new_dir->i_nlink) {
>> +		mlog(ML_ERROR, "new dir %llu has been removed, inode %llu "
>> +				"can not be moved into it.",
>> +				(unsigned long long)new_dir->i_ino,
>> +				(unsigned long long)old_inode->i_ino);
> 
> This is something that is rare, but not an error or otherwise outstanding
> condition. Therefore printing to the kernel log is not advisable and may
> confuse users. Please turn that into a debug print or remove it all
> together, thanks.
> 	--Mark
> 
> --
> Mark Fasheh
> 
> .
> 
OK, thanks Mark, I will resend a new version immediately.

Thanks,
Yiwen Jiang





More information about the Ocfs2-devel mailing list