Page MenuHomeFreeBSD

net80211: add the 802.11-2016 cipher list to the crypto array set.
ClosedPublic

Authored by adrian on Apr 22 2024, 3:39 AM.
Referenced Files
F108473455: D44899.id138453.diff
Sat, Jan 25, 6:27 AM
F108434790: D44899.id138552.diff
Fri, Jan 24, 6:00 PM
Unknown Object (File)
Fri, Jan 10, 2:17 PM
Unknown Object (File)
Fri, Jan 10, 1:54 PM
Unknown Object (File)
Fri, Jan 10, 6:24 AM
Unknown Object (File)
Thu, Jan 9, 10:19 PM
Unknown Object (File)
Dec 12 2024, 1:07 AM
Unknown Object (File)
Dec 2 2024, 3:05 PM

Details

Summary

These are the bitmap / cipher module number fields used for net80211
ciphers.

This requires a kernel recompile, but nothing (currently) in userland
is using these.

Diff Detail

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

Event Timeline

bz added inline comments.
sys/net80211/ieee80211_crypto.h
147

I love enums.

cc added inline comments.
sys/net80211/ieee80211_crypto.h
147

I love enums.

+1

167–171

In C printf, this is what I get. Also the output in Eclipse IDE console is a little different than in a Mac terminal. Is the result what we expected?

printf("%s\n", IEEE80211_CRYPTO_BITS);

quoted result:
WEPTKIPAESAES_CCMTKIPMICCKIPNONEAES_CCM_256 BIP_CMAC_128
BIP_CMAC_256 BIP_GMAC_128 BIP_CMAC_256
AES_GCM_128AES_GCM_256

sys/net80211/ieee80211_crypto.h
167–171

For use with printf(9)'s %b:

The %b identifier expects two arguments: an int and a char *.  These are
used as a register value and a print mask for decoding bitmasks.  The
print mask is made up of two parts: the base and the arguments.  The base
value is the output base (radix) expressed as an octal value; for
example, \10 gives octal and \20 gives hexadecimal.  The arguments are
made up of a sequence of bit identifiers.  Each bit identifier begins
with an octal value which is the number of the bit (starting from 1) this
identifier describes.  The rest of the identifier is a string of
characters containing the name of the bit.  The string is terminated by
either the bit number at the start of the next bit identifier or NUL for
the last bit identifier.
sys/net80211/ieee80211_crypto.h
167–171

For use with printf(9)'s %b:

The %b identifier expects two arguments: an int and a char *.  These are

Thanks for letting me know what I am missing. But after applying this patch in main, the ifconfig does not show the "cryptocaps". In verbose mode, it is empty. Any idea if there is a bug?

before the patch:
root@n2fbsd:/usr/src # ifconfig wlan0 list caps
drivercaps=581c001<STA,SHSLOT,SHPREAMBLE,MONITOR,WPA1,WPA2,WME>
cryptocaps=b<WEP,TKIP,AES_CCM>

after the patch:
root@n2fbsd:~ # ifconfig wlan0 list caps
drivercaps=581c001<STA,SHSLOT,SHPREAMBLE,MONITOR,WPA1,WPA2,WME>
root@n2fbsd:~ #

root@n2fbsd:~ # ifconfig -v wlan0 list caps
drivercaps=581c001<STA,SHSLOT,SHPREAMBLE,MONITOR,WPA1,WPA2,WME>
cryptocaps=0<>
htcaps=0<>
vhtcaps=0<>
...

sys/net80211/ieee80211_crypto.h
167–171

Hold on a second. I think I forgot to compile the kernel with the HW CRYPTO defined. Let me test again.

cc added inline comments.
sys/net80211/ieee80211_crypto.h
167–171

No surprise. To list it, HW CRYPTO must be defined for my driver.

After the patch:

root@n2fbsd:~ # ifconfig wlan0 list caps
drivercaps=581c001<STA,SHSLOT,SHPREAMBLE,MONITOR,WPA1,WPA2,WME>
cryptocaps=b<WEP,TKIP,AES_CCM>
root@n2fbsd:~ #

This revision is now accepted and ready to land.May 1 2024, 8:55 PM
bz requested changes to this revision.May 2 2024, 7:40 PM
bz added inline comments.
sys/net80211/ieee80211_crypto.h
168–170

In reality there is no "\7NONE" as we do not define the IEEE80211_CRYPTO_NONE? Where do we want to be consistent: in the defines or the printf?

This revision now requires changes to proceed.May 2 2024, 7:40 PM
adrian added inline comments.
sys/net80211/ieee80211_crypto.h
147

I do too, but they're already defines. I'm happy to add it to a follow-up enum cleanup task?

We just need to be sure there's nothing in the codebase and wpa/hostapd driver_bsd.c code that's using these things as compile time flags?

This revision was not accepted when it landed; it landed in state Needs Review.May 14 2024, 9:40 PM
This revision was automatically updated to reflect the committed changes.