mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 21:35:07 +00:00
mm: usercopy: move the virt_addr_valid() below the is_vmalloc_addr()
The is_kmap_addr() and the is_vmalloc_addr() in the check_heap_object() will not work, because the virt_addr_valid() will exclude the kmap and vmalloc regions. So let's move the virt_addr_valid() below the is_vmalloc_addr(). Signed-off-by: Yuanzheng Song <songyuanzheng@huawei.com> Fixes: 4e140f59d285 ("mm/usercopy: Check kmap addresses properly") Fixes: 0aef499f3172 ("mm/usercopy: Detect vmalloc overruns") Cc: Matthew Wilcox (Oracle) <willy@infradead.org> Signed-off-by: Kees Cook <keescook@chromium.org> Link: https://lore.kernel.org/r/20220505071037.4121100-1-songyuanzheng@huawei.com
This commit is contained in:
parent
710e4ebfba
commit
a5f4d9df1f
@ -163,9 +163,6 @@ static inline void check_heap_object(const void *ptr, unsigned long n,
|
|||||||
{
|
{
|
||||||
struct folio *folio;
|
struct folio *folio;
|
||||||
|
|
||||||
if (!virt_addr_valid(ptr))
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (is_kmap_addr(ptr)) {
|
if (is_kmap_addr(ptr)) {
|
||||||
unsigned long page_end = (unsigned long)ptr | (PAGE_SIZE - 1);
|
unsigned long page_end = (unsigned long)ptr | (PAGE_SIZE - 1);
|
||||||
|
|
||||||
@ -190,6 +187,9 @@ static inline void check_heap_object(const void *ptr, unsigned long n,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!virt_addr_valid(ptr))
|
||||||
|
return;
|
||||||
|
|
||||||
folio = virt_to_folio(ptr);
|
folio = virt_to_folio(ptr);
|
||||||
|
|
||||||
if (folio_test_slab(folio)) {
|
if (folio_test_slab(folio)) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user