Page MenuHomeFreeBSD

mbuf: Add M_WRITABLE_EXTPG
AcceptedPublic

Authored by jhb on Sep 25 2024, 3:13 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 4:50 AM
Unknown Object (File)
Sat, Jan 11, 4:50 AM
Unknown Object (File)
Sat, Jan 11, 12:45 AM
Unknown Object (File)
Nov 28 2024, 8:17 AM
Unknown Object (File)
Nov 24 2024, 2:19 AM
Unknown Object (File)
Nov 12 2024, 5:52 PM
Unknown Object (File)
Nov 12 2024, 3:34 PM
Unknown Object (File)
Nov 7 2024, 7:38 AM
Subscribers

Details

Reviewers
gallatin
kp
Summary

This can be used instead of M_WRITABLE where the calling code is
prepared to handle writing to M_EXTPG mbufs.

Diff Detail

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

Event Timeline

jhb requested review of this revision.Sep 25 2024, 3:13 PM

I'm confused.. if we are marking non-writable M_EXTPG mufs as M_RDONLY, why can't we simply remove the M_EXTPG check from M_WRITABLE? Why do we need a new macro?

I'm confused.. if we are marking non-writable M_EXTPG mufs as M_RDONLY, why can't we simply remove the M_EXTPG check from M_WRITABLE? Why do we need a new macro?

Because there are many places that call M_WRITABLE in the tree and if it succeeds expect to directly use mtod() to get a writable pointer to the data payload (possibly after using m_pullup which panics if called on an M_EXTPG mbuf). m_copyback() is explicitly aware of M_EXTPG mbufs and handles them correctly, so the new macro works fine the assertion there.

This revision is now accepted and ready to land.Sep 26 2024, 2:37 PM