Skip to content

Commit 3a8c920

Browse files
Mark TinguelyBen Myers
authored andcommitted
xfs: fix memory leak in xfs_dir2_node_removename
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 <[email protected]> Reviewed-by: Ben Myers <[email protected]> Signed-off-by: Ben Myers <[email protected]> (cherry picked from commit ef70160)
1 parent f94c445 commit 3a8c920

File tree

1 file changed

+13
-13
lines changed

1 file changed

+13
-13
lines changed

fs/xfs/xfs_dir2_node.c

Lines changed: 13 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -2067,12 +2067,12 @@ xfs_dir2_node_lookup(
20672067
*/
20682068
int /* error */
20692069
xfs_dir2_node_removename(
2070-
xfs_da_args_t *args) /* operation arguments */
2070+
struct xfs_da_args *args) /* operation arguments */
20712071
{
2072-
xfs_da_state_blk_t *blk; /* leaf block */
2072+
struct xfs_da_state_blk *blk; /* leaf block */
20732073
int error; /* error return value */
20742074
int rval; /* operation return value */
2075-
xfs_da_state_t *state; /* btree cursor */
2075+
struct xfs_da_state *state; /* btree cursor */
20762076

20772077
trace_xfs_dir2_node_removename(args);
20782078

@@ -2084,19 +2084,18 @@ xfs_dir2_node_removename(
20842084
state->mp = args->dp->i_mount;
20852085
state->blocksize = state->mp->m_dirblksize;
20862086
state->node_ents = state->mp->m_dir_node_ents;
2087-
/*
2088-
* Look up the entry we're deleting, set up the cursor.
2089-
*/
2087+
2088+
/* Look up the entry we're deleting, set up the cursor. */
20902089
error = xfs_da3_node_lookup_int(state, &rval);
20912090
if (error)
2092-
rval = error;
2093-
/*
2094-
* Didn't find it, upper layer screwed up.
2095-
*/
2091+
goto out_free;
2092+
2093+
/* Didn't find it, upper layer screwed up. */
20962094
if (rval != EEXIST) {
2097-
xfs_da_state_free(state);
2098-
return rval;
2095+
error = rval;
2096+
goto out_free;
20992097
}
2098+
21002099
blk = &state->path.blk[state->path.active - 1];
21012100
ASSERT(blk->magic == XFS_DIR2_LEAFN_MAGIC);
21022101
ASSERT(state->extravalid);
@@ -2107,7 +2106,7 @@ xfs_dir2_node_removename(
21072106
error = xfs_dir2_leafn_remove(args, blk->bp, blk->index,
21082107
&state->extrablk, &rval);
21092108
if (error)
2110-
return error;
2109+
goto out_free;
21112110
/*
21122111
* Fix the hash values up the btree.
21132112
*/
@@ -2122,6 +2121,7 @@ xfs_dir2_node_removename(
21222121
*/
21232122
if (!error)
21242123
error = xfs_dir2_node_to_leaf(state);
2124+
out_free:
21252125
xfs_da_state_free(state);
21262126
return error;
21272127
}

0 commit comments

Comments
 (0)