Page MenuHomeFreeBSD

pfilctl: initialize pio_nheads for PFILIOC_LISTHEADS ioctl
Needs ReviewPublic

Authored by rew on Apr 24 2022, 6:17 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Nov 26, 8:53 PM
Unknown Object (File)
Mon, Nov 17, 5:42 AM
Unknown Object (File)
Sat, Nov 15, 5:06 PM
Unknown Object (File)
Fri, Nov 14, 10:26 AM
Unknown Object (File)
Oct 19 2025, 12:55 PM
Unknown Object (File)
Oct 19 2025, 12:55 PM
Unknown Object (File)
Oct 18 2025, 10:19 PM
Unknown Object (File)
Sep 30 2025, 8:06 PM
Subscribers

Details

Reviewers
glebius
Summary

When pfilctl hooks is called with no hooks present:

% pfilctl hooks
pfilctl: ioctl(PFILIOC_LISTHEADS): Bad address

If pio_nheads or pio_nhooks is not initialized, pfilioc_listheads()
thinks the caller wants the heads/hooks copied out. However, in this
case, the caller is only expecting the number of heads/hooks returned
and hasn't prepared the buffer that pfilioc_listheads() is trying to
copyout to, causing the bad address error.

Looking at pfilioc_listheads() in sys/net/pfil.c, should the semantics
be to return the number of heads/hooks when either pio_nheads or
pio_nhooks is zero?

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 45343
Build 42231: arc lint + arc unit