AFS: Don't pass error value to page_cache_release() in error handling
In the error handling in afs_mntpt_do_automount(), we pass an error pointer to page_cache_release() if read_mapping_page() failed. Instead, we should extend the gotos around the error handling we don't need. Reported-by: Dan Carpenter <error27@gmail.com> Signed-off-by: David Howells <dhowells@redhat.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
05ce7bfe54
commit
083fd8b21a
1 changed files with 12 additions and 12 deletions
|
@ -138,9 +138,9 @@ static struct vfsmount *afs_mntpt_do_automount(struct dentry *mntpt)
|
|||
{
|
||||
struct afs_super_info *super;
|
||||
struct vfsmount *mnt;
|
||||
struct page *page = NULL;
|
||||
struct page *page;
|
||||
size_t size;
|
||||
char *buf, *devname = NULL, *options = NULL;
|
||||
char *buf, *devname, *options;
|
||||
int ret;
|
||||
|
||||
_enter("{%s}", mntpt->d_name.name);
|
||||
|
@ -150,22 +150,22 @@ static struct vfsmount *afs_mntpt_do_automount(struct dentry *mntpt)
|
|||
ret = -EINVAL;
|
||||
size = mntpt->d_inode->i_size;
|
||||
if (size > PAGE_SIZE - 1)
|
||||
goto error;
|
||||
goto error_no_devname;
|
||||
|
||||
ret = -ENOMEM;
|
||||
devname = (char *) get_zeroed_page(GFP_KERNEL);
|
||||
if (!devname)
|
||||
goto error;
|
||||
goto error_no_devname;
|
||||
|
||||
options = (char *) get_zeroed_page(GFP_KERNEL);
|
||||
if (!options)
|
||||
goto error;
|
||||
goto error_no_options;
|
||||
|
||||
/* read the contents of the AFS special symlink */
|
||||
page = read_mapping_page(mntpt->d_inode->i_mapping, 0, NULL);
|
||||
if (IS_ERR(page)) {
|
||||
ret = PTR_ERR(page);
|
||||
goto error;
|
||||
goto error_no_page;
|
||||
}
|
||||
|
||||
ret = -EIO;
|
||||
|
@ -196,12 +196,12 @@ static struct vfsmount *afs_mntpt_do_automount(struct dentry *mntpt)
|
|||
return mnt;
|
||||
|
||||
error:
|
||||
if (page)
|
||||
page_cache_release(page);
|
||||
if (devname)
|
||||
free_page((unsigned long) devname);
|
||||
if (options)
|
||||
error_no_page:
|
||||
free_page((unsigned long) options);
|
||||
error_no_options:
|
||||
free_page((unsigned long) devname);
|
||||
error_no_devname:
|
||||
_leave(" = %d", ret);
|
||||
return ERR_PTR(ret);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue