diff options
| author | Anders Roxell <[email protected]> | 2025-08-30 09:49:53 +0000 |
|---|---|---|
| committer | Vinod Koul <[email protected]> | 2025-09-02 06:35:18 +0000 |
| commit | e63419dbf2ceb083c1651852209c7f048089ac0f (patch) | |
| tree | 2603a651e81a13d3e7320ebfe7c0170f50058779 /drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c | |
| parent | dmaengine: idxd: Fix double free in idxd_setup_wqs() (diff) | |
| download | kernel-e63419dbf2ceb083c1651852209c7f048089ac0f.tar.gz kernel-e63419dbf2ceb083c1651852209c7f048089ac0f.zip | |
dmaengine: ti: edma: Fix memory allocation size for queue_priority_map
Fix a critical memory allocation bug in edma_setup_from_hw() where
queue_priority_map was allocated with insufficient memory. The code
declared queue_priority_map as s8 (*)[2] (pointer to array of 2 s8),
but allocated memory using sizeof(s8) instead of the correct size.
This caused out-of-bounds memory writes when accessing:
queue_priority_map[i][0] = i;
queue_priority_map[i][1] = i;
The bug manifested as kernel crashes with "Oops - undefined instruction"
on ARM platforms (BeagleBoard-X15) during EDMA driver probe, as the
memory corruption triggered kernel hardening features on Clang.
Change the allocation to use sizeof(*queue_priority_map) which
automatically gets the correct size for the 2D array structure.
Fixes: 2b6b3b742019 ("ARM/dmaengine: edma: Merge the two drivers under drivers/dma/")
Signed-off-by: Anders Roxell <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Vinod Koul <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c')
0 files changed, 0 insertions, 0 deletions
