The vmap_to_page macro (three levels deep!) can come up with
a NULL pointer. Lets add the proper ASSERT to catch this errant
behavior.
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
ASSERT(pages);
for ( i = 0; i < pages; i++ )
- page_list_add(vmap_to_page(va + i * PAGE_SIZE), &pg_list);
+ {
+ struct page_info *page = vmap_to_page(va + i * PAGE_SIZE);
+ ASSERT(page);
+ page_list_add(page, &pg_list);
+ }
vunmap(va);
while ( (pg = page_list_remove_head(&pg_list)) != NULL )