s390/vmem: fix identity mapping
authorHeiko Carstens <heiko.carstens@de.ibm.com>
Tue, 10 May 2016 10:10:22 +0000 (12:10 +0200)
committerMartin Schwidefsky <schwidefsky@de.ibm.com>
Wed, 11 May 2016 08:20:30 +0000 (10:20 +0200)
The identity mapping is suboptimal for the last 2GB frame. The mapping
will be established with a mix of 4KB and 1MB mappings instead of a
single 2GB mapping.

This happens because of a off-by-one bug introduced with
commit 50be63450728 ("s390/mm: Convert bootmem to memblock").

Currently the identity mapping looks like this:

0x0000000080000000-0x0000000180000000        4G PUD RW
0x0000000180000000-0x00000001fff00000     2047M PMD RW
0x00000001fff00000-0x0000000200000000        1M PTE RW

With the bug fixed it looks like this:

0x0000000080000000-0x0000000200000000        6G PUD RW

Fixes: 50be63450728 ("s390/mm: Convert bootmem to memblock")
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
arch/s390/mm/vmem.c

index d27fccbad7c1e6a67af2d355c486c3b7016958e9..f7ad6cd38e3e6aa8b2edaf492f6ec90302573d2f 100644 (file)
@@ -370,7 +370,7 @@ void __init vmem_map_init(void)
        ro_end = (unsigned long)&_eshared & PAGE_MASK;
        for_each_memblock(memory, reg) {
                start = reg->base;
-               end = reg->base + reg->size - 1;
+               end = reg->base + reg->size;
                if (start >= ro_end || end <= ro_start)
                        vmem_add_mem(start, end - start, 0);
                else if (start >= ro_start && end <= ro_end)