Skip to content

Commit

Permalink
afs: Fix page leak on afs_write_begin() failure
Browse files Browse the repository at this point in the history
Fix the leak of the target page in afs_write_begin() when it fails.

Fixes: 15b4650 ("afs: convert to new aops")
Signed-off-by: David Howells <[email protected]>
cc: Nick Piggin <[email protected]>
  • Loading branch information
dhowells committed Oct 29, 2020
1 parent fa04a40 commit 21db2cd
Showing 1 changed file with 11 additions and 12 deletions.
23 changes: 11 additions & 12 deletions fs/afs/write.c
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ static int afs_fill_page(struct afs_vnode *vnode, struct key *key,
*/
int afs_write_begin(struct file *file, struct address_space *mapping,
loff_t pos, unsigned len, unsigned flags,
struct page **pagep, void **fsdata)
struct page **_page, void **fsdata)
{
struct afs_vnode *vnode = AFS_FS_I(file_inode(file));
struct page *page;
Expand Down Expand Up @@ -110,9 +110,6 @@ int afs_write_begin(struct file *file, struct address_space *mapping,
SetPageUptodate(page);
}

/* page won't leak in error case: it eventually gets cleaned off LRU */
*pagep = page;

try_again:
/* See if this page is already partially written in a way that we can
* merge the new write with.
Expand Down Expand Up @@ -155,6 +152,7 @@ int afs_write_begin(struct file *file, struct address_space *mapping,
set_page_private(page, priv);
else
attach_page_private(page, (void *)priv);
*_page = page;
_leave(" = 0");
return 0;

Expand All @@ -164,17 +162,18 @@ int afs_write_begin(struct file *file, struct address_space *mapping,
flush_conflicting_write:
_debug("flush conflict");
ret = write_one_page(page);
if (ret < 0) {
_leave(" = %d", ret);
return ret;
}
if (ret < 0)
goto error;

ret = lock_page_killable(page);
if (ret < 0) {
_leave(" = %d", ret);
return ret;
}
if (ret < 0)
goto error;
goto try_again;

error:
put_page(page);
_leave(" = %d", ret);
return ret;
}

/*
Expand Down

0 comments on commit 21db2cd

Please sign in to comment.