aboutsummaryrefslogtreecommitdiffstats
path: root/fs/exofs/inode.c
diff options
context:
space:
mode:
authorBoaz Harrosh <bharrosh@panasas.com>2012-11-30 09:03:31 -0500
committerBoaz Harrosh <bharrosh@panasas.com>2012-12-14 05:17:32 -0500
commit861d66601acda6d7a2038fb3c95f68009128003a (patch)
tree5d0c9ede684df2d9788bde18129354fe4736bcad /fs/exofs/inode.c
parentaf402ab2b0369c2b1acf4cde72c5ed5050c74e5b (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.c10
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
363err: 363err:
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