123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 |
- /*
- * Copyright (c) 2010-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
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
- #ifndef COMMON_H
- #define COMMON_H
- #include <linux/netdevice.h>
- #define ATH6KL_MAX_IE 256
- extern int ath6kl_printk(const char *level, const char *fmt, ...);
- #define A_CACHE_LINE_PAD 128
- /*
- * Reflects the version of binary interface exposed by ATH6KL target
- * firmware. Needs to be incremented by 1 for any change in the firmware
- * that requires upgrade of the driver on the host side for the change to
- * work correctly
- */
- #define ATH6KL_ABI_VERSION 1
- #define SIGNAL_QUALITY_METRICS_NUM_MAX 2
- enum {
- SIGNAL_QUALITY_METRICS_SNR = 0,
- SIGNAL_QUALITY_METRICS_RSSI,
- SIGNAL_QUALITY_METRICS_ALL,
- };
- /*
- * Data Path
- */
- #define WMI_MAX_TX_DATA_FRAME_LENGTH \
- (1500 + sizeof(struct wmi_data_hdr) + \
- sizeof(struct ethhdr) + \
- sizeof(struct ath6kl_llc_snap_hdr))
- /* An AMSDU frame */ /* The MAX AMSDU length of AR6003 is 3839 */
- #define WMI_MAX_AMSDU_RX_DATA_FRAME_LENGTH \
- (3840 + sizeof(struct wmi_data_hdr) + \
- sizeof(struct ethhdr) + \
- sizeof(struct ath6kl_llc_snap_hdr))
- #define EPPING_ALIGNMENT_PAD \
- (((sizeof(struct htc_frame_hdr) + 3) & (~0x3)) \
- - sizeof(struct htc_frame_hdr))
- struct ath6kl_llc_snap_hdr {
- u8 dsap;
- u8 ssap;
- u8 cntl;
- u8 org_code[3];
- __be16 eth_type;
- } __packed;
- enum crypto_type {
- NONE_CRYPT = 0x01,
- WEP_CRYPT = 0x02,
- TKIP_CRYPT = 0x04,
- AES_CRYPT = 0x08,
- };
- #define ATH6KL_NODE_HASHSIZE 32
- /* simple hash is enough for variation of macaddr */
- #define ATH6KL_NODE_HASH(addr) \
- (((const u8 *)(addr))[ETH_ALEN - 1] % \
- ATH6KL_NODE_HASHSIZE)
- /*
- * Table of ath6kl_node instances. Each ieee80211com
- * has at least one for holding the scan candidates.
- * When operating as an access point or in ibss mode there
- * is a second table for associated stations or neighbors.
- */
- struct ath6kl_node_table {
- spinlock_t nt_nodelock; /* on node table */
- struct bss *nt_node_first; /* information of all nodes */
- struct bss *nt_node_last; /* information of all nodes */
- struct bss *nt_hash[ATH6KL_NODE_HASHSIZE];
- const char *nt_name; /* for debugging */
- u32 nt_node_age; /* node aging time */
- };
- #define WLAN_NODE_INACT_TIMEOUT_MSEC 120000
- #define WLAN_NODE_INACT_CNT 4
- struct ath6kl_common_ie {
- u16 ie_chan;
- u8 *ie_tstamp;
- u8 *ie_ssid;
- u8 *ie_rates;
- u8 *ie_xrates;
- u8 *ie_country;
- u8 *ie_wpa;
- u8 *ie_rsn;
- u8 *ie_wmm;
- u8 *ie_ath;
- u16 ie_capInfo;
- u16 ie_beaconInt;
- u8 *ie_tim;
- u8 *ie_chswitch;
- u8 ie_erp;
- u8 *ie_wsc;
- u8 *ie_htcap;
- u8 *ie_htop;
- };
- struct bss {
- u8 ni_macaddr[ETH_ALEN];
- u8 ni_snr;
- s16 ni_rssi;
- struct bss *ni_list_next;
- struct bss *ni_list_prev;
- struct bss *ni_hash_next;
- struct bss *ni_hash_prev;
- struct ath6kl_common_ie ni_cie;
- u8 *ni_buf;
- u16 ni_framelen;
- struct ath6kl_node_table *ni_table;
- u32 ni_refcnt;
- u32 ni_tstamp;
- u32 ni_actcnt;
- };
- struct htc_endpoint_credit_dist;
- struct ath6kl;
- enum htc_credit_dist_reason;
- struct htc_credit_state_info;
- struct bss *wlan_node_alloc(int wh_size);
- void wlan_node_free(struct bss *ni);
- void wlan_setup_node(struct ath6kl_node_table *nt, struct bss *ni,
- const u8 *mac_addr);
- struct bss *wlan_find_node(struct ath6kl_node_table *nt,
- const u8 *mac_addr);
- void wlan_node_reclaim(struct ath6kl_node_table *nt, struct bss *ni);
- void wlan_free_allnodes(struct ath6kl_node_table *nt);
- void wlan_iterate_nodes(struct ath6kl_node_table *nt, void *arg);
- void wlan_node_table_init(struct ath6kl_node_table *nt);
- void wlan_node_table_cleanup(struct ath6kl_node_table *nt);
- void wlan_refresh_inactive_nodes(struct ath6kl *ar);
- struct bss *wlan_find_ssid_node(struct ath6kl_node_table *nt, u8 *ssid,
- u32 ssid_len, bool is_wpa2, bool match_ssid);
- void wlan_node_return(struct ath6kl_node_table *nt, struct bss *ni);
- int ath6k_setup_credit_dist(void *htc_handle,
- struct htc_credit_state_info *cred_info);
- void ath6k_credit_distribute(struct htc_credit_state_info *cred_inf,
- struct list_head *epdist_list,
- enum htc_credit_dist_reason reason);
- void ath6k_credit_init(struct htc_credit_state_info *cred_inf,
- struct list_head *ep_list,
- int tot_credits);
- void ath6k_seek_credits(struct htc_credit_state_info *cred_inf,
- struct htc_endpoint_credit_dist *ep_dist);
- struct ath6kl *ath6kl_core_alloc(struct device *sdev);
- int ath6kl_core_init(struct ath6kl *ar);
- int ath6kl_unavail_ev(struct ath6kl *ar);
- struct sk_buff *ath6kl_buf_alloc(int size);
- #endif /* COMMON_H */
|