diff options
| author | Pavel Tatashin <[email protected]> | 2017-08-18 15:16:05 -0700 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2017-08-18 15:32:01 -0700 | 
| commit | 3010f876500f9ba921afaeccec30c45ca6584dc8 (patch) | |
| tree | 61f656b6b3f56459f27cb11944102bf3dfcc162b /scripts/gdb/linux/cpus.py | |
| parent | 768dc4e48420955518974d8486c1b00ec05e7274 (diff) | |
mm: discard memblock data later
There is existing use after free bug when deferred struct pages are
enabled:
The memblock_add() allocates memory for the memory array if more than
128 entries are needed.  See comment in e820__memblock_setup():
  * The bootstrap memblock region count maximum is 128 entries
  * (INIT_MEMBLOCK_REGIONS), but EFI might pass us more E820 entries
  * than that - so allow memblock resizing.
This memblock memory is freed here:
        free_low_memory_core_early()
We access the freed memblock.memory later in boot when deferred pages
are initialized in this path:
        deferred_init_memmap()
                for_each_mem_pfn_range()
                  __next_mem_pfn_range()
                    type = &memblock.memory;
One possible explanation for why this use-after-free hasn't been hit
before is that the limit of INIT_MEMBLOCK_REGIONS has never been
exceeded at least on systems where deferred struct pages were enabled.
Tested by reducing INIT_MEMBLOCK_REGIONS down to 4 from the current 128,
and verifying in qemu that this code is getting excuted and that the
freed pages are sane.
Link: http://lkml.kernel.org/r/[email protected]
Fixes: 7e18adb4f80b ("mm: meminit: initialise remaining struct pages in parallel with kswapd")
Signed-off-by: Pavel Tatashin <[email protected]>
Reviewed-by: Steven Sistare <[email protected]>
Reviewed-by: Daniel Jordan <[email protected]>
Reviewed-by: Bob Picco <[email protected]>
Acked-by: Michal Hocko <[email protected]>
Cc: Mel Gorman <[email protected]>
Cc: <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/cpus.py')
0 files changed, 0 insertions, 0 deletions