public inbox for linux-xfs@vger.kernel.org
 help / color / mirror / Atom feed
* [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