diff options
| -rw-r--r-- | fs/ext4/file.c | 14 | 
1 files changed, 9 insertions, 5 deletions
| diff --git a/fs/ext4/file.c b/fs/ext4/file.c index c48ea76b63e4..7f8023340eb8 100644 --- a/fs/ext4/file.c +++ b/fs/ext4/file.c @@ -393,7 +393,7 @@ static int ext4_sample_last_mounted(struct super_block *sb,  	if (likely(sbi->s_mount_flags & EXT4_MF_MNTDIR_SAMPLED))  		return 0; -	if (sb_rdonly(sb)) +	if (sb_rdonly(sb) || !sb_start_intwrite_trylock(sb))  		return 0;  	sbi->s_mount_flags |= EXT4_MF_MNTDIR_SAMPLED; @@ -407,21 +407,25 @@ static int ext4_sample_last_mounted(struct super_block *sb,  	path.mnt = mnt;  	path.dentry = mnt->mnt_root;  	cp = d_path(&path, buf, sizeof(buf)); +	err = 0;  	if (IS_ERR(cp)) -		return 0; +		goto out;  	handle = ext4_journal_start_sb(sb, EXT4_HT_MISC, 1); +	err = PTR_ERR(handle);  	if (IS_ERR(handle)) -		return PTR_ERR(handle); +		goto out;  	BUFFER_TRACE(sbi->s_sbh, "get_write_access");  	err = ext4_journal_get_write_access(handle, sbi->s_sbh);  	if (err) -		goto out; +		goto out_journal;  	strlcpy(sbi->s_es->s_last_mounted, cp,  		sizeof(sbi->s_es->s_last_mounted));  	ext4_handle_dirty_super(handle, sb); -out: +out_journal:  	ext4_journal_stop(handle); +out: +	sb_end_intwrite(sb);  	return err;  } | 
