mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 10:00:17 +00:00
drm/ttm: fix out-of-bounds read in ttm_put_pages() v2
commita66477b0efupstream. When ttm_put_pages() tries to figure out whether it's dealing with transparent hugepages, it just reads past the bounds of the pages array without a check. v2: simplify the test if enough pages are left in the array (Christian). Signed-off-by: Jann Horn <jannh@google.com> Signed-off-by: Christian König <christian.koenig@amd.com> Fixes:5c42c64f7d("drm/ttm: fix the fix for huge compound pages") Cc: stable@vger.kernel.org Reviewed-by: Michel Dänzer <michel.daenzer@amd.com> Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com> Reviewed-by: Huang Rui <ray.huang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
8223263d7c
commit
508b773175
@@ -730,7 +730,8 @@ static void ttm_put_pages(struct page **pages, unsigned npages, int flags,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
||||||
if (!(flags & TTM_PAGE_FLAG_DMA32)) {
|
if (!(flags & TTM_PAGE_FLAG_DMA32) &&
|
||||||
|
(npages - i) >= HPAGE_PMD_NR) {
|
||||||
for (j = 0; j < HPAGE_PMD_NR; ++j)
|
for (j = 0; j < HPAGE_PMD_NR; ++j)
|
||||||
if (p++ != pages[i + j])
|
if (p++ != pages[i + j])
|
||||||
break;
|
break;
|
||||||
@@ -759,7 +760,7 @@ static void ttm_put_pages(struct page **pages, unsigned npages, int flags,
|
|||||||
unsigned max_size, n2free;
|
unsigned max_size, n2free;
|
||||||
|
|
||||||
spin_lock_irqsave(&huge->lock, irq_flags);
|
spin_lock_irqsave(&huge->lock, irq_flags);
|
||||||
while (i < npages) {
|
while ((npages - i) >= HPAGE_PMD_NR) {
|
||||||
struct page *p = pages[i];
|
struct page *p = pages[i];
|
||||||
unsigned j;
|
unsigned j;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user