diff options
author | Vasily Gorbik <gor@linux.ibm.com> | 2019-08-19 23:19:00 +0200 |
---|---|---|
committer | Vasily Gorbik <gor@linux.ibm.com> | 2019-08-26 12:51:18 +0200 |
commit | 759d4899d905c2a491d34987366421aebca359de (patch) | |
tree | 24a348f45afcab6e90b02c6c42f6482562a7dd3f /arch/s390/purgatory | |
parent | s390/mem_detect: provide single get_mem_detect_end (diff) | |
download | linux-759d4899d905c2a491d34987366421aebca359de.tar.xz linux-759d4899d905c2a491d34987366421aebca359de.zip |
s390/kaslr: reserve memory for kasan usage
Sometimes the kernel fails to boot with:
"The Linux kernel failed to boot with the KernelAddressSanitizer:
out of memory during initialisation" even with big amounts of memory when
both kaslr and kasan are enabled.
The problem is that kasan initialization code requires 1/8 of physical
memory plus some for page tables. To keep as much code instrumented
as possible kasan avoids using memblock for memory allocations. Instead
kasan uses trivial memory allocator which simply chops off the memory
from the end of online physical memory. For that reason when kaslr is
enabled together with kasan avoid positioning kernel into upper memory
region which would be utilized during kasan initialization.
Reviewed-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
Diffstat (limited to 'arch/s390/purgatory')
0 files changed, 0 insertions, 0 deletions