diff options
Diffstat (limited to 'fs/ext4/dir.c')
| -rw-r--r-- | fs/ext4/dir.c | 38 | 
1 files changed, 6 insertions, 32 deletions
diff --git a/fs/ext4/dir.c b/fs/ext4/dir.c index 680bb338891..ef1bed66c14 100644 --- a/fs/ext4/dir.c +++ b/fs/ext4/dir.c @@ -105,7 +105,7 @@ int __ext4_check_dir_entry(const char *function, unsigned int line,  static int ext4_readdir(struct file *file, struct dir_context *ctx)  {  	unsigned int offset; -	int i, stored; +	int i;  	struct ext4_dir_entry_2 *de;  	int err;  	struct inode *inode = file_inode(file); @@ -133,7 +133,6 @@ static int ext4_readdir(struct file *file, struct dir_context *ctx)  			return ret;  	} -	stored = 0;  	offset = ctx->pos & (sb->s_blocksize - 1);  	while (ctx->pos < inode->i_size) { @@ -353,41 +352,16 @@ struct fname {   */  static void free_rb_tree_fname(struct rb_root *root)  { -	struct rb_node	*n = root->rb_node; -	struct rb_node	*parent; -	struct fname	*fname; - -	while (n) { -		/* Do the node's children first */ -		if (n->rb_left) { -			n = n->rb_left; -			continue; -		} -		if (n->rb_right) { -			n = n->rb_right; -			continue; -		} -		/* -		 * The node has no children; free it, and then zero -		 * out parent's link to it.  Finally go to the -		 * beginning of the loop and try to free the parent -		 * node. -		 */ -		parent = rb_parent(n); -		fname = rb_entry(n, struct fname, rb_hash); +	struct fname *fname, *next; + +	rbtree_postorder_for_each_entry_safe(fname, next, root, rb_hash)  		while (fname) {  			struct fname *old = fname;  			fname = fname->next;  			kfree(old);  		} -		if (!parent) -			*root = RB_ROOT; -		else if (parent->rb_left == n) -			parent->rb_left = NULL; -		else if (parent->rb_right == n) -			parent->rb_right = NULL; -		n = parent; -	} + +	*root = RB_ROOT;  }  | 
