Page MenuHomeFreeBSD

Add the netdump mbuf allocator.
ClosedPublic

Authored by markj on May 1 2018, 5:21 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 8:32 PM
Unknown Object (File)
Sun, Jan 5, 8:38 AM
Unknown Object (File)
Mon, Dec 30, 6:07 PM
Unknown Object (File)
Sun, Dec 29, 5:37 PM
Unknown Object (File)
Sat, Dec 28, 5:11 PM
Unknown Object (File)
Fri, Dec 27, 5:58 PM
Unknown Object (File)
Dec 5 2024, 7:06 PM
Unknown Object (File)
Nov 29 2024, 2:56 PM

Details

Summary

The aim here is to permit mbuf allocations after a panic without
calling into the page allocator, without imposing any runtime overhead
during regular operation of the system, and without modifying driver
code. The approach taken is to pre-allocate a number of mbufs and
clusters, storing them in linked lists. The lists back a set of UMA
cache zones which replace the regular mbuf/cluster UMA zones. At panic
time, the zone pointers are overwritten with those of the cache zones,
so m_get() and so on return mbufs from the linked lists.

The main complication is that a few drivers (cxgb and iflib) cache mbuf
zone pointers from m_getzone(), so they need some special handling.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 16436
Build 16355: arc lint + arc unit

Event Timeline

This revision is now accepted and ready to land.May 1 2018, 8:52 PM
emaste added inline comments.
sys/kern/kern_mbuf.c
879

just commit these independently first?

julian added inline comments.
sys/kern/kern_mbuf.c
383

how about a big comment here separating this code from 'regular code' so that the casual reader can instantly know what is going on.

know it's ifdef'd but take the message in this review and make it a comment.

496

in some cases it has been known to dump memory and then keep running.
do you have a way to 'un-overwrite' the zone pointers?

sys/kern/kern_mbuf.c
383

netdump_mbuf_reinit() already has a similar comment; I'll move it.

496

Not at the moment. I will look into the difficulty of getting that to work.

879

Yeah, didn't mean to include these.

This revision now requires review to proceed.May 4 2018, 7:53 PM
markj marked an inline comment as done.May 4 2018, 7:56 PM
markj added inline comments.
sys/kern/kern_mbuf.c
496

For the initial revision I plan to just return an error if one attempts to netdump while panicstr == NULL. From DDB one can execute "panic" to get a dump in that case. It may be possible for the system to resume operation after a netdump, but I don't think it's very straightforward, so I will punt on that for now.

This revision was not accepted when it landed; it landed in state Needs Review.May 6 2018, 12:20 AM
This revision was automatically updated to reflect the committed changes.