> + for (i = 0 ; i < (1 << order) ; ++i)
> + reserved += free_pages_check(page + i);
> + if (reserved)
> + return 0;
> +
> + if (!PageHighMem(page)) {
> + debug_check_no_locks_freed(page_address(page),
> + PAGE_SIZE << order);
> + debug_check_no_obj_freed(page_address(page),
> + PAGE_SIZE << order);
> + }
> + arch_free_page(page, order);
> + kernel_map_pages(page, 1 << order, 0);
> +
> + return 1;
> +}
> +
> +/*
> * Frees a list of pages.
> * Assumes all pages on list are in same zone, and of same order.
> * count is the number of pages to free.
> @@ -529,22 +558,10 @@ static void free_one_page(struct zone *zone, struct page *page, int order)
> static void __free_pages_ok(struct page *page, unsigned int order)
> {
> unsigned long flags;
> - int i;
> - int reserved = 0;
>
> - for (i = 0 ; i < (1 << order) ; ++i)
> - reserved += free_pages_check(page + i);
> - if (reserved)
> + if (!free_page_prepare(page, order))
> return;
>
> - if (!PageHighMem(page)) {
> - debug_check_no_locks_freed(page_address(page),PAGE_SIZE<<order);
> - debug_check_no_obj_freed(page_address(page),
> - PAGE_SIZE << order);
> - }
> - arch_free_page(page, order);
> - kernel_map_pages(page, 1 << order, 0);
> -
> local_irq_save(flags);
> __count_vm_events(PGFREE, 1 << order);
> free_one_page(page_zone(page), page, order);
> --
> 1.6.0.rc1.258.g80295
>
> --
> To unsubscribe, send a message with 'unsubscribe linux-mm' in
> the body to
majordomo@kvack.org. For more info on Linux MM,
> see:
http://www.linux-mm.org/ .
> Don't email: <a href=mailto:"dont@kvack.org">
email@kvack.org </a>
>