Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src-draft/trunk]: src/sys/net80211 Initialize all avail ciphers.
details: https://anonhg.NetBSD.org/src-all/rev/af1266c6359d
branches: trunk
changeset: 376738:af1266c6359d
user: Nathanial Sloss <nat%netbsd.org@localhost>
date: Fri May 08 07:09:14 2020 +1000
description:
Initialize all avail ciphers.
Avoid an unnecessary panic if we don't have a particular cipher.
diffstat:
sys/net80211/ieee80211_crypto.c | 7 ++++++-
sys/net80211/ieee80211_crypto.h | 3 +++
sys/net80211/ieee80211_crypto_ccmp.c | 6 +++---
sys/net80211/ieee80211_crypto_tkip.c | 2 +-
sys/net80211/ieee80211_crypto_wep.c | 2 +-
5 files changed, 14 insertions(+), 6 deletions(-)
diffs (84 lines):
diff -r 317d33f372a1 -r af1266c6359d sys/net80211/ieee80211_crypto.c
--- a/sys/net80211/ieee80211_crypto.c Sat May 02 15:32:09 2020 +0200
+++ b/sys/net80211/ieee80211_crypto.c Fri May 08 07:09:14 2020 +1000
@@ -165,6 +165,9 @@ ieee80211_crypto_attach(struct ieee80211
{
/* NB: we assume everything is pre-zero'd */
ciphers[IEEE80211_CIPHER_NONE] = &ieee80211_cipher_none;
+ ciphers[IEEE80211_CIPHER_TKIP] = &tkip;
+ ciphers[IEEE80211_CIPHER_WEP] = &wep;
+ ciphers[IEEE80211_CIPHER_AES_CCM] = &ccmp;
}
/*
@@ -333,7 +336,9 @@ ieee80211_crypto_newkey(struct ieee80211
return 0;
}
#else
- panic("wlan_cipher not usable."); /* NNN NetBSD modules? */
+ IEEE80211_DPRINTF(vap, IEEE80211_MSG_CRYPTO,
+ "%s: no support for cipher %d\n", __func__, cipher);
+ return 0;
#endif
}
diff -r 317d33f372a1 -r af1266c6359d sys/net80211/ieee80211_crypto.h
--- a/sys/net80211/ieee80211_crypto.h Sat May 02 15:32:09 2020 +0200
+++ b/sys/net80211/ieee80211_crypto.h Fri May 08 07:09:14 2020 +1000
@@ -200,6 +200,9 @@ struct ieee80211_cipher {
int (*ic_demic)(struct ieee80211_key *, struct mbuf *, int);
};
extern const struct ieee80211_cipher ieee80211_cipher_none;
+extern const struct ieee80211_cipher tkip;
+extern const struct ieee80211_cipher ccmp;
+extern const struct ieee80211_cipher wep;
#define IEEE80211_KEY_UNDEFINED(k) \
((k)->wk_cipher == &ieee80211_cipher_none)
diff -r 317d33f372a1 -r af1266c6359d sys/net80211/ieee80211_crypto_ccmp.c
--- a/sys/net80211/ieee80211_crypto_ccmp.c Sat May 02 15:32:09 2020 +0200
+++ b/sys/net80211/ieee80211_crypto_ccmp.c Fri May 08 07:09:14 2020 +1000
@@ -92,7 +92,7 @@ static int ccmp_decap(struct ieee80211_k
static int ccmp_enmic(struct ieee80211_key *, struct mbuf *, int);
static int ccmp_demic(struct ieee80211_key *, struct mbuf *, int);
-static const struct ieee80211_cipher ccmp = {
+const struct ieee80211_cipher ccmp = {
.ic_name = "AES-CCM",
.ic_cipher = IEEE80211_CIPHER_AES_CCM,
.ic_header = IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN +
@@ -259,8 +259,8 @@ ccmp_decap(struct ieee80211_key *k, stru
struct ccmp_ctx *ctx = k->wk_private;
struct ieee80211vap *vap = ctx->cc_vap;
struct ieee80211_frame *wh;
- uint8_t *ivp, tid;
- uint64_t pn;
+ uint8_t *ivp, tid = 0;
+ uint64_t pn = 0;
rxs = ieee80211_get_rx_params_ptr(m);
diff -r 317d33f372a1 -r af1266c6359d sys/net80211/ieee80211_crypto_tkip.c
--- a/sys/net80211/ieee80211_crypto_tkip.c Sat May 02 15:32:09 2020 +0200
+++ b/sys/net80211/ieee80211_crypto_tkip.c Fri May 08 07:09:14 2020 +1000
@@ -81,7 +81,7 @@ static int tkip_enmic(struct ieee80211_k
static int tkip_decap(struct ieee80211_key *, struct mbuf *, int);
static int tkip_demic(struct ieee80211_key *, struct mbuf *, int);
-static const struct ieee80211_cipher tkip = {
+const struct ieee80211_cipher tkip = {
.ic_name = "TKIP",
.ic_cipher = IEEE80211_CIPHER_TKIP,
.ic_header = IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN +
diff -r 317d33f372a1 -r af1266c6359d sys/net80211/ieee80211_crypto_wep.c
--- a/sys/net80211/ieee80211_crypto_wep.c Sat May 02 15:32:09 2020 +0200
+++ b/sys/net80211/ieee80211_crypto_wep.c Fri May 08 07:09:14 2020 +1000
@@ -78,7 +78,7 @@ static int wep_decap(struct ieee80211_ke
static int wep_enmic(struct ieee80211_key *, struct mbuf *, int);
static int wep_demic(struct ieee80211_key *, struct mbuf *, int);
-static const struct ieee80211_cipher wep = {
+const struct ieee80211_cipher wep = {
.ic_name = "WEP",
.ic_cipher = IEEE80211_CIPHER_WEP,
.ic_header = IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN,
Home |
Main Index |
Thread Index |
Old Index