On 18-11-05 13:19:50, Alexander Duyck wrote: > This patch is going through and combining the bits in memmap_init_zone and > memmap_init_zone_device that are related to hotplug into a single function > called __memmap_init_hotplug. > > I also took the opportunity to integrate __init_single_page's functionality > into this function. In doing so I can get rid of some of the redundancy > such as the LRU pointers versus the pgmap. Please don't do it, __init_single_page() is hard function to optimize, do not copy its code. Instead could you you split __init_single_page() in two parts, something like this: static inline init_single_page_nolru(struct page *page, unsigned long pfn, unsigned long zone, int nid) { mm_zero_struct_page(page); set_page_links(page, zone, nid, pfn); init_page_count(page); page_mapcount_reset(page); page_cpupid_reset_last(page); #ifdef WANT_PAGE_VIRTUAL /* The shift won't overflow because ZONE_NORMAL is below 4G. */ if (!is_highmem_idx(zone)) set_page_address(page, __va(pfn << PAGE_SHIFT)); #endif } static void __meminit init_single_page(struct page *page, unsigned long pfn, unsigned long zone, int nid) { init_single_page_nolru(page, pfn, zone, nid); INIT_LIST_HEAD(&page->lru); } And call init_single_page_nolru() from __init_pageblock() ? Also, remove WANT_PAGE_VIRTUAL optimization, I do not think it worse it. The rest looks very good, please do the above change. Reviewed-by: Pavel Tatashin <pasha.tatashin@xxxxxxxxxx> > > Signed-off-by: Alexander Duyck <alexander.h.duyck@xxxxxxxxxxxxxxx> > ---