diff options
| author | Andrew Price <[email protected]> | 2025-07-16 13:12:07 +0000 |
|---|---|---|
| committer | Andreas Gruenbacher <[email protected]> | 2025-07-16 13:26:44 +0000 |
| commit | 557c024ca7250bb65ae60f16c02074106c2f197b (patch) | |
| tree | 222038b5225f47c4d318058a0530efb2b2076525 /drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c | |
| parent | gfs2: Set .migrate_folio in gfs2_{rgrp,meta}_aops (diff) | |
| download | kernel-557c024ca7250bb65ae60f16c02074106c2f197b.tar.gz kernel-557c024ca7250bb65ae60f16c02074106c2f197b.zip | |
gfs2: Validate i_depth for exhash directories
A fuzzer test introduced corruption that ends up with a depth of 0 in
dir_e_read(), causing an undefined shift by 32 at:
index = hash >> (32 - dip->i_depth);
As calculated in an open-coded way in dir_make_exhash(), the minimum
depth for an exhash directory is ilog2(sdp->sd_hash_ptrs) and 0 is
invalid as sdp->sd_hash_ptrs is fixed as sdp->bsize / 16 at mount time.
So we can avoid the undefined behaviour by checking for depth values
lower than the minimum in gfs2_dinode_in(). Values greater than the
maximum are already being checked for there.
Also switch the calculation in dir_make_exhash() to use ilog2() to
clarify how the depth is calculated.
Tested with the syzkaller repro.c and xfstests '-g quick'.
Reported-by: [email protected]
Signed-off-by: Andrew Price <[email protected]>
Signed-off-by: Andreas Gruenbacher <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c')
0 files changed, 0 insertions, 0 deletions
