diff options
Diffstat (limited to 'drivers/net/wireless/ath/ath9k/common.h')
| -rw-r--r-- | drivers/net/wireless/ath/ath9k/common.h | 69 | 
1 files changed, 43 insertions, 26 deletions
diff --git a/drivers/net/wireless/ath/ath9k/common.h b/drivers/net/wireless/ath/ath9k/common.h index 4c04ee85ff0..ffc454b1863 100644 --- a/drivers/net/wireless/ath/ath9k/common.h +++ b/drivers/net/wireless/ath/ath9k/common.h @@ -1,5 +1,5 @@  /* - * Copyright (c) 2009 Atheros Communications Inc. + * Copyright (c) 2009-2011 Atheros Communications Inc.   *   * Permission to use, copy, modify, and/or distribute this software for any   * purpose with or without fee is hereby granted, provided that the above @@ -17,28 +17,21 @@  #include <net/mac80211.h>  #include "../ath.h" -#include "../debug.h"  #include "hw.h"  #include "hw-ops.h" -/* Common header for Atheros 802.11n base driver cores */ +#include "common-init.h" +#include "common-beacon.h" +#include "common-debug.h" -#define IEEE80211_WEP_NKID 4 +/* Common header for Atheros 802.11n base driver cores */ -#define WME_NUM_TID             16  #define WME_BA_BMP_SIZE         64  #define WME_MAX_BA              WME_BA_BMP_SIZE  #define ATH_TID_MAX_BUFS        (2 * WME_MAX_BA) -/* These must match mac80211 skb queue mapping numbers */ -#define WME_AC_VO   0 -#define WME_AC_VI   1 -#define WME_AC_BE   2 -#define WME_AC_BK   3 -#define WME_NUM_AC  4 - -#define ATH_RSSI_DUMMY_MARKER   0x127 +#define ATH_RSSI_DUMMY_MARKER   127  #define ATH_RSSI_LPF_LEN 		10  #define RSSI_LPF_THRESHOLD		-20  #define ATH_RSSI_EP_MULTIPLIER     (1<<7) @@ -51,23 +44,47 @@  	x = ATH_LPF_RSSI((x), ATH_RSSI_IN((y)), ATH_RSSI_LPF_LEN);  	\  } while (0)  #define ATH_EP_RND(x, mul) 						\ -	((((x)%(mul)) >= ((mul)/2)) ? ((x) + ((mul) - 1)) / (mul) : (x)/(mul)) +	(((x) + ((mul)/2)) / (mul)) + +#define IEEE80211_MS_TO_TU(x)   (((x) * 1000) / 1024) -/* Defines the BT AR_BT_COEX_WGHT used */ -enum ath_stomp_type { -	ATH_BTCOEX_NO_STOMP, -	ATH_BTCOEX_STOMP_ALL, -	ATH_BTCOEX_STOMP_LOW, -	ATH_BTCOEX_STOMP_NONE +struct ath_beacon_config { +	int beacon_interval; +	u16 dtim_period; +	u16 bmiss_timeout; +	u8 dtim_count; +	bool enable_beacon; +	bool ibss_creator; +	u32 nexttbtt; +	u32 intval;  }; -int ath9k_cmn_padpos(__le16 frame_control); +bool ath9k_cmn_rx_accept(struct ath_common *common, +			 struct ieee80211_hdr *hdr, +			 struct ieee80211_rx_status *rxs, +			 struct ath_rx_status *rx_stats, +			 bool *decrypt_error, +			 unsigned int rxfilter); +void ath9k_cmn_rx_skb_postprocess(struct ath_common *common, +				  struct sk_buff *skb, +				  struct ath_rx_status *rx_stats, +				  struct ieee80211_rx_status *rxs, +				  bool decrypt_error); +int ath9k_cmn_process_rate(struct ath_common *common, +			   struct ieee80211_hw *hw, +			   struct ath_rx_status *rx_stats, +			   struct ieee80211_rx_status *rxs); +void ath9k_cmn_process_rssi(struct ath_common *common, +			    struct ieee80211_hw *hw, +			    struct ath_rx_status *rx_stats, +			    struct ieee80211_rx_status *rxs);  int ath9k_cmn_get_hw_crypto_keytype(struct sk_buff *skb); -void ath9k_cmn_update_ichannel(struct ath9k_channel *ichan, -			       struct ieee80211_channel *chan, -			       enum nl80211_channel_type channel_type); -struct ath9k_channel *ath9k_cmn_get_curchannel(struct ieee80211_hw *hw, -					       struct ath_hw *ah); +struct ath9k_channel *ath9k_cmn_get_channel(struct ieee80211_hw *hw, +					    struct ath_hw *ah, +					    struct cfg80211_chan_def *chandef);  int ath9k_cmn_count_streams(unsigned int chainmask, int max);  void ath9k_cmn_btcoex_bt_stomp(struct ath_common *common,  				  enum ath_stomp_type stomp_type); +void ath9k_cmn_update_txpow(struct ath_hw *ah, u16 cur_txpow, +			    u16 new_txpow, u16 *txpower); +void ath9k_cmn_init_crypto(struct ath_hw *ah);  | 
