Commit 742f3c81 authored by Anton Ivanov's avatar Anton Ivanov Committed by Richard Weinberger

um: Optimize Flush TLB for force/fork case

When UML handles a fork the page tables need to be brought up
to date. That was done using brute force - full tlb flush.

This is actually unnecessary, because the mapped-in mappings are
all correct and the only mappings which need to be updated
after a flush are any unmaps (so that paging works) as well as
any pending protection changes.

This optimization squeezes out up to 3% from a full kernel rebuild
time under memory pressure.
Signed-off-by: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
parent 8892d854
...@@ -242,10 +242,11 @@ static inline int update_pte_range(pmd_t *pmd, unsigned long addr, ...@@ -242,10 +242,11 @@ static inline int update_pte_range(pmd_t *pmd, unsigned long addr,
prot = ((r ? UM_PROT_READ : 0) | (w ? UM_PROT_WRITE : 0) | prot = ((r ? UM_PROT_READ : 0) | (w ? UM_PROT_WRITE : 0) |
(x ? UM_PROT_EXEC : 0)); (x ? UM_PROT_EXEC : 0));
if (hvc->force || pte_newpage(*pte)) { if (hvc->force || pte_newpage(*pte)) {
if (pte_present(*pte)) if (pte_present(*pte)) {
ret = add_mmap(addr, pte_val(*pte) & PAGE_MASK, if (pte_newpage(*pte))
PAGE_SIZE, prot, hvc); ret = add_mmap(addr, pte_val(*pte) & PAGE_MASK,
else PAGE_SIZE, prot, hvc);
} else
ret = add_munmap(addr, PAGE_SIZE, hvc); ret = add_munmap(addr, PAGE_SIZE, hvc);
} else if (pte_newprot(*pte)) } else if (pte_newprot(*pte))
ret = add_mprotect(addr, PAGE_SIZE, prot, hvc); ret = add_mprotect(addr, PAGE_SIZE, prot, hvc);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment