diff options
author | Rui Teng <rui.teng@linux.vnet.ibm.com> | 2017-01-12 10:09:06 +0100 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2017-07-31 08:56:58 +0200 |
commit | 23493c121912a39f0262e0dbeb236e1d39efa4d5 (patch) | |
tree | 41e43bb1f8cbde6d9f83abc5edc2792a3de30b01 | |
parent | powerpc/udbg: Reduce the footgun potential of EARLY_DEBUG_LPAR(_HVSI) (diff) | |
download | linux-23493c121912a39f0262e0dbeb236e1d39efa4d5.tar.xz linux-23493c121912a39f0262e0dbeb236e1d39efa4d5.zip |
powerpc/mm: Fix check of multiple 16G pages from device tree
The offset of hugepage block will not be 16G, if the expected
page is more than one. Calculate the totol size instead of the
hardcode value.
Fixes: 4792adbac9eb ("powerpc: Don't use a 16G page if beyond mem= limits")
Signed-off-by: Rui Teng <rui.teng@linux.vnet.ibm.com>
Tested-by: Anshuman Khandual <khandual@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
-rw-r--r-- | arch/powerpc/mm/hash_utils_64.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/powerpc/mm/hash_utils_64.c b/arch/powerpc/mm/hash_utils_64.c index 7a20669c19e7..7419fc1854ad 100644 --- a/arch/powerpc/mm/hash_utils_64.c +++ b/arch/powerpc/mm/hash_utils_64.c @@ -507,7 +507,7 @@ static int __init htab_dt_scan_hugepage_blocks(unsigned long node, printk(KERN_INFO "Huge page(16GB) memory: " "addr = 0x%lX size = 0x%lX pages = %d\n", phys_addr, block_size, expected_pages); - if (phys_addr + (16 * GB) <= memblock_end_of_DRAM()) { + if (phys_addr + block_size * expected_pages <= memblock_end_of_DRAM()) { memblock_reserve(phys_addr, block_size * expected_pages); add_gpage(phys_addr, block_size, expected_pages); } |