* [PATCH v3] xfs: fix memory leak in xfs_dir2_node_removename
@ 2013-10-06 2:48 Mark Tinguely
2013-12-04 21:00 ` Ben Myers
0 siblings, 1 reply; 3+ messages in thread
From: Mark Tinguely @ 2013-10-06 2:48 UTC (permalink / raw)
To: xfs
[-- Attachment #1: v3-xfs-fix-leak-in-xfs_dir2_node_removename.patch --]
[-- Type: text/plain, Size: 2386 bytes --]
Fix the leak of kernel memory in xfs_dir2_node_removename()
when xfs_dir2_leafn_remove() returns an error code.
Signed-off-by: Mark Tinguely <tinguely@sgi.com>
---
v3 change error logic and goto label names
v2 corrected bad return code as pointed out by Roger Willcocks.
Found by Coverity (134681) in userspace.
fs/xfs/xfs_dir2_node.c | 26 +++++++++++++-------------
1 file changed, 13 insertions(+), 13 deletions(-)
Index: b/fs/xfs/xfs_dir2_node.c
===================================================================
--- a/fs/xfs/xfs_dir2_node.c
+++ b/fs/xfs/xfs_dir2_node.c
@@ -2105,12 +2105,12 @@ xfs_dir2_node_lookup(
*/
int /* error */
xfs_dir2_node_removename(
- xfs_da_args_t *args) /* operation arguments */
+ struct xfs_da_args *args) /* operation arguments */
{
- xfs_da_state_blk_t *blk; /* leaf block */
+ struct xfs_da_state_blk *blk; /* leaf block */
int error; /* error return value */
int rval; /* operation return value */
- xfs_da_state_t *state; /* btree cursor */
+ struct xfs_da_state *state; /* btree cursor */
trace_xfs_dir2_node_removename(args);
@@ -2122,19 +2122,18 @@ xfs_dir2_node_removename(
state->mp = args->dp->i_mount;
state->blocksize = state->mp->m_dirblksize;
state->node_ents = state->mp->m_dir_node_ents;
- /*
- * Look up the entry we're deleting, set up the cursor.
- */
+
+ /* Look up the entry we're deleting, set up the cursor. */
error = xfs_da3_node_lookup_int(state, &rval);
if (error)
- rval = error;
- /*
- * Didn't find it, upper layer screwed up.
- */
+ goto out_free;
+
+ /* Didn't find it, upper layer screwed up. */
if (rval != EEXIST) {
- xfs_da_state_free(state);
- return rval;
+ error = rval;
+ goto out_free;
}
+
blk = &state->path.blk[state->path.active - 1];
ASSERT(blk->magic == XFS_DIR2_LEAFN_MAGIC);
ASSERT(state->extravalid);
@@ -2145,7 +2144,7 @@ xfs_dir2_node_removename(
error = xfs_dir2_leafn_remove(args, blk->bp, blk->index,
&state->extrablk, &rval);
if (error)
- return error;
+ goto out_free;
/*
* Fix the hash values up the btree.
*/
@@ -2160,6 +2159,7 @@ xfs_dir2_node_removename(
*/
if (!error)
error = xfs_dir2_node_to_leaf(state);
+out_free:
xfs_da_state_free(state);
return error;
}
_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v3] xfs: fix memory leak in xfs_dir2_node_removename
2013-10-06 2:48 [PATCH v3] xfs: fix memory leak in xfs_dir2_node_removename Mark Tinguely
@ 2013-12-04 21:00 ` Ben Myers
2013-12-05 22:47 ` Ben Myers
0 siblings, 1 reply; 3+ messages in thread
From: Ben Myers @ 2013-12-04 21:00 UTC (permalink / raw)
To: Mark Tinguely; +Cc: xfs
On Sat, Oct 05, 2013 at 09:48:25PM -0500, Mark Tinguely wrote:
> Fix the leak of kernel memory in xfs_dir2_node_removename()
> when xfs_dir2_leafn_remove() returns an error code.
>
> Signed-off-by: Mark Tinguely <tinguely@sgi.com>
Looks good.
Reviewed-by: Ben Myers <bpm@sgi.com>
_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v3] xfs: fix memory leak in xfs_dir2_node_removename
2013-12-04 21:00 ` Ben Myers
@ 2013-12-05 22:47 ` Ben Myers
0 siblings, 0 replies; 3+ messages in thread
From: Ben Myers @ 2013-12-05 22:47 UTC (permalink / raw)
To: Mark Tinguely, Rich Johnston; +Cc: xfs
On Wed, Dec 04, 2013 at 03:00:14PM -0600, Ben Myers wrote:
> On Sat, Oct 05, 2013 at 09:48:25PM -0500, Mark Tinguely wrote:
> > Fix the leak of kernel memory in xfs_dir2_node_removename()
> > when xfs_dir2_leafn_remove() returns an error code.
> >
> > Signed-off-by: Mark Tinguely <tinguely@sgi.com>
>
> Looks good.
>
> Reviewed-by: Ben Myers <bpm@sgi.com>
Applied this one. Rich, I think there are xfsprogs bits to go with.
_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2013-12-05 22:47 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-06 2:48 [PATCH v3] xfs: fix memory leak in xfs_dir2_node_removename Mark Tinguely
2013-12-04 21:00 ` Ben Myers
2013-12-05 22:47 ` Ben Myers
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox