⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ieee80211.h

📁 linux 内核源代码
💻 H
字号:
/* * IEEE 802.11 defines * * Copyright (c) 2001-2002, SSH Communications Security Corp and Jouni Malinen * <jkmaline@cc.hut.fi> * Copyright (c) 2002-2003, Jouni Malinen <jkmaline@cc.hut.fi> * Copyright (c) 2005, Devicescape Software, Inc. * Copyright (c) 2006, Michael Wu <flamingice@sourmilk.net> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#ifndef IEEE80211_H#define IEEE80211_H#include <linux/types.h>#include <asm/byteorder.h>#define FCS_LEN 4#define IEEE80211_FCTL_VERS		0x0003#define IEEE80211_FCTL_FTYPE		0x000c#define IEEE80211_FCTL_STYPE		0x00f0#define IEEE80211_FCTL_TODS		0x0100#define IEEE80211_FCTL_FROMDS		0x0200#define IEEE80211_FCTL_MOREFRAGS	0x0400#define IEEE80211_FCTL_RETRY		0x0800#define IEEE80211_FCTL_PM		0x1000#define IEEE80211_FCTL_MOREDATA		0x2000#define IEEE80211_FCTL_PROTECTED	0x4000#define IEEE80211_FCTL_ORDER		0x8000#define IEEE80211_SCTL_FRAG		0x000F#define IEEE80211_SCTL_SEQ		0xFFF0#define IEEE80211_FTYPE_MGMT		0x0000#define IEEE80211_FTYPE_CTL		0x0004#define IEEE80211_FTYPE_DATA		0x0008/* management */#define IEEE80211_STYPE_ASSOC_REQ	0x0000#define IEEE80211_STYPE_ASSOC_RESP	0x0010#define IEEE80211_STYPE_REASSOC_REQ	0x0020#define IEEE80211_STYPE_REASSOC_RESP	0x0030#define IEEE80211_STYPE_PROBE_REQ	0x0040#define IEEE80211_STYPE_PROBE_RESP	0x0050#define IEEE80211_STYPE_BEACON		0x0080#define IEEE80211_STYPE_ATIM		0x0090#define IEEE80211_STYPE_DISASSOC	0x00A0#define IEEE80211_STYPE_AUTH		0x00B0#define IEEE80211_STYPE_DEAUTH		0x00C0#define IEEE80211_STYPE_ACTION		0x00D0/* control */#define IEEE80211_STYPE_PSPOLL		0x00A0#define IEEE80211_STYPE_RTS		0x00B0#define IEEE80211_STYPE_CTS		0x00C0#define IEEE80211_STYPE_ACK		0x00D0#define IEEE80211_STYPE_CFEND		0x00E0#define IEEE80211_STYPE_CFENDACK	0x00F0/* data */#define IEEE80211_STYPE_DATA			0x0000#define IEEE80211_STYPE_DATA_CFACK		0x0010#define IEEE80211_STYPE_DATA_CFPOLL		0x0020#define IEEE80211_STYPE_DATA_CFACKPOLL		0x0030#define IEEE80211_STYPE_NULLFUNC		0x0040#define IEEE80211_STYPE_CFACK			0x0050#define IEEE80211_STYPE_CFPOLL			0x0060#define IEEE80211_STYPE_CFACKPOLL		0x0070#define IEEE80211_STYPE_QOS_DATA		0x0080#define IEEE80211_STYPE_QOS_DATA_CFACK		0x0090#define IEEE80211_STYPE_QOS_DATA_CFPOLL		0x00A0#define IEEE80211_STYPE_QOS_DATA_CFACKPOLL	0x00B0#define IEEE80211_STYPE_QOS_NULLFUNC		0x00C0#define IEEE80211_STYPE_QOS_CFACK		0x00D0#define IEEE80211_STYPE_QOS_CFPOLL		0x00E0#define IEEE80211_STYPE_QOS_CFACKPOLL		0x00F0/* miscellaneous IEEE 802.11 constants */#define IEEE80211_MAX_FRAG_THRESHOLD	2346#define IEEE80211_MAX_RTS_THRESHOLD	2347#define IEEE80211_MAX_AID		2007#define IEEE80211_MAX_TIM_LEN		251#define IEEE80211_MAX_DATA_LEN		2304/* Maximum size for the MA-UNITDATA primitive, 802.11 standard section   6.2.1.1.2.   The figure in section 7.1.2 suggests a body size of up to 2312   bytes is allowed, which is a bit confusing, I suspect this   represents the 2304 bytes of real data, plus a possible 8 bytes of   WEP IV and ICV. (this interpretation suggested by Ramiro Barreiro) */#define IEEE80211_MAX_SSID_LEN		32struct ieee80211_hdr {	__le16 frame_control;	__le16 duration_id;	u8 addr1[6];	u8 addr2[6];	u8 addr3[6];	__le16 seq_ctrl;	u8 addr4[6];} __attribute__ ((packed));struct ieee80211_mgmt {	__le16 frame_control;	__le16 duration;	u8 da[6];	u8 sa[6];	u8 bssid[6];	__le16 seq_ctrl;	union {		struct {			__le16 auth_alg;			__le16 auth_transaction;			__le16 status_code;			/* possibly followed by Challenge text */			u8 variable[0];		} __attribute__ ((packed)) auth;		struct {			__le16 reason_code;		} __attribute__ ((packed)) deauth;		struct {			__le16 capab_info;			__le16 listen_interval;			/* followed by SSID and Supported rates */			u8 variable[0];		} __attribute__ ((packed)) assoc_req;		struct {			__le16 capab_info;			__le16 status_code;			__le16 aid;			/* followed by Supported rates */			u8 variable[0];		} __attribute__ ((packed)) assoc_resp, reassoc_resp;		struct {			__le16 capab_info;			__le16 listen_interval;			u8 current_ap[6];			/* followed by SSID and Supported rates */			u8 variable[0];		} __attribute__ ((packed)) reassoc_req;		struct {			__le16 reason_code;		} __attribute__ ((packed)) disassoc;		struct {			__le64 timestamp;			__le16 beacon_int;			__le16 capab_info;			/* followed by some of SSID, Supported rates,			 * FH Params, DS Params, CF Params, IBSS Params, TIM */			u8 variable[0];		} __attribute__ ((packed)) beacon;		struct {			/* only variable items: SSID, Supported rates */			u8 variable[0];		} __attribute__ ((packed)) probe_req;		struct {			__le64 timestamp;			__le16 beacon_int;			__le16 capab_info;			/* followed by some of SSID, Supported rates,			 * FH Params, DS Params, CF Params, IBSS Params */			u8 variable[0];		} __attribute__ ((packed)) probe_resp;		struct {			u8 category;			union {				struct {					u8 action_code;					u8 dialog_token;					u8 status_code;					u8 variable[0];				} __attribute__ ((packed)) wme_action;				struct{					u8 action_code;					u8 element_id;					u8 length;					u8 switch_mode;					u8 new_chan;					u8 switch_count;				} __attribute__((packed)) chan_switch;			} u;		} __attribute__ ((packed)) action;	} u;} __attribute__ ((packed));/* Control frames */struct ieee80211_rts {	__le16 frame_control;	__le16 duration;	u8 ra[6];	u8 ta[6];} __attribute__ ((packed));struct ieee80211_cts {	__le16 frame_control;	__le16 duration;	u8 ra[6];} __attribute__ ((packed));/* Authentication algorithms */#define WLAN_AUTH_OPEN 0#define WLAN_AUTH_SHARED_KEY 1#define WLAN_AUTH_FAST_BSS_TRANSITION 2#define WLAN_AUTH_LEAP 128#define WLAN_AUTH_CHALLENGE_LEN 128#define WLAN_CAPABILITY_ESS		(1<<0)#define WLAN_CAPABILITY_IBSS		(1<<1)#define WLAN_CAPABILITY_CF_POLLABLE	(1<<2)#define WLAN_CAPABILITY_CF_POLL_REQUEST	(1<<3)#define WLAN_CAPABILITY_PRIVACY		(1<<4)#define WLAN_CAPABILITY_SHORT_PREAMBLE	(1<<5)#define WLAN_CAPABILITY_PBCC		(1<<6)#define WLAN_CAPABILITY_CHANNEL_AGILITY	(1<<7)/* 802.11h */#define WLAN_CAPABILITY_SPECTRUM_MGMT	(1<<8)#define WLAN_CAPABILITY_QOS		(1<<9)#define WLAN_CAPABILITY_SHORT_SLOT_TIME	(1<<10)#define WLAN_CAPABILITY_DSSS_OFDM	(1<<13)/* 802.11g ERP information element */#define WLAN_ERP_NON_ERP_PRESENT (1<<0)#define WLAN_ERP_USE_PROTECTION (1<<1)#define WLAN_ERP_BARKER_PREAMBLE (1<<2)/* WLAN_ERP_BARKER_PREAMBLE values */enum {	WLAN_ERP_PREAMBLE_SHORT = 0,	WLAN_ERP_PREAMBLE_LONG = 1,};/* Status codes */enum ieee80211_statuscode {	WLAN_STATUS_SUCCESS = 0,	WLAN_STATUS_UNSPECIFIED_FAILURE = 1,	WLAN_STATUS_CAPS_UNSUPPORTED = 10,	WLAN_STATUS_REASSOC_NO_ASSOC = 11,	WLAN_STATUS_ASSOC_DENIED_UNSPEC = 12,	WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG = 13,	WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION = 14,	WLAN_STATUS_CHALLENGE_FAIL = 15,	WLAN_STATUS_AUTH_TIMEOUT = 16,	WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA = 17,	WLAN_STATUS_ASSOC_DENIED_RATES = 18,	/* 802.11b */	WLAN_STATUS_ASSOC_DENIED_NOSHORTPREAMBLE = 19,	WLAN_STATUS_ASSOC_DENIED_NOPBCC = 20,	WLAN_STATUS_ASSOC_DENIED_NOAGILITY = 21,	/* 802.11h */	WLAN_STATUS_ASSOC_DENIED_NOSPECTRUM = 22,	WLAN_STATUS_ASSOC_REJECTED_BAD_POWER = 23,	WLAN_STATUS_ASSOC_REJECTED_BAD_SUPP_CHAN = 24,	/* 802.11g */	WLAN_STATUS_ASSOC_DENIED_NOSHORTTIME = 25,	WLAN_STATUS_ASSOC_DENIED_NODSSSOFDM = 26,	/* 802.11i */	WLAN_STATUS_INVALID_IE = 40,	WLAN_STATUS_INVALID_GROUP_CIPHER = 41,	WLAN_STATUS_INVALID_PAIRWISE_CIPHER = 42,	WLAN_STATUS_INVALID_AKMP = 43,	WLAN_STATUS_UNSUPP_RSN_VERSION = 44,	WLAN_STATUS_INVALID_RSN_IE_CAP = 45,	WLAN_STATUS_CIPHER_SUITE_REJECTED = 46,};/* Reason codes */enum ieee80211_reasoncode {	WLAN_REASON_UNSPECIFIED = 1,	WLAN_REASON_PREV_AUTH_NOT_VALID = 2,	WLAN_REASON_DEAUTH_LEAVING = 3,	WLAN_REASON_DISASSOC_DUE_TO_INACTIVITY = 4,	WLAN_REASON_DISASSOC_AP_BUSY = 5,	WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA = 6,	WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA = 7,	WLAN_REASON_DISASSOC_STA_HAS_LEFT = 8,	WLAN_REASON_STA_REQ_ASSOC_WITHOUT_AUTH = 9,	/* 802.11h */	WLAN_REASON_DISASSOC_BAD_POWER = 10,	WLAN_REASON_DISASSOC_BAD_SUPP_CHAN = 11,	/* 802.11i */	WLAN_REASON_INVALID_IE = 13,	WLAN_REASON_MIC_FAILURE = 14,	WLAN_REASON_4WAY_HANDSHAKE_TIMEOUT = 15,	WLAN_REASON_GROUP_KEY_HANDSHAKE_TIMEOUT = 16,	WLAN_REASON_IE_DIFFERENT = 17,	WLAN_REASON_INVALID_GROUP_CIPHER = 18,	WLAN_REASON_INVALID_PAIRWISE_CIPHER = 19,	WLAN_REASON_INVALID_AKMP = 20,	WLAN_REASON_UNSUPP_RSN_VERSION = 21,	WLAN_REASON_INVALID_RSN_IE_CAP = 22,	WLAN_REASON_IEEE8021X_FAILED = 23,	WLAN_REASON_CIPHER_SUITE_REJECTED = 24,};/* Information Element IDs */enum ieee80211_eid {	WLAN_EID_SSID = 0,	WLAN_EID_SUPP_RATES = 1,	WLAN_EID_FH_PARAMS = 2,	WLAN_EID_DS_PARAMS = 3,	WLAN_EID_CF_PARAMS = 4,	WLAN_EID_TIM = 5,	WLAN_EID_IBSS_PARAMS = 6,	WLAN_EID_CHALLENGE = 16,	/* 802.11d */	WLAN_EID_COUNTRY = 7,	WLAN_EID_HP_PARAMS = 8,	WLAN_EID_HP_TABLE = 9,	WLAN_EID_REQUEST = 10,	/* 802.11h */	WLAN_EID_PWR_CONSTRAINT = 32,	WLAN_EID_PWR_CAPABILITY = 33,	WLAN_EID_TPC_REQUEST = 34,	WLAN_EID_TPC_REPORT = 35,	WLAN_EID_SUPPORTED_CHANNELS = 36,	WLAN_EID_CHANNEL_SWITCH = 37,	WLAN_EID_MEASURE_REQUEST = 38,	WLAN_EID_MEASURE_REPORT = 39,	WLAN_EID_QUIET = 40,	WLAN_EID_IBSS_DFS = 41,	/* 802.11g */	WLAN_EID_ERP_INFO = 42,	WLAN_EID_EXT_SUPP_RATES = 50,	/* 802.11i */	WLAN_EID_RSN = 48,	WLAN_EID_WPA = 221,	WLAN_EID_GENERIC = 221,	WLAN_EID_VENDOR_SPECIFIC = 221,	WLAN_EID_QOS_PARAMETER = 222};/* cipher suite selectors */#define WLAN_CIPHER_SUITE_USE_GROUP	0x000FAC00#define WLAN_CIPHER_SUITE_WEP40		0x000FAC01#define WLAN_CIPHER_SUITE_TKIP		0x000FAC02/* reserved: 				0x000FAC03 */#define WLAN_CIPHER_SUITE_CCMP		0x000FAC04#define WLAN_CIPHER_SUITE_WEP104	0x000FAC05#define WLAN_MAX_KEY_LEN		32/** * ieee80211_get_SA - get pointer to SA * * Given an 802.11 frame, this function returns the offset * to the source address (SA). It does not verify that the * header is long enough to contain the address, and the * header must be long enough to contain the frame control * field. * * @hdr: the frame */static inline u8 *ieee80211_get_SA(struct ieee80211_hdr *hdr){	u8 *raw = (u8 *) hdr;	u8 tofrom = (*(raw+1)) & 3; /* get the TODS and FROMDS bits */	switch (tofrom) {		case 2:			return hdr->addr3;		case 3:			return hdr->addr4;	}	return hdr->addr2;}/** * ieee80211_get_DA - get pointer to DA * * Given an 802.11 frame, this function returns the offset * to the destination address (DA). It does not verify that * the header is long enough to contain the address, and the * header must be long enough to contain the frame control * field. * * @hdr: the frame */static inline u8 *ieee80211_get_DA(struct ieee80211_hdr *hdr){	u8 *raw = (u8 *) hdr;	u8 to_ds = (*(raw+1)) & 1; /* get the TODS bit */	if (to_ds)		return hdr->addr3;	return hdr->addr1;}/** * ieee80211_get_morefrag - determine whether the MOREFRAGS bit is set * * This function determines whether the "more fragments" bit is set * in the frame. * * @hdr: the frame */static inline int ieee80211_get_morefrag(struct ieee80211_hdr *hdr){	return (le16_to_cpu(hdr->frame_control) &		IEEE80211_FCTL_MOREFRAGS) != 0;}#endif /* IEEE80211_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -