Page MenuHomeFreeBSD

riscv: Remove unnecessary invalidations in pmap_enter_quick_locked()
ClosedPublic

Authored by markj on Oct 19 2023, 1:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 30 2024, 11:53 AM
Unknown Object (File)
Nov 30 2024, 11:39 AM
Unknown Object (File)
Nov 25 2024, 10:08 PM
Unknown Object (File)
Nov 25 2024, 6:33 AM
Unknown Object (File)
Nov 24 2024, 5:14 PM
Unknown Object (File)
Nov 22 2024, 6:49 AM
Unknown Object (File)
Nov 20 2024, 3:00 AM
Unknown Object (File)
Nov 19 2024, 1:43 PM
Subscribers

Details

Summary

This function always overwrites an invalid PTE, so if
pmap_try_insert_pv_entry() fails it is certainly not necessary to
invalidate anything, because the PTE has not yet been written by that
point.

It should also not be necessary to invalidate TLBs after overwriting an
invalid entry. In principle the TLB could cache negative entries, but
then the worst case scenario is a spurious fault. Since pmap_enter()
does not bother issuing an sfence.vma, pmap_enter_quick_locked() should
behave similarly.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

markj requested review of this revision.Oct 19 2023, 1:08 PM

So RISC-V can cache -ve PTEs?

kib added inline comments.
sys/riscv/riscv/pmap.c
3463

BTW, return (NULL) there would be more clear

3476

And there

This revision is now accepted and ready to land.Oct 20 2023, 5:14 PM
In D42291#965582, @kib wrote:

So RISC-V can cache -ve PTEs?

Yes, and the spec explicitly calls this out.

markj marked 2 inline comments as done.

Simplify some return paths.

This revision now requires review to proceed.Oct 20 2023, 5:44 PM
This revision is now accepted and ready to land.Oct 20 2023, 5:49 PM