riscv: Support allocating gigantic hugepages using CMA
authorKefeng Wang <wangkefeng.wang@huawei.com>
Fri, 30 Jul 2021 12:48:41 +0000 (20:48 +0800)
committerPalmer Dabbelt <palmerdabbelt@google.com>
Sat, 14 Aug 2021 04:33:54 +0000 (21:33 -0700)
This patch adds support to allocate gigantic hugepages using CMA by
specifying the hugetlb_cma= kernel parameter.  This is only supported on
RV64.

Reviewed-by: Alexandre Ghiti <alex@ghiti.fr>
Signed-off-by: Kefeng Wang <wangkefeng.wang@huawei.com>
Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
arch/riscv/mm/init.c

index 888dff9530b8f7ef6ba0dfe51327aaf8d2070660..248f9ec393c12aa5845bdaed9aaae700e8642dc9 100644 (file)
@@ -19,6 +19,7 @@
 #include <linux/set_memory.h>
 #include <linux/dma-map-ops.h>
 #include <linux/crash_dump.h>
+#include <linux/hugetlb.h>
 
 #include <asm/fixmap.h>
 #include <asm/tlbflush.h>
@@ -202,6 +203,8 @@ static void __init setup_bootmem(void)
 
        early_init_fdt_scan_reserved_mem();
        dma_contiguous_reserve(dma32_phys_limit);
+       if (IS_ENABLED(CONFIG_64BIT))
+               hugetlb_cma_reserve(PUD_SHIFT - PAGE_SHIFT);
        memblock_allow_resize();
 }