Page MenuHomeFreeBSD

net80211: don't dereference a NULL HTINFO IE if it's presented
ClosedPublic

Authored by adrian on Jun 11 2025, 6:19 PM.
Referenced Files
Unknown Object (File)
Wed, Jul 23, 1:48 PM
Unknown Object (File)
Thu, Jul 17, 7:29 AM
Unknown Object (File)
Wed, Jul 16, 3:22 PM
Unknown Object (File)
Mon, Jul 7, 1:54 PM
Unknown Object (File)
Sat, Jul 5, 9:20 PM
Unknown Object (File)
Sat, Jul 5, 1:56 PM
Unknown Object (File)
Sat, Jul 5, 1:34 AM
Unknown Object (File)
Thu, Jul 3, 10:40 PM

Details

Summary

ieee80211_vht_get_vhtflags() is checking the htinfo IE for the
20/40MHz flag as part of deciding valid channel widths.

However, in the hostapd path, the ASSOC_REQ/REASSOC_REQ path
will parse the IEs, do some HT/VHT setup, then call
ieee80211_ht_updatehtcap_final(). In a HT ASSOC/REASSOC request
there won't be a HTINFO IE, however ieee80211_vht_get_vhtflags()
still checks for it, leading to a panic.

Instead, treat it as if we don't yet know if it's HT40 or not.
I'm not sure if we should do that or have it just do
_RETURN_CHAN_BITS(0).

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable