]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
memblock: fix memblock_estimated_nr_free_pages() for soft-reserved memory
authorAkinobu Mita <akinobu.mita@gmail.com>
Tue, 11 Nov 2025 01:00:10 +0000 (10:00 +0900)
committerMike Rapoport (Microsoft) <rppt@kernel.org>
Tue, 11 Nov 2025 16:15:35 +0000 (18:15 +0200)
memblock_estimated_nr_free_pages() returns the difference between the total
size of the "memory" memblock type and the "reserved" memblock type.

The "soft-reserved" memory regions are added to the "reserved" memblock
type, but not to the "memory" memblock type. Therefore,
memblock_estimated_nr_free_pages() may return a smaller value than
expected, or if it underflows, an extremely large value.

/proc/sys/kernel/threads-max is determined by the value of
memblock_estimated_nr_free_pages().  This issue was discovered on machines
with CXL memory because kernel.threads-max was either smaller than expected
or extremely large for the installed DRAM size.

This fixes the issue by replacing memblock_reserved_size() with
memblock_reserved_kern_size() that tells how much memory was
reserved from the actual RAM.

Suggested-by: Mike Rapoport <rppt@kernel.org>
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Link: https://patch.msgid.link/20251111010010.7800-1-akinobu.mita@gmail.com
Signed-off-by: Mike Rapoport (Microsoft) <rppt@kernel.org>
mm/memblock.c

index e23e16618e9b380dcdda80b0d198689b11014797..f0f2dc66e9a20c9a261f3440cd8d26c4d96ad4f6 100644 (file)
@@ -1826,7 +1826,8 @@ phys_addr_t __init_memblock memblock_reserved_kern_size(phys_addr_t limit, int n
  */
 unsigned long __init memblock_estimated_nr_free_pages(void)
 {
-       return PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
+       return PHYS_PFN(memblock_phys_mem_size() -
+                       memblock_reserved_kern_size(MEMBLOCK_ALLOC_ANYWHERE, NUMA_NO_NODE));
 }
 
 /* lowest address */