staging: vchiq_2835_arm: Fix NULL ptr dereference in free_pagelist
This fixes a NULL pointer dereference on RPi 2 with multi_v7_defconfig.
The function page_address() could return NULL with enabled CONFIG_HIGHMEM.
So fix this by using kmap() instead.
Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com>
Fixes: 71bad7f086
("staging: add bcm2708 vchiq driver")
Cc: stable <stable@vger.kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
e5f5d0e20b
commit
974d4d03fc
@ -612,18 +612,20 @@ free_pagelist(struct vchiq_pagelist_info *pagelistinfo,
|
|||||||
if (head_bytes > actual)
|
if (head_bytes > actual)
|
||||||
head_bytes = actual;
|
head_bytes = actual;
|
||||||
|
|
||||||
memcpy((char *)page_address(pages[0]) +
|
memcpy((char *)kmap(pages[0]) +
|
||||||
pagelist->offset,
|
pagelist->offset,
|
||||||
fragments,
|
fragments,
|
||||||
head_bytes);
|
head_bytes);
|
||||||
|
kunmap(pages[0]);
|
||||||
}
|
}
|
||||||
if ((actual >= 0) && (head_bytes < actual) &&
|
if ((actual >= 0) && (head_bytes < actual) &&
|
||||||
(tail_bytes != 0)) {
|
(tail_bytes != 0)) {
|
||||||
memcpy((char *)page_address(pages[num_pages - 1]) +
|
memcpy((char *)kmap(pages[num_pages - 1]) +
|
||||||
((pagelist->offset + actual) &
|
((pagelist->offset + actual) &
|
||||||
(PAGE_SIZE - 1) & ~(g_cache_line_size - 1)),
|
(PAGE_SIZE - 1) & ~(g_cache_line_size - 1)),
|
||||||
fragments + g_cache_line_size,
|
fragments + g_cache_line_size,
|
||||||
tail_bytes);
|
tail_bytes);
|
||||||
|
kunmap(pages[num_pages - 1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
down(&g_free_fragments_mutex);
|
down(&g_free_fragments_mutex);
|
||||||
|
Loading…
Reference in New Issue
Block a user