diff options
| author | Takashi Iwai <[email protected]> | 2022-12-22 09:11:48 +0100 | 
|---|---|---|
| committer | Takashi Iwai <[email protected]> | 2022-12-22 09:11:48 +0100 | 
| commit | 2d78eb0342dd2c9c5cde9ae9ada1d33f189a858b (patch) | |
| tree | f711bc9cab45f4963e4883ef15ff4c54a6cbc12e /fs/xfs/libxfs/xfs_dir2_leaf.c | |
| parent | b47068b4aa53a57552398e3f60d0ed1918700c2b (diff) | |
| parent | ee0b089d660021792e4ab4dda191b097ce1e964f (diff) | |
Merge branch 'for-next' into for-linus
Diffstat (limited to 'fs/xfs/libxfs/xfs_dir2_leaf.c')
| -rw-r--r-- | fs/xfs/libxfs/xfs_dir2_leaf.c | 9 | 
1 files changed, 7 insertions, 2 deletions
| diff --git a/fs/xfs/libxfs/xfs_dir2_leaf.c b/fs/xfs/libxfs/xfs_dir2_leaf.c index d9b66306a9a7..cb9e950a911d 100644 --- a/fs/xfs/libxfs/xfs_dir2_leaf.c +++ b/fs/xfs/libxfs/xfs_dir2_leaf.c @@ -146,6 +146,8 @@ xfs_dir3_leaf_check_int(  	xfs_dir2_leaf_tail_t		*ltp;  	int				stale;  	int				i; +	bool				isleaf1 = (hdr->magic == XFS_DIR2_LEAF1_MAGIC || +						   hdr->magic == XFS_DIR3_LEAF1_MAGIC);  	ltp = xfs_dir2_leaf_tail_p(geo, leaf); @@ -158,8 +160,7 @@ xfs_dir3_leaf_check_int(  		return __this_address;  	/* Leaves and bests don't overlap in leaf format. */ -	if ((hdr->magic == XFS_DIR2_LEAF1_MAGIC || -	     hdr->magic == XFS_DIR3_LEAF1_MAGIC) && +	if (isleaf1 &&  	    (char *)&hdr->ents[hdr->count] > (char *)xfs_dir2_leaf_bests_p(ltp))  		return __this_address; @@ -175,6 +176,10 @@ xfs_dir3_leaf_check_int(  		}  		if (hdr->ents[i].address == cpu_to_be32(XFS_DIR2_NULL_DATAPTR))  			stale++; +		if (isleaf1 && xfs_dir2_dataptr_to_db(geo, +				be32_to_cpu(hdr->ents[i].address)) >= +				be32_to_cpu(ltp->bestcount)) +			return __this_address;  	}  	if (hdr->stale != stale)  		return __this_address; |