2003-06-23 16:55:01 +00:00
|
|
|
/*-
|
2017-11-27 15:23:17 +00:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
|
|
|
|
*
|
2003-06-27 05:13:52 +00:00
|
|
|
* Copyright (c) 2001 Atsushi Onoe
|
2008-04-20 20:35:46 +00:00
|
|
|
* Copyright (c) 2002-2008 Sam Leffler, Errno Consulting
|
2003-06-23 16:55:01 +00:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
2003-06-27 05:13:52 +00:00
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2003-06-23 16:55:01 +00:00
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
#ifndef _NET80211_IEEE80211_CRYPTO_H_
|
|
|
|
#define _NET80211_IEEE80211_CRYPTO_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* 802.11 protocol crypto-related definitions.
|
|
|
|
*/
|
|
|
|
#define IEEE80211_KEYBUF_SIZE 16
|
2004-12-08 17:26:47 +00:00
|
|
|
#define IEEE80211_MICBUF_SIZE (8+8) /* space for both tx+rx keys */
|
2003-06-23 16:55:01 +00:00
|
|
|
|
2004-12-08 17:26:47 +00:00
|
|
|
/*
|
|
|
|
* Old WEP-style key. Deprecated.
|
|
|
|
*/
|
2003-06-23 16:55:01 +00:00
|
|
|
struct ieee80211_wepkey {
|
2004-12-08 17:26:47 +00:00
|
|
|
u_int wk_len; /* key length in bytes */
|
Update 802.11 wireless support:
o major overhaul of the way channels are handled: channels are now
fully enumerated and uniquely identify the operating characteristics;
these changes are visible to user applications which require changes
o make scanning support independent of the state machine to enable
background scanning and roaming
o move scanning support into loadable modules based on the operating
mode to enable different policies and reduce the memory footprint
on systems w/ constrained resources
o add background scanning in station mode (no support for adhoc/ibss
mode yet)
o significantly speedup sta mode scanning with a variety of techniques
o add roaming support when background scanning is supported; for now
we use a simple algorithm to trigger a roam: we threshold the rssi
and tx rate, if either drops too low we try to roam to a new ap
o add tx fragmentation support
o add first cut at 802.11n support: this code works with forthcoming
drivers but is incomplete; it's included now to establish a baseline
for other drivers to be developed and for user applications
o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates
prepending mbufs for traffic generated locally
o add support for Atheros protocol extensions; mainly the fast frames
encapsulation (note this can be used with any card that can tx+rx
large frames correctly)
o add sta support for ap's that beacon both WPA1+2 support
o change all data types from bsd-style to posix-style
o propagate noise floor data from drivers to net80211 and on to user apps
o correct various issues in the sta mode state machine related to handling
authentication and association failures
o enable the addition of sta mode power save support for drivers that need
net80211 support (not in this commit)
o remove old WI compatibility ioctls (wicontrol is officially dead)
o change the data structures returned for get sta info and get scan
results so future additions will not break user apps
o fixed tx rate is now maintained internally as an ieee rate and not an
index into the rate set; this needs to be extended to deal with
multi-mode operation
o add extended channel specifications to radiotap to enable 11n sniffing
Drivers:
o ath: add support for bg scanning, tx fragmentation, fast frames,
dynamic turbo (lightly tested), 11n (sniffing only and needs
new hal)
o awi: compile tested only
o ndis: lightly tested
o ipw: lightly tested
o iwi: add support for bg scanning (well tested but may have some
rough edges)
o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data
o wi: lightly tested
This work is based on contributions by Atheros, kmacy, sephe, thompsa,
mlaier, kevlo, and others. Much of the scanning work was supported by
Atheros. The 11n work was supported by Marvell.
2007-06-11 03:36:55 +00:00
|
|
|
uint8_t wk_key[IEEE80211_KEYBUF_SIZE];
|
2004-12-08 17:26:47 +00:00
|
|
|
};
|
|
|
|
|
2008-04-20 20:35:46 +00:00
|
|
|
struct ieee80211_rsnparms {
|
|
|
|
uint8_t rsn_mcastcipher; /* mcast/group cipher */
|
|
|
|
uint8_t rsn_mcastkeylen; /* mcast key length */
|
|
|
|
uint8_t rsn_ucastcipher; /* selected unicast cipher */
|
|
|
|
uint8_t rsn_ucastkeylen; /* unicast key length */
|
|
|
|
uint8_t rsn_keymgmt; /* selected key mgmt algo */
|
|
|
|
uint16_t rsn_caps; /* capabilities */
|
|
|
|
};
|
|
|
|
|
2004-12-08 17:26:47 +00:00
|
|
|
struct ieee80211_cipher;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Crypto key state. There is sufficient room for all supported
|
|
|
|
* ciphers (see below). The underlying ciphers are handled
|
|
|
|
* separately through loadable cipher modules that register with
|
|
|
|
* the generic crypto support. A key has a reference to an instance
|
|
|
|
* of the cipher; any per-key state is hung off wk_private by the
|
|
|
|
* cipher when it is attached. Ciphers are automatically called
|
|
|
|
* to detach and cleanup any such state when the key is deleted.
|
|
|
|
*
|
|
|
|
* The generic crypto support handles encap/decap of cipher-related
|
|
|
|
* frame contents for both hardware- and software-based implementations.
|
|
|
|
* A key requiring software crypto support is automatically flagged and
|
|
|
|
* the cipher is expected to honor this and do the necessary work.
|
|
|
|
* Ciphers such as TKIP may also support mixed hardware/software
|
|
|
|
* encrypt/decrypt and MIC processing.
|
|
|
|
*/
|
Update 802.11 wireless support:
o major overhaul of the way channels are handled: channels are now
fully enumerated and uniquely identify the operating characteristics;
these changes are visible to user applications which require changes
o make scanning support independent of the state machine to enable
background scanning and roaming
o move scanning support into loadable modules based on the operating
mode to enable different policies and reduce the memory footprint
on systems w/ constrained resources
o add background scanning in station mode (no support for adhoc/ibss
mode yet)
o significantly speedup sta mode scanning with a variety of techniques
o add roaming support when background scanning is supported; for now
we use a simple algorithm to trigger a roam: we threshold the rssi
and tx rate, if either drops too low we try to roam to a new ap
o add tx fragmentation support
o add first cut at 802.11n support: this code works with forthcoming
drivers but is incomplete; it's included now to establish a baseline
for other drivers to be developed and for user applications
o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates
prepending mbufs for traffic generated locally
o add support for Atheros protocol extensions; mainly the fast frames
encapsulation (note this can be used with any card that can tx+rx
large frames correctly)
o add sta support for ap's that beacon both WPA1+2 support
o change all data types from bsd-style to posix-style
o propagate noise floor data from drivers to net80211 and on to user apps
o correct various issues in the sta mode state machine related to handling
authentication and association failures
o enable the addition of sta mode power save support for drivers that need
net80211 support (not in this commit)
o remove old WI compatibility ioctls (wicontrol is officially dead)
o change the data structures returned for get sta info and get scan
results so future additions will not break user apps
o fixed tx rate is now maintained internally as an ieee rate and not an
index into the rate set; this needs to be extended to deal with
multi-mode operation
o add extended channel specifications to radiotap to enable 11n sniffing
Drivers:
o ath: add support for bg scanning, tx fragmentation, fast frames,
dynamic turbo (lightly tested), 11n (sniffing only and needs
new hal)
o awi: compile tested only
o ndis: lightly tested
o ipw: lightly tested
o iwi: add support for bg scanning (well tested but may have some
rough edges)
o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data
o wi: lightly tested
This work is based on contributions by Atheros, kmacy, sephe, thompsa,
mlaier, kevlo, and others. Much of the scanning work was supported by
Atheros. The 11n work was supported by Marvell.
2007-06-11 03:36:55 +00:00
|
|
|
typedef uint16_t ieee80211_keyix; /* h/w key index */
|
2005-08-08 18:46:36 +00:00
|
|
|
|
2004-12-08 17:26:47 +00:00
|
|
|
struct ieee80211_key {
|
Update 802.11 wireless support:
o major overhaul of the way channels are handled: channels are now
fully enumerated and uniquely identify the operating characteristics;
these changes are visible to user applications which require changes
o make scanning support independent of the state machine to enable
background scanning and roaming
o move scanning support into loadable modules based on the operating
mode to enable different policies and reduce the memory footprint
on systems w/ constrained resources
o add background scanning in station mode (no support for adhoc/ibss
mode yet)
o significantly speedup sta mode scanning with a variety of techniques
o add roaming support when background scanning is supported; for now
we use a simple algorithm to trigger a roam: we threshold the rssi
and tx rate, if either drops too low we try to roam to a new ap
o add tx fragmentation support
o add first cut at 802.11n support: this code works with forthcoming
drivers but is incomplete; it's included now to establish a baseline
for other drivers to be developed and for user applications
o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates
prepending mbufs for traffic generated locally
o add support for Atheros protocol extensions; mainly the fast frames
encapsulation (note this can be used with any card that can tx+rx
large frames correctly)
o add sta support for ap's that beacon both WPA1+2 support
o change all data types from bsd-style to posix-style
o propagate noise floor data from drivers to net80211 and on to user apps
o correct various issues in the sta mode state machine related to handling
authentication and association failures
o enable the addition of sta mode power save support for drivers that need
net80211 support (not in this commit)
o remove old WI compatibility ioctls (wicontrol is officially dead)
o change the data structures returned for get sta info and get scan
results so future additions will not break user apps
o fixed tx rate is now maintained internally as an ieee rate and not an
index into the rate set; this needs to be extended to deal with
multi-mode operation
o add extended channel specifications to radiotap to enable 11n sniffing
Drivers:
o ath: add support for bg scanning, tx fragmentation, fast frames,
dynamic turbo (lightly tested), 11n (sniffing only and needs
new hal)
o awi: compile tested only
o ndis: lightly tested
o ipw: lightly tested
o iwi: add support for bg scanning (well tested but may have some
rough edges)
o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data
o wi: lightly tested
This work is based on contributions by Atheros, kmacy, sephe, thompsa,
mlaier, kevlo, and others. Much of the scanning work was supported by
Atheros. The 11n work was supported by Marvell.
2007-06-11 03:36:55 +00:00
|
|
|
uint8_t wk_keylen; /* key length in bytes */
|
2016-11-05 22:41:22 +00:00
|
|
|
uint8_t wk_pad; /* .. some drivers use this. Fix that. */
|
|
|
|
uint8_t wk_pad1[2];
|
|
|
|
uint32_t wk_flags;
|
|
|
|
#define IEEE80211_KEY_XMIT 0x00000001 /* key used for xmit */
|
|
|
|
#define IEEE80211_KEY_RECV 0x00000002 /* key used for recv */
|
|
|
|
#define IEEE80211_KEY_GROUP 0x00000004 /* key used for WPA group operation */
|
|
|
|
#define IEEE80211_KEY_NOREPLAY 0x00000008 /* ignore replay failures */
|
|
|
|
#define IEEE80211_KEY_SWENCRYPT 0x00000010 /* host-based encrypt */
|
|
|
|
#define IEEE80211_KEY_SWDECRYPT 0x00000020 /* host-based decrypt */
|
|
|
|
#define IEEE80211_KEY_SWENMIC 0x00000040 /* host-based enmic */
|
|
|
|
#define IEEE80211_KEY_SWDEMIC 0x00000080 /* host-based demic */
|
|
|
|
#define IEEE80211_KEY_DEVKEY 0x00000100 /* device key request completed */
|
|
|
|
#define IEEE80211_KEY_CIPHER0 0x00001000 /* cipher-specific action 0 */
|
|
|
|
#define IEEE80211_KEY_CIPHER1 0x00002000 /* cipher-specific action 1 */
|
|
|
|
#define IEEE80211_KEY_NOIV 0x00004000 /* don't insert IV/MIC for !mgmt */
|
|
|
|
#define IEEE80211_KEY_NOIVMGT 0x00008000 /* don't insert IV/MIC for mgmt */
|
|
|
|
#define IEEE80211_KEY_NOMIC 0x00010000 /* don't insert MIC for !mgmt */
|
|
|
|
#define IEEE80211_KEY_NOMICMGT 0x00020000 /* don't insert MIC for mgmt */
|
|
|
|
|
2005-08-08 18:46:36 +00:00
|
|
|
ieee80211_keyix wk_keyix; /* h/w key index */
|
|
|
|
ieee80211_keyix wk_rxkeyix; /* optional h/w rx key index */
|
Update 802.11 wireless support:
o major overhaul of the way channels are handled: channels are now
fully enumerated and uniquely identify the operating characteristics;
these changes are visible to user applications which require changes
o make scanning support independent of the state machine to enable
background scanning and roaming
o move scanning support into loadable modules based on the operating
mode to enable different policies and reduce the memory footprint
on systems w/ constrained resources
o add background scanning in station mode (no support for adhoc/ibss
mode yet)
o significantly speedup sta mode scanning with a variety of techniques
o add roaming support when background scanning is supported; for now
we use a simple algorithm to trigger a roam: we threshold the rssi
and tx rate, if either drops too low we try to roam to a new ap
o add tx fragmentation support
o add first cut at 802.11n support: this code works with forthcoming
drivers but is incomplete; it's included now to establish a baseline
for other drivers to be developed and for user applications
o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates
prepending mbufs for traffic generated locally
o add support for Atheros protocol extensions; mainly the fast frames
encapsulation (note this can be used with any card that can tx+rx
large frames correctly)
o add sta support for ap's that beacon both WPA1+2 support
o change all data types from bsd-style to posix-style
o propagate noise floor data from drivers to net80211 and on to user apps
o correct various issues in the sta mode state machine related to handling
authentication and association failures
o enable the addition of sta mode power save support for drivers that need
net80211 support (not in this commit)
o remove old WI compatibility ioctls (wicontrol is officially dead)
o change the data structures returned for get sta info and get scan
results so future additions will not break user apps
o fixed tx rate is now maintained internally as an ieee rate and not an
index into the rate set; this needs to be extended to deal with
multi-mode operation
o add extended channel specifications to radiotap to enable 11n sniffing
Drivers:
o ath: add support for bg scanning, tx fragmentation, fast frames,
dynamic turbo (lightly tested), 11n (sniffing only and needs
new hal)
o awi: compile tested only
o ndis: lightly tested
o ipw: lightly tested
o iwi: add support for bg scanning (well tested but may have some
rough edges)
o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data
o wi: lightly tested
This work is based on contributions by Atheros, kmacy, sephe, thompsa,
mlaier, kevlo, and others. Much of the scanning work was supported by
Atheros. The 11n work was supported by Marvell.
2007-06-11 03:36:55 +00:00
|
|
|
uint8_t wk_key[IEEE80211_KEYBUF_SIZE+IEEE80211_MICBUF_SIZE];
|
2004-12-08 17:26:47 +00:00
|
|
|
#define wk_txmic wk_key+IEEE80211_KEYBUF_SIZE+0 /* XXX can't () right */
|
|
|
|
#define wk_rxmic wk_key+IEEE80211_KEYBUF_SIZE+8 /* XXX can't () right */
|
2008-04-20 20:35:46 +00:00
|
|
|
/* key receive sequence counter */
|
|
|
|
uint64_t wk_keyrsc[IEEE80211_TID_SIZE];
|
Update 802.11 wireless support:
o major overhaul of the way channels are handled: channels are now
fully enumerated and uniquely identify the operating characteristics;
these changes are visible to user applications which require changes
o make scanning support independent of the state machine to enable
background scanning and roaming
o move scanning support into loadable modules based on the operating
mode to enable different policies and reduce the memory footprint
on systems w/ constrained resources
o add background scanning in station mode (no support for adhoc/ibss
mode yet)
o significantly speedup sta mode scanning with a variety of techniques
o add roaming support when background scanning is supported; for now
we use a simple algorithm to trigger a roam: we threshold the rssi
and tx rate, if either drops too low we try to roam to a new ap
o add tx fragmentation support
o add first cut at 802.11n support: this code works with forthcoming
drivers but is incomplete; it's included now to establish a baseline
for other drivers to be developed and for user applications
o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates
prepending mbufs for traffic generated locally
o add support for Atheros protocol extensions; mainly the fast frames
encapsulation (note this can be used with any card that can tx+rx
large frames correctly)
o add sta support for ap's that beacon both WPA1+2 support
o change all data types from bsd-style to posix-style
o propagate noise floor data from drivers to net80211 and on to user apps
o correct various issues in the sta mode state machine related to handling
authentication and association failures
o enable the addition of sta mode power save support for drivers that need
net80211 support (not in this commit)
o remove old WI compatibility ioctls (wicontrol is officially dead)
o change the data structures returned for get sta info and get scan
results so future additions will not break user apps
o fixed tx rate is now maintained internally as an ieee rate and not an
index into the rate set; this needs to be extended to deal with
multi-mode operation
o add extended channel specifications to radiotap to enable 11n sniffing
Drivers:
o ath: add support for bg scanning, tx fragmentation, fast frames,
dynamic turbo (lightly tested), 11n (sniffing only and needs
new hal)
o awi: compile tested only
o ndis: lightly tested
o ipw: lightly tested
o iwi: add support for bg scanning (well tested but may have some
rough edges)
o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data
o wi: lightly tested
This work is based on contributions by Atheros, kmacy, sephe, thompsa,
mlaier, kevlo, and others. Much of the scanning work was supported by
Atheros. The 11n work was supported by Marvell.
2007-06-11 03:36:55 +00:00
|
|
|
uint64_t wk_keytsc; /* key transmit sequence counter */
|
2004-12-08 17:26:47 +00:00
|
|
|
const struct ieee80211_cipher *wk_cipher;
|
|
|
|
void *wk_private; /* private cipher state */
|
2008-05-28 23:32:00 +00:00
|
|
|
uint8_t wk_macaddr[IEEE80211_ADDR_LEN];
|
2004-12-08 17:26:47 +00:00
|
|
|
};
|
2005-04-12 17:55:13 +00:00
|
|
|
#define IEEE80211_KEY_COMMON /* common flags passed in by apps */\
|
2010-07-01 20:50:12 +00:00
|
|
|
(IEEE80211_KEY_XMIT | IEEE80211_KEY_RECV | IEEE80211_KEY_GROUP | \
|
|
|
|
IEEE80211_KEY_NOREPLAY)
|
2004-12-08 17:26:47 +00:00
|
|
|
|
2008-05-28 23:25:36 +00:00
|
|
|
#define IEEE80211_KEY_SWCRYPT \
|
|
|
|
(IEEE80211_KEY_SWENCRYPT | IEEE80211_KEY_SWDECRYPT)
|
|
|
|
#define IEEE80211_KEY_SWMIC (IEEE80211_KEY_SWENMIC | IEEE80211_KEY_SWDEMIC)
|
|
|
|
|
2016-09-15 22:27:00 +00:00
|
|
|
#define IEEE80211_KEY_DEVICE /* flags owned by device driver */\
|
|
|
|
(IEEE80211_KEY_DEVKEY|IEEE80211_KEY_CIPHER0|IEEE80211_KEY_CIPHER1| \
|
2016-11-19 02:00:24 +00:00
|
|
|
IEEE80211_KEY_SWCRYPT|IEEE80211_KEY_SWMIC|IEEE80211_KEY_NOIV | \
|
|
|
|
IEEE80211_KEY_NOIVMGT|IEEE80211_KEY_NOMIC|IEEE80211_KEY_NOMICMGT)
|
2016-09-15 22:27:00 +00:00
|
|
|
|
2009-02-05 19:20:34 +00:00
|
|
|
#define IEEE80211_KEY_BITS \
|
|
|
|
"\20\1XMIT\2RECV\3GROUP\4SWENCRYPT\5SWDECRYPT\6SWENMIC\7SWDEMIC" \
|
|
|
|
"\10DEVKEY\11CIPHER0\12CIPHER1"
|
|
|
|
|
2008-04-20 20:35:46 +00:00
|
|
|
#define IEEE80211_KEYIX_NONE ((ieee80211_keyix) -1)
|
|
|
|
|
2004-12-08 17:26:47 +00:00
|
|
|
/*
|
|
|
|
* NB: these values are ordered carefully; there are lots of
|
2008-04-20 20:35:46 +00:00
|
|
|
* of implications in any reordering. Beware that 4 is used
|
|
|
|
* only to indicate h/w TKIP MIC support in driver capabilities;
|
|
|
|
* there is no separate cipher support (it's rolled into the
|
|
|
|
* TKIP cipher support).
|
2004-12-08 17:26:47 +00:00
|
|
|
*/
|
|
|
|
#define IEEE80211_CIPHER_WEP 0
|
|
|
|
#define IEEE80211_CIPHER_TKIP 1
|
|
|
|
#define IEEE80211_CIPHER_AES_OCB 2
|
|
|
|
#define IEEE80211_CIPHER_AES_CCM 3
|
2008-04-20 20:35:46 +00:00
|
|
|
#define IEEE80211_CIPHER_TKIPMIC 4 /* TKIP MIC capability */
|
2004-12-08 17:26:47 +00:00
|
|
|
#define IEEE80211_CIPHER_CKIP 5
|
|
|
|
#define IEEE80211_CIPHER_NONE 6 /* pseudo value */
|
|
|
|
|
|
|
|
#define IEEE80211_CIPHER_MAX (IEEE80211_CIPHER_NONE+1)
|
|
|
|
|
2008-04-20 20:35:46 +00:00
|
|
|
/* capability bits in ic_cryptocaps/iv_cryptocaps */
|
|
|
|
#define IEEE80211_CRYPTO_WEP (1<<IEEE80211_CIPHER_WEP)
|
|
|
|
#define IEEE80211_CRYPTO_TKIP (1<<IEEE80211_CIPHER_TKIP)
|
|
|
|
#define IEEE80211_CRYPTO_AES_OCB (1<<IEEE80211_CIPHER_AES_OCB)
|
|
|
|
#define IEEE80211_CRYPTO_AES_CCM (1<<IEEE80211_CIPHER_AES_CCM)
|
|
|
|
#define IEEE80211_CRYPTO_TKIPMIC (1<<IEEE80211_CIPHER_TKIPMIC)
|
|
|
|
#define IEEE80211_CRYPTO_CKIP (1<<IEEE80211_CIPHER_CKIP)
|
2004-12-08 17:26:47 +00:00
|
|
|
|
2009-01-27 23:00:38 +00:00
|
|
|
#define IEEE80211_CRYPTO_BITS \
|
|
|
|
"\20\1WEP\2TKIP\3AES\4AES_CCM\5TKIPMIC\6CKIP"
|
|
|
|
|
2004-12-08 17:26:47 +00:00
|
|
|
#if defined(__KERNEL__) || defined(_KERNEL)
|
|
|
|
|
|
|
|
struct ieee80211com;
|
2008-04-20 20:35:46 +00:00
|
|
|
struct ieee80211vap;
|
2004-12-08 17:26:47 +00:00
|
|
|
struct ieee80211_node;
|
|
|
|
struct mbuf;
|
|
|
|
|
2008-04-20 20:35:46 +00:00
|
|
|
MALLOC_DECLARE(M_80211_CRYPTO);
|
2004-12-08 17:26:47 +00:00
|
|
|
|
2005-04-04 04:27:20 +00:00
|
|
|
void ieee80211_crypto_attach(struct ieee80211com *);
|
|
|
|
void ieee80211_crypto_detach(struct ieee80211com *);
|
2008-04-20 20:35:46 +00:00
|
|
|
void ieee80211_crypto_vattach(struct ieee80211vap *);
|
|
|
|
void ieee80211_crypto_vdetach(struct ieee80211vap *);
|
|
|
|
int ieee80211_crypto_newkey(struct ieee80211vap *,
|
2005-04-12 17:55:13 +00:00
|
|
|
int cipher, int flags, struct ieee80211_key *);
|
2008-04-20 20:35:46 +00:00
|
|
|
int ieee80211_crypto_delkey(struct ieee80211vap *,
|
2004-12-08 17:26:47 +00:00
|
|
|
struct ieee80211_key *);
|
2008-05-28 23:32:00 +00:00
|
|
|
int ieee80211_crypto_setkey(struct ieee80211vap *, struct ieee80211_key *);
|
2008-04-20 20:35:46 +00:00
|
|
|
void ieee80211_crypto_delglobalkeys(struct ieee80211vap *);
|
2008-05-28 23:33:29 +00:00
|
|
|
void ieee80211_crypto_reload_keys(struct ieee80211com *);
|
[net80211] turn the default TX key configuration (for WEP) into a vap callback.
The ath10k firmware supports hardware WEP offload, and in native wifi mode
(or 802.3 ethernet mode, for that matter) the WEP key isn't actually included
in the TX payload from net80211. Instead, a separate firmware command is issued
that sets the default TX key to be the specified key.
However, net80211 doesn't at all inform the driver layer that this is
occuring - it just "expects" to be inserting WEP header information
when doing WEP TX, even with hardware encryption.
So, to better support the newer world order, turn the default TX key assignment
into a VAP method that can be overridden by the driver and ensure its wrapped
in a crypto begin/end set. That way it should be correctly atomic from the
point of view of keychanges (as long as the driver does the right thing.)
It'd be nice if we passed through to the key_set call a flag that says
"also make this the default key" - that's captured here by calling the
deftxkey method after the key_set method. Maybe I can do that later.
Note: this is a net80211 ABI change, and will require a kernel+modules
recompile. Happy Holidays, etc.
Tested:
* ath10k driver port
* rtwn_usb, WEP station
2016-12-27 06:10:28 +00:00
|
|
|
void ieee80211_crypto_set_deftxkey(struct ieee80211vap *,
|
|
|
|
ieee80211_keyix kid);
|
2004-12-08 17:26:47 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Template for a supported cipher. Ciphers register with the
|
|
|
|
* crypto code and are typically loaded as separate modules
|
|
|
|
* (the null cipher is always present).
|
|
|
|
* XXX may need refcnts
|
|
|
|
*/
|
|
|
|
struct ieee80211_cipher {
|
|
|
|
const char *ic_name; /* printable name */
|
|
|
|
u_int ic_cipher; /* IEEE80211_CIPHER_* */
|
|
|
|
u_int ic_header; /* size of privacy header (bytes) */
|
|
|
|
u_int ic_trailer; /* size of privacy trailer (bytes) */
|
|
|
|
u_int ic_miclen; /* size of mic trailer (bytes) */
|
2008-04-20 20:35:46 +00:00
|
|
|
void* (*ic_attach)(struct ieee80211vap *, struct ieee80211_key *);
|
2004-12-08 17:26:47 +00:00
|
|
|
void (*ic_detach)(struct ieee80211_key *);
|
|
|
|
int (*ic_setkey)(struct ieee80211_key *);
|
2015-10-03 00:50:13 +00:00
|
|
|
void (*ic_setiv)(struct ieee80211_key *, uint8_t *);
|
2015-10-02 21:25:48 +00:00
|
|
|
int (*ic_encap)(struct ieee80211_key *, struct mbuf *);
|
2005-06-10 16:11:24 +00:00
|
|
|
int (*ic_decap)(struct ieee80211_key *, struct mbuf *, int);
|
2005-06-06 04:04:38 +00:00
|
|
|
int (*ic_enmic)(struct ieee80211_key *, struct mbuf *, int);
|
|
|
|
int (*ic_demic)(struct ieee80211_key *, struct mbuf *, int);
|
2003-06-23 16:55:01 +00:00
|
|
|
};
|
2004-12-08 17:26:47 +00:00
|
|
|
extern const struct ieee80211_cipher ieee80211_cipher_none;
|
|
|
|
|
2007-03-11 06:36:10 +00:00
|
|
|
#define IEEE80211_KEY_UNDEFINED(k) \
|
|
|
|
((k)->wk_cipher == &ieee80211_cipher_none)
|
|
|
|
|
2005-04-04 04:27:20 +00:00
|
|
|
void ieee80211_crypto_register(const struct ieee80211_cipher *);
|
|
|
|
void ieee80211_crypto_unregister(const struct ieee80211_cipher *);
|
|
|
|
int ieee80211_crypto_available(u_int cipher);
|
2003-06-23 16:55:01 +00:00
|
|
|
|
2016-12-07 04:02:41 +00:00
|
|
|
int ieee80211_crypto_get_key_wepidx(const struct ieee80211vap *,
|
|
|
|
const struct ieee80211_key *k);
|
2015-10-02 21:25:48 +00:00
|
|
|
uint8_t ieee80211_crypto_get_keyid(struct ieee80211vap *vap,
|
|
|
|
struct ieee80211_key *k);
|
2015-10-03 00:57:33 +00:00
|
|
|
struct ieee80211_key *ieee80211_crypto_get_txkey(struct ieee80211_node *,
|
|
|
|
struct mbuf *);
|
2008-04-20 20:35:46 +00:00
|
|
|
struct ieee80211_key *ieee80211_crypto_encap(struct ieee80211_node *,
|
|
|
|
struct mbuf *);
|
2016-11-19 02:00:24 +00:00
|
|
|
int ieee80211_crypto_decap(struct ieee80211_node *,
|
|
|
|
struct mbuf *, int, struct ieee80211_key **);
|
2016-11-05 22:41:22 +00:00
|
|
|
int ieee80211_crypto_demic(struct ieee80211vap *vap, struct ieee80211_key *k,
|
|
|
|
struct mbuf *, int);
|
2004-12-08 17:26:47 +00:00
|
|
|
/*
|
|
|
|
* Add any MIC.
|
|
|
|
*/
|
|
|
|
static __inline int
|
2008-04-20 20:35:46 +00:00
|
|
|
ieee80211_crypto_enmic(struct ieee80211vap *vap,
|
2005-06-06 04:04:38 +00:00
|
|
|
struct ieee80211_key *k, struct mbuf *m, int force)
|
2004-12-08 17:26:47 +00:00
|
|
|
{
|
|
|
|
const struct ieee80211_cipher *cip = k->wk_cipher;
|
2005-06-06 04:04:38 +00:00
|
|
|
return (cip->ic_miclen > 0 ? cip->ic_enmic(k, m, force) : 1);
|
2004-12-08 17:26:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Reset key state to an unused state. The crypto
|
|
|
|
* key allocation mechanism insures other state (e.g.
|
|
|
|
* key data) is properly setup before a key is used.
|
|
|
|
*/
|
|
|
|
static __inline void
|
2008-04-20 20:35:46 +00:00
|
|
|
ieee80211_crypto_resetkey(struct ieee80211vap *vap,
|
2005-08-08 18:46:36 +00:00
|
|
|
struct ieee80211_key *k, ieee80211_keyix ix)
|
2004-12-08 17:26:47 +00:00
|
|
|
{
|
2008-12-15 22:31:54 +00:00
|
|
|
k->wk_cipher = &ieee80211_cipher_none;
|
2008-04-20 20:35:46 +00:00
|
|
|
k->wk_private = k->wk_cipher->ic_attach(vap, k);
|
2005-08-08 18:46:36 +00:00
|
|
|
k->wk_keyix = k->wk_rxkeyix = ix;
|
2004-12-08 17:26:47 +00:00
|
|
|
k->wk_flags = IEEE80211_KEY_XMIT | IEEE80211_KEY_RECV;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Crypt-related notification methods.
|
|
|
|
*/
|
2008-04-20 20:35:46 +00:00
|
|
|
void ieee80211_notify_replay_failure(struct ieee80211vap *,
|
2004-12-08 17:26:47 +00:00
|
|
|
const struct ieee80211_frame *, const struct ieee80211_key *,
|
2009-06-05 23:10:30 +00:00
|
|
|
uint64_t rsc, int tid);
|
2008-04-20 20:35:46 +00:00
|
|
|
void ieee80211_notify_michael_failure(struct ieee80211vap *,
|
2004-12-08 17:26:47 +00:00
|
|
|
const struct ieee80211_frame *, u_int keyix);
|
|
|
|
#endif /* defined(__KERNEL__) || defined(_KERNEL) */
|
2003-06-23 16:55:01 +00:00
|
|
|
#endif /* _NET80211_IEEE80211_CRYPTO_H_ */
|