arm64: mm: Ensure we ignore the initrd if it is placed out of range
authorWill Deacon <will.deacon@arm.com>
Wed, 3 Apr 2019 16:58:39 +0000 (17:58 +0100)
committerWill Deacon <will.deacon@arm.com>
Wed, 3 Apr 2019 17:35:08 +0000 (18:35 +0100)
If the initrd payload isn't completely accessible via the linear map,
then we print a warning during boot and nobble the virtual address of
the payload so that we ignore it later on.

Unfortunately, since commit c756c592e442 ("arm64: Utilize
phys_initrd_start/phys_initrd_size"), the virtual address isn't
initialised until later anyway, so we need to nobble the size of the
payload to ensure that we don't try to use it later on.

Fixes: c756c592e442 ("arm64: Utilize phys_initrd_start/phys_initrd_size")
Reported-by: Pierre Kuo <vichy.kuo@gmail.com>
Acked-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
arch/arm64/mm/init.c

index 43fa75601b3d9dcf6a5246355c492ef22d5e135a..03a8a6888ec04fdf828c07556d0cc9213b0f1ce6 100644 (file)
@@ -377,7 +377,7 @@ void __init arm64_memblock_init(void)
                         base + size > memblock_start_of_DRAM() +
                                       linear_region_size,
                        "initrd not fully accessible via the linear mapping -- please check your bootloader ...\n")) {
-                       initrd_start = 0;
+                       phys_initrd_size = 0;
                } else {
                        memblock_remove(base, size); /* clear MEMBLOCK_ flags */
                        memblock_add(base, size);