提交 28d4bf7a 编写于 作者: C Cyril Chemparathy 提交者: Will Deacon

ARM: mm: clean up membank size limit checks

This patch cleans up the highmem sanity check code by simplifying the range
checks with a pre-calculated size_limit.  This patch should otherwise have no
functional impact on behavior.

This patch also removes a redundant (bank->start < vmalloc_limit) check, since
this is already covered by the !highmem condition.
Signed-off-by: NCyril Chemparathy <cyril@ti.com>
Signed-off-by: NVitaly Andrianov <vitalya@ti.com>
Acked-by: NNicolas Pitre <nico@linaro.org>
Tested-by: NSantosh Shilimkar <santosh.shilimkar@ti.com>
Tested-by: NSubash Patel <subash.rp@samsung.com>
Signed-off-by: NWill Deacon <will.deacon@arm.com>
上级 adf2e9fd
...@@ -992,10 +992,15 @@ void __init sanity_check_meminfo(void) ...@@ -992,10 +992,15 @@ void __init sanity_check_meminfo(void)
for (i = 0, j = 0; i < meminfo.nr_banks; i++) { for (i = 0, j = 0; i < meminfo.nr_banks; i++) {
struct membank *bank = &meminfo.bank[j]; struct membank *bank = &meminfo.bank[j];
phys_addr_t size_limit;
*bank = meminfo.bank[i]; *bank = meminfo.bank[i];
size_limit = bank->size;
if (bank->start >= vmalloc_limit) if (bank->start >= vmalloc_limit)
highmem = 1; highmem = 1;
else
size_limit = vmalloc_limit - bank->start;
bank->highmem = highmem; bank->highmem = highmem;
...@@ -1004,8 +1009,7 @@ void __init sanity_check_meminfo(void) ...@@ -1004,8 +1009,7 @@ void __init sanity_check_meminfo(void)
* Split those memory banks which are partially overlapping * Split those memory banks which are partially overlapping
* the vmalloc area greatly simplifying things later. * the vmalloc area greatly simplifying things later.
*/ */
if (!highmem && bank->start < vmalloc_limit && if (!highmem && bank->size > size_limit) {
bank->size > vmalloc_limit - bank->start) {
if (meminfo.nr_banks >= NR_BANKS) { if (meminfo.nr_banks >= NR_BANKS) {
printk(KERN_CRIT "NR_BANKS too low, " printk(KERN_CRIT "NR_BANKS too low, "
"ignoring high memory\n"); "ignoring high memory\n");
...@@ -1014,12 +1018,12 @@ void __init sanity_check_meminfo(void) ...@@ -1014,12 +1018,12 @@ void __init sanity_check_meminfo(void)
(meminfo.nr_banks - i) * sizeof(*bank)); (meminfo.nr_banks - i) * sizeof(*bank));
meminfo.nr_banks++; meminfo.nr_banks++;
i++; i++;
bank[1].size -= vmalloc_limit - bank->start; bank[1].size -= size_limit;
bank[1].start = vmalloc_limit; bank[1].start = vmalloc_limit;
bank[1].highmem = highmem = 1; bank[1].highmem = highmem = 1;
j++; j++;
} }
bank->size = vmalloc_limit - bank->start; bank->size = size_limit;
} }
#else #else
/* /*
...@@ -1037,14 +1041,13 @@ void __init sanity_check_meminfo(void) ...@@ -1037,14 +1041,13 @@ void __init sanity_check_meminfo(void)
* Check whether this memory bank would partially overlap * Check whether this memory bank would partially overlap
* the vmalloc area. * the vmalloc area.
*/ */
if (bank->start + bank->size > vmalloc_limit) if (bank->size > size_limit) {
unsigned long newsize = vmalloc_limit - bank->start;
printk(KERN_NOTICE "Truncating RAM at %.8llx-%.8llx " printk(KERN_NOTICE "Truncating RAM at %.8llx-%.8llx "
"to -%.8llx (vmalloc region overlap).\n", "to -%.8llx (vmalloc region overlap).\n",
(unsigned long long)bank->start, (unsigned long long)bank->start,
(unsigned long long)bank->start + bank->size - 1, (unsigned long long)bank->start + bank->size - 1,
(unsigned long long)bank->start + newsize - 1); (unsigned long long)bank->start + size_limit - 1);
bank->size = newsize; bank->size = size_limit;
} }
#endif #endif
if (!bank->highmem && bank->start + bank->size > arm_lowmem_limit) if (!bank->highmem && bank->start + bank->size > arm_lowmem_limit)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册