Page MenuHomeFreeBSD

Fix mbuf leaks in various pru_send implementations
ClosedPublic

Authored by markj on May 6 2021, 9:16 PM.
Tags
None
Referenced Files
F108181484: D30151.id.diff
Wed, Jan 22, 8:07 AM
Unknown Object (File)
Sat, Jan 18, 8:23 AM
Unknown Object (File)
Fri, Jan 17, 9:02 PM
Unknown Object (File)
Wed, Jan 15, 12:13 AM
Unknown Object (File)
Tue, Jan 14, 11:56 PM
Unknown Object (File)
Tue, Jan 14, 12:15 PM
Unknown Object (File)
Dec 8 2024, 8:37 AM
Unknown Object (File)
Dec 8 2024, 8:37 AM
Subscribers

Details

Summary

The various protocol implementations are not very consistent about
freeing mbufs in error paths. In general, all protocols must free both
"m" and "control" upon an error, except if PRUS_NOTREADY is specified
(this is only implemented by TCP and unix(4) and requires further work
not handled in this diff), in which case "control" still must be freed.

This diff plugs various leaks in the pru_send implementations.

N.B. in general we seem to avoid calling m_freem(NULL), though this
works fine in practice and would be consistent with other kernel memory
allocators. Is there some reason to keep this pattern?

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Warnings
SeverityLocationCodeMessage
Warningsys/netinet6/raw_ip6.c:893SPELL1Possible Spelling Mistake
Warningsys/netinet6/raw_ip6.c:895SPELL1Possible Spelling Mistake
Warningsys/netinet6/raw_ip6.c:897SPELL1Possible Spelling Mistake
Unit
No Test Coverage
Build Status
Buildable 39059
Build 35948: arc lint + arc unit