Page MenuHomeFreeBSD

vm_phys: Check for overlap when adding a segment
ClosedPublic

Authored by olce on Jan 23 2025, 5:15 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Oct 15, 10:37 PM
Unknown Object (File)
Sun, Oct 5, 12:26 PM
Unknown Object (File)
Sat, Oct 4, 5:42 AM
Unknown Object (File)
Thu, Sep 25, 12:00 AM
Unknown Object (File)
Aug 25 2025, 11:36 PM
Unknown Object (File)
Aug 22 2025, 6:16 PM
Unknown Object (File)
Aug 16 2025, 8:01 AM
Unknown Object (File)
Aug 14 2025, 10:37 PM
Subscribers

Details

Summary

Segments are passed by machine-dependent routines, so explicit checks
will make debugging much easier on very weird machines or when someone
is tweaking these machine-dependent routines. Additionally, this
operation is not performance-sensitive.

For the same reasons, test that we don't reach the maximum number of
physical segments (the compile-time of the internal storage) in
production kernel (replaces the existing KASSERT()).

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 61927
Build 58811: arc lint + arc unit

Event Timeline

olce requested review of this revision.Jan 23 2025, 5:15 PM
sys/vm/vm_phys.c
424

Why is this an assertion when the other check applies to non-INVARIANTS kernels?

439

Stray semicolon at the end of the message?

olce marked 2 inline comments as done.
olce edited the summary of this revision. (Show Details)

Cater to comments.

sys/vm/vm_phys.c
424

Nothing strong, I just felt less compelled to convert this check to a regular test+panic as the number of domains is registered once by machine-dependent code and then passed domains are either 0 or some index from a loop using vm_ndomains as bound.

Changed to a true panic.

This revision is now accepted and ready to land.Feb 18 2025, 8:03 PM