fuse: fix fuse_file_lseek returning with lock held
This bug was found with smatch (http://repo.or.cz/w/smatch.git/). If we return directly the inode->i_mutex lock doesn't get released. Signed-off-by: Dan Carpenter <error27@gmail.com> Signed-off-by: Miklos Szeredi <mszeredi@suse.cz> CC: stable@kernel.org
This commit is contained in:
parent
0d34fb8e93
commit
5291658d87
|
@ -1465,7 +1465,7 @@ static loff_t fuse_file_llseek(struct file *file, loff_t offset, int origin)
|
||||||
case SEEK_END:
|
case SEEK_END:
|
||||||
retval = fuse_update_attributes(inode, NULL, file, NULL);
|
retval = fuse_update_attributes(inode, NULL, file, NULL);
|
||||||
if (retval)
|
if (retval)
|
||||||
return retval;
|
goto exit;
|
||||||
offset += i_size_read(inode);
|
offset += i_size_read(inode);
|
||||||
break;
|
break;
|
||||||
case SEEK_CUR:
|
case SEEK_CUR:
|
||||||
|
@ -1479,6 +1479,7 @@ static loff_t fuse_file_llseek(struct file *file, loff_t offset, int origin)
|
||||||
}
|
}
|
||||||
retval = offset;
|
retval = offset;
|
||||||
}
|
}
|
||||||
|
exit:
|
||||||
mutex_unlock(&inode->i_mutex);
|
mutex_unlock(&inode->i_mutex);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue