mm/memory_hotplug: shrink zones when offlining memory
stable inclusion from linux-4.19.100 commit 86834898d5a5e5aef9ae6d285201f2d99a4eb300 -------------------------------- commit feee6b29 upstream. -- snip -- - Missing arm64 hot(un)plug support - Missing some vmem_altmap_offset() cleanups - Missing sub-section hotadd support - Missing unification of mm/hmm.c and kernel/memremap.c -- snip -- We currently try to shrink a single zone when removing memory. We use the zone of the first page of the memory we are removing. If that memmap was never initialized (e.g., memory was never onlined), we will read garbage and can trigger kernel BUGs (due to a stale pointer): BUG: unable to handle page fault for address: 000000000000353d #PF: supervisor write access in kernel mode #PF: error_code(0x0002) - not-present page PGD 0 P4D 0 Oops: 0002 [#1] SMP PTI CPU: 1 PID: 7 Comm: kworker/u8:0 Not tainted 5.3.0-rc5-next-20190820+ #317 Hardware name: QEMU St...
Showing
- arch/arm64/mm/mmu.c 1 addition, 3 deletionsarch/arm64/mm/mmu.c
- arch/ia64/mm/init.c 1 addition, 3 deletionsarch/ia64/mm/init.c
- arch/powerpc/mm/mem.c 1 addition, 10 deletionsarch/powerpc/mm/mem.c
- arch/s390/mm/init.c 1 addition, 3 deletionsarch/s390/mm/init.c
- arch/sh/mm/init.c 1 addition, 3 deletionsarch/sh/mm/init.c
- arch/x86/mm/init_32.c 1 addition, 3 deletionsarch/x86/mm/init_32.c
- arch/x86/mm/init_64.c 1 addition, 7 deletionsarch/x86/mm/init_64.c
- include/linux/memory_hotplug.h 5 additions, 2 deletionsinclude/linux/memory_hotplug.h
- kernel/memremap.c 1 addition, 2 deletionskernel/memremap.c
- mm/hmm.c 1 addition, 3 deletionsmm/hmm.c
- mm/memory_hotplug.c 14 additions, 15 deletionsmm/memory_hotplug.c
Please register or sign in to comment