Clean up hugetlb boot time printk - Reword sentence to clarify meaning with multiple options - Add support for using GB prefixes for the page size - Add extra printk to delayed > MAX_ORDER allocation code Signed-off-by: Andi Kleen --- mm/hugetlb.c | 33 ++++++++++++++++++++++++++++++--- 1 file changed, 30 insertions(+), 3 deletions(-) Index: linux/mm/hugetlb.c =================================================================== --- linux.orig/mm/hugetlb.c +++ linux/mm/hugetlb.c @@ -512,6 +512,15 @@ static struct page *alloc_huge_page(stru return page; } +static __init char *memfmt(char *buf, unsigned long n) +{ + if (n >= (1UL << 30)) + sprintf(buf, "%lu GB", n >> 30); + else + sprintf(buf, "%lu MB", n >> 20); + return buf; +} + static __initdata LIST_HEAD(huge_boot_pages); struct huge_bm_page { @@ -538,14 +547,28 @@ static int __init alloc_bm_huge_page(str /* Put bootmem huge pages into the standard lists after mem_map is up */ static int __init huge_init_bm(void) { + unsigned long pages = 0; struct huge_bm_page *m; + struct hstate *h = NULL; + char buf[32]; + list_for_each_entry (m, &huge_boot_pages, list) { struct page *page = virt_to_page(m); - struct hstate *h = m->hstate; + h = m->hstate; __ClearPageReserved(page); prep_compound_page(page, h->order); huge_new_page(h, page); + pages++; } + + /* + * This only prints for a single hstate. This works for x86-64, + * but if you do multiple > MAX_ORDER hstates you'll need to fix it. + */ + if (pages > 0) + printk(KERN_INFO "HugeTLB pre-allocated %ld %s pages\n", + h->free_huge_pages, + memfmt(buf, huge_page_size(h))); return 0; } __initcall(huge_init_bm); @@ -553,6 +576,8 @@ __initcall(huge_init_bm); static int __init hugetlb_init_hstate(struct hstate *h) { unsigned long i; + char buf[32]; + unsigned long pages = 0; if (h == &global_hstate && !h->order) { h->order = HPAGE_SHIFT - PAGE_SHIFT; @@ -574,12 +599,14 @@ static int __init hugetlb_init_hstate(st } else if (!alloc_fresh_huge_page(h)) break; h->parsed_hugepages++; + pages++; } max_huge_pages[h - hstates] = h->parsed_hugepages; - printk(KERN_INFO "Total HugeTLB memory allocated, %ld %dMB pages\n", + if (pages > 0) + printk(KERN_INFO "HugeTLB pre-allocated %ld %s pages\n", h->free_huge_pages, - 1 << (h->order + PAGE_SHIFT - 20)); + memfmt(buf, huge_page_size(h))); return 0; }