diff options
author | Björn Töpel <[email protected]> | 2023-05-31 11:38:17 +0200 |
---|---|---|
committer | Palmer Dabbelt <[email protected]> | 2023-06-19 17:58:01 -0700 |
commit | 7d3332be011e4ed061c1403b30b5e54ebccb4fa2 (patch) | |
tree | 5ea66abc64191a329eeb7ed89ae4826c7c2b1a83 /scripts/rustdoc_test_builder.rs | |
parent | 16252e018a30486eedcfec81fc313445cac25bea (diff) |
riscv: mm: Pre-allocate PGD entries for vmalloc/modules area
The RISC-V port requires that kernel PGD entries are to be
synchronized between MMs. This is done via the vmalloc_fault()
function, that simply copies the PGD entries from init_mm to the
faulting one.
Historically, faulting in PGD entries have been a source for both bugs
[1], and poor performance.
One way to get rid of vmalloc faults is by pre-allocating the PGD
entries. Pre-allocating the entries potientially wastes 64 * 4K (65 on
SV39). The pre-allocation function is pulled from Jörg Rödel's x86
work, with the addition of 3-level page tables (PMD allocations).
The pmd_alloc() function needs the ptlock cache to be initialized
(when split page locks is enabled), so the pre-allocation is done in a
RISC-V specific pgtable_cache_init() implementation.
Pre-allocate the kernel PGD entries for the vmalloc/modules area, but
only for 64b platforms.
Link: https://lore.kernel.org/lkml/[email protected]/ # [1]
Signed-off-by: Björn Töpel <[email protected]>
Reviewed-by: Alexandre Ghiti <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Palmer Dabbelt <[email protected]>
Diffstat (limited to 'scripts/rustdoc_test_builder.rs')
0 files changed, 0 insertions, 0 deletions