diff options
author | Boaz Harrosh <bharrosh@panasas.com> | 2012-11-30 09:03:31 -0500 |
---|---|---|
committer | Boaz Harrosh <bharrosh@panasas.com> | 2012-12-14 05:17:32 -0500 |
commit | 861d66601acda6d7a2038fb3c95f68009128003a (patch) | |
tree | 5d0c9ede684df2d9788bde18129354fe4736bcad /fs/exofs/inode.c | |
parent | af402ab2b0369c2b1acf4cde72c5ed5050c74e5b (diff) |
exofs: don't leak io_state and pages on read error
Same bug as fixed by Idan for write_exec was in read_exec.
Fix the io_state leak and pages state on read error.
Also while at it:
The if (!pcol->read_4_write) at the error path is redundant
because all goto err; are after the if (pcol->read_4_write)
bale out.
Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
Diffstat (limited to 'fs/exofs/inode.c')
-rw-r--r-- | fs/exofs/inode.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/fs/exofs/inode.c b/fs/exofs/inode.c index 1634b946565f..d1f80abd8828 100644 --- a/fs/exofs/inode.c +++ b/fs/exofs/inode.c | |||
@@ -361,12 +361,12 @@ static int read_exec(struct page_collect *pcol) | |||
361 | return 0; | 361 | return 0; |
362 | 362 | ||
363 | err: | 363 | err: |
364 | if (!pcol->read_4_write) | 364 | if (!pcol_copy) /* Failed before ownership transfer */ |
365 | _unlock_pcol_pages(pcol, ret, READ); | 365 | pcol_copy = pcol; |
366 | 366 | _unlock_pcol_pages(pcol_copy, ret, READ); | |
367 | pcol_free(pcol); | 367 | pcol_free(pcol_copy); |
368 | |||
369 | kfree(pcol_copy); | 368 | kfree(pcol_copy); |
369 | |||
370 | return ret; | 370 | return ret; |
371 | } | 371 | } |
372 | 372 | ||