honor new IEEE80211_KEY_GROUP key flag
Reviewed by: Tai-hwa Liang
This commit is contained in:
parent
dd70e17b12
commit
8ca623d734
@ -1452,6 +1452,35 @@ ath_key_alloc(struct ieee80211com *ic, const struct ieee80211_key *k)
|
||||
{
|
||||
struct ath_softc *sc = ic->ic_ifp->if_softc;
|
||||
|
||||
/*
|
||||
* Group key allocation must be handled specially for
|
||||
* parts that do not support multicast key cache search
|
||||
* functionality. For those parts the key id must match
|
||||
* the h/w key index so lookups find the right key. On
|
||||
* parts w/ the key search facility we install the sender's
|
||||
* mac address (with the high bit set) and let the hardware
|
||||
* find the key w/o using the key id. This is preferred as
|
||||
* it permits us to support multiple users for adhoc and/or
|
||||
* multi-station operation.
|
||||
*/
|
||||
if ((k->wk_flags & IEEE80211_KEY_GROUP) && !sc->sc_mcastkey) {
|
||||
u_int keyix;
|
||||
|
||||
if (!(&ic->ic_nw_keys[0] <= k &&
|
||||
k < &ic->ic_nw_keys[IEEE80211_WEP_NKID])) {
|
||||
/* should not happen */
|
||||
DPRINTF(sc, ATH_DEBUG_KEYCACHE,
|
||||
"%s: bogus group key\n", __func__);
|
||||
return IEEE80211_KEYIX_NONE;
|
||||
}
|
||||
keyix = k - ic->ic_nw_keys;
|
||||
/*
|
||||
* XXX we pre-allocate the global keys so
|
||||
* have no way to check if they've already been allocated.
|
||||
*/
|
||||
return keyix;
|
||||
}
|
||||
|
||||
/*
|
||||
* We allocate two pair for TKIP when using the h/w to do
|
||||
* the MIC. For everything else, including software crypto,
|
||||
|
@ -188,7 +188,8 @@ struct ath_softc {
|
||||
sc_hasveol : 1, /* tx VEOL support */
|
||||
sc_hastpc : 1, /* per-packet TPC support */
|
||||
sc_ledstate: 1, /* LED on/off state */
|
||||
sc_blinking: 1; /* LED blink operation active */
|
||||
sc_blinking: 1, /* LED blink operation active */
|
||||
sc_mcastkey: 1; /* mcast key cache search */
|
||||
/* rate tables */
|
||||
const HAL_RATE_TABLE *sc_rates[IEEE80211_MODE_MAX];
|
||||
const HAL_RATE_TABLE *sc_currates; /* current rate table */
|
||||
|
Loading…
x
Reference in New Issue
Block a user