- ext4_warning(dir->i_sb, __func__,
- "dx entry: limit != root limit");
-@@ -617,7 +627,7 @@ static int htree_dirblock_to_tree(struct
+ ext4_warning(dir->i_sb, "dx entry: limit != root limit");
+ brelse(bh);
+@@ -480,14 +490,17 @@ dx_probe(const struct qstr *d_name, stru
+ if (!indirect--) return frame;
+ if (!(bh = ext4_bread (NULL,dir, dx_get_block(at), 0, err)))
+ goto fail2;
+- at = entries = ((struct dx_node *) bh->b_data)->entries;
++ entries = ((struct dx_node *) bh->b_data)->entries;
+ if (dx_get_limit(entries) != dx_node_limit (dir)) {
+ ext4_warning(dir->i_sb,
+- "dx entry: limit != node limit");
++ "block %u(%lu): limit %u != node limit %u",
++ dx_get_block(at), (long)bh->b_blocknr,
++ dx_get_limit(entries), dx_node_limit(dir));
+ brelse(bh);
+ *err = ERR_BAD_DX_DIR;
+ goto fail2;
+ }
++ at = entries;
+ frame++;
+ frame->bh = NULL;
+ }
+@@ -613,7 +626,7 @@ static int htree_dirblock_to_tree(struct