aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/mwl8k.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/mwl8k.c')
-rw-r--r--drivers/net/wireless/mwl8k.c73
1 files changed, 8 insertions, 65 deletions
diff --git a/drivers/net/wireless/mwl8k.c b/drivers/net/wireless/mwl8k.c
index c32e93c8c410..91b7062711e7 100644
--- a/drivers/net/wireless/mwl8k.c
+++ b/drivers/net/wireless/mwl8k.c
@@ -58,7 +58,6 @@ MODULE_DEVICE_TABLE(pci, mwl8k_table);
58#define MWL8K_HIU_H2A_INTERRUPT_STATUS_MASK 0x00000c28 58#define MWL8K_HIU_H2A_INTERRUPT_STATUS_MASK 0x00000c28
59#define MWL8K_H2A_INT_DUMMY (1 << 20) 59#define MWL8K_H2A_INT_DUMMY (1 << 20)
60#define MWL8K_H2A_INT_RESET (1 << 15) 60#define MWL8K_H2A_INT_RESET (1 << 15)
61#define MWL8K_H2A_INT_PS (1 << 2)
62#define MWL8K_H2A_INT_DOORBELL (1 << 1) 61#define MWL8K_H2A_INT_DOORBELL (1 << 1)
63#define MWL8K_H2A_INT_PPA_READY (1 << 0) 62#define MWL8K_H2A_INT_PPA_READY (1 << 0)
64 63
@@ -161,10 +160,8 @@ struct mwl8k_priv {
161 160
162 /* lock held over TX and TX reap */ 161 /* lock held over TX and TX reap */
163 spinlock_t tx_lock; 162 spinlock_t tx_lock;
164 u32 int_mask;
165 163
166 struct ieee80211_vif *vif; 164 struct ieee80211_vif *vif;
167 struct list_head vif_list;
168 165
169 struct ieee80211_channel *current_channel; 166 struct ieee80211_channel *current_channel;
170 167
@@ -173,10 +170,8 @@ struct mwl8k_priv {
173 dma_addr_t cookie_dma; 170 dma_addr_t cookie_dma;
174 171
175 u16 num_mcaddrs; 172 u16 num_mcaddrs;
176 u16 region_code;
177 u8 hw_rev; 173 u8 hw_rev;
178 __le32 fw_rev; 174 __le32 fw_rev;
179 u32 wep_enabled;
180 175
181 /* 176 /*
182 * Running count of TX packets in flight, to avoid 177 * Running count of TX packets in flight, to avoid
@@ -226,8 +221,6 @@ struct mwl8k_priv {
226 221
227/* Per interface specific private data */ 222/* Per interface specific private data */
228struct mwl8k_vif { 223struct mwl8k_vif {
229 struct list_head node;
230
231 /* backpointer to parent config block */ 224 /* backpointer to parent config block */
232 struct mwl8k_priv *priv; 225 struct mwl8k_priv *priv;
233 226
@@ -247,18 +240,11 @@ struct mwl8k_vif {
247 /* number of supported legacy rates */ 240 /* number of supported legacy rates */
248 u8 legacy_nrates; 241 u8 legacy_nrates;
249 242
250 /* Number of supported MCS rates. Work in progress */
251 u8 mcs_nrates;
252
253 /* Index into station database.Returned by update_sta_db call */ 243 /* Index into station database.Returned by update_sta_db call */
254 u8 peer_id; 244 u8 peer_id;
255 245
256 /* Non AMPDU sequence number assigned by driver */ 246 /* Non AMPDU sequence number assigned by driver */
257 u16 seqno; 247 u16 seqno;
258
259 /* Note:There is no channel info,
260 * refer to the master channel info in priv
261 */
262}; 248};
263 249
264#define MWL8K_VIF(_vif) ((struct mwl8k_vif *)&((_vif)->drv_priv)) 250#define MWL8K_VIF(_vif) ((struct mwl8k_vif *)&((_vif)->drv_priv))
@@ -681,11 +667,9 @@ struct ewc_ht_info {
681 667
682/* Peer Entry flags - used to define the type of the peer node */ 668/* Peer Entry flags - used to define the type of the peer node */
683#define MWL8K_PEER_TYPE_ACCESSPOINT 2 669#define MWL8K_PEER_TYPE_ACCESSPOINT 2
684#define MWL8K_PEER_TYPE_ADHOC_STATION 4
685 670
686#define MWL8K_IEEE_LEGACY_DATA_RATES 12 671#define MWL8K_IEEE_LEGACY_DATA_RATES 12
687#define MWL8K_MCS_BITMAP_SIZE 16 672#define MWL8K_MCS_BITMAP_SIZE 16
688#define pad_size 16
689 673
690struct peer_capability_info { 674struct peer_capability_info {
691 /* Peer type - AP vs. STA. */ 675 /* Peer type - AP vs. STA. */
@@ -707,7 +691,7 @@ struct peer_capability_info {
707 691
708 /* HT rate table. Intersection of our rates and peer rates. */ 692 /* HT rate table. Intersection of our rates and peer rates. */
709 __u8 ht_rates[MWL8K_MCS_BITMAP_SIZE]; 693 __u8 ht_rates[MWL8K_MCS_BITMAP_SIZE];
710 __u8 pad[pad_size]; 694 __u8 pad[16];
711 695
712 /* If set, interoperability mode, no proprietary extensions. */ 696 /* If set, interoperability mode, no proprietary extensions. */
713 __u8 interop; 697 __u8 interop;
@@ -717,15 +701,6 @@ struct peer_capability_info {
717} __attribute__((packed)); 701} __attribute__((packed));
718 702
719/* Inline functions to manipulate QoS field in data descriptor. */ 703/* Inline functions to manipulate QoS field in data descriptor. */
720static inline u16 mwl8k_qos_setbit_tid(u16 qos, u8 tid)
721{
722 u16 val_mask = 0x000f;
723 u16 qos_mask = ~val_mask;
724
725 /* TID bits 0-3 */
726 return (qos & qos_mask) | (tid & val_mask);
727}
728
729static inline u16 mwl8k_qos_setbit_eosp(u16 qos) 704static inline u16 mwl8k_qos_setbit_eosp(u16 qos)
730{ 705{
731 u16 val_mask = 1 << 4; 706 u16 val_mask = 1 << 4;
@@ -826,9 +801,7 @@ static inline struct sk_buff *mwl8k_add_dma_header(struct sk_buff *skb)
826/* 801/*
827 * Packet reception. 802 * Packet reception.
828 */ 803 */
829#define MWL8K_RX_CTRL_KEY_INDEX_MASK 0x30
830#define MWL8K_RX_CTRL_OWNED_BY_HOST 0x02 804#define MWL8K_RX_CTRL_OWNED_BY_HOST 0x02
831#define MWL8K_RX_CTRL_AMPDU 0x01
832 805
833struct mwl8k_rx_desc { 806struct mwl8k_rx_desc {
834 __le16 pkt_len; 807 __le16 pkt_len;
@@ -1073,8 +1046,6 @@ enum {
1073 1046
1074/* Transmit packet ACK policy */ 1047/* Transmit packet ACK policy */
1075#define MWL8K_TXD_ACK_POLICY_NORMAL 0 1048#define MWL8K_TXD_ACK_POLICY_NORMAL 0
1076#define MWL8K_TXD_ACK_POLICY_NONE 1
1077#define MWL8K_TXD_ACK_POLICY_NO_EXPLICIT 2
1078#define MWL8K_TXD_ACK_POLICY_BLOCKACK 3 1049#define MWL8K_TXD_ACK_POLICY_BLOCKACK 3
1079 1050
1080#define GET_TXQ(_ac) (\ 1051#define GET_TXQ(_ac) (\
@@ -1083,20 +1054,11 @@ enum {
1083 ((_ac) == WME_AC_BK) ? MWL8K_WME_AC_BK : \ 1054 ((_ac) == WME_AC_BK) ? MWL8K_WME_AC_BK : \
1084 MWL8K_WME_AC_BE) 1055 MWL8K_WME_AC_BE)
1085 1056
1086#define MWL8K_TXD_STATUS_IDLE 0x00000000
1087#define MWL8K_TXD_STATUS_USED 0x00000001
1088#define MWL8K_TXD_STATUS_OK 0x00000001 1057#define MWL8K_TXD_STATUS_OK 0x00000001
1089#define MWL8K_TXD_STATUS_OK_RETRY 0x00000002 1058#define MWL8K_TXD_STATUS_OK_RETRY 0x00000002
1090#define MWL8K_TXD_STATUS_OK_MORE_RETRY 0x00000004 1059#define MWL8K_TXD_STATUS_OK_MORE_RETRY 0x00000004
1091#define MWL8K_TXD_STATUS_MULTICAST_TX 0x00000008 1060#define MWL8K_TXD_STATUS_MULTICAST_TX 0x00000008
1092#define MWL8K_TXD_STATUS_BROADCAST_TX 0x00000010
1093#define MWL8K_TXD_STATUS_FAILED_LINK_ERROR 0x00000020
1094#define MWL8K_TXD_STATUS_FAILED_EXCEED_LIMIT 0x00000040
1095#define MWL8K_TXD_STATUS_FAILED_AGING 0x00000080
1096#define MWL8K_TXD_STATUS_HOST_CMD 0x40000000
1097#define MWL8K_TXD_STATUS_FW_OWNED 0x80000000 1061#define MWL8K_TXD_STATUS_FW_OWNED 0x80000000
1098#define MWL8K_TXD_SOFTSTALE 0x80
1099#define MWL8K_TXD_SOFTSTALE_MGMT_RETRY 0x01
1100 1062
1101struct mwl8k_tx_desc { 1063struct mwl8k_tx_desc {
1102 __le32 status; 1064 __le32 status;
@@ -1279,12 +1241,10 @@ static int mwl8k_tx_wait_empty(struct ieee80211_hw *hw, u32 delay_ms)
1279 return 0; 1241 return 0;
1280} 1242}
1281 1243
1282#define MWL8K_TXD_OK (MWL8K_TXD_STATUS_OK | \ 1244#define MWL8K_TXD_SUCCESS(status) \
1283 MWL8K_TXD_STATUS_OK_RETRY | \ 1245 ((status) & (MWL8K_TXD_STATUS_OK | \
1284 MWL8K_TXD_STATUS_OK_MORE_RETRY) 1246 MWL8K_TXD_STATUS_OK_RETRY | \
1285#define MWL8K_TXD_SUCCESS(stat) ((stat) & MWL8K_TXD_OK) 1247 MWL8K_TXD_STATUS_OK_MORE_RETRY))
1286#define MWL8K_TXD_FAIL_RETRY(stat) \
1287 ((stat) & (MWL8K_TXD_STATUS_FAILED_EXCEED_LIMIT))
1288 1248
1289static void mwl8k_txq_reclaim(struct ieee80211_hw *hw, int index, int force) 1249static void mwl8k_txq_reclaim(struct ieee80211_hw *hw, int index, int force)
1290{ 1250{
@@ -1671,7 +1631,6 @@ static int mwl8k_cmd_get_hw_spec(struct ieee80211_hw *hw)
1671 priv->num_mcaddrs = le16_to_cpu(cmd->num_mcaddrs); 1631 priv->num_mcaddrs = le16_to_cpu(cmd->num_mcaddrs);
1672 priv->fw_rev = le32_to_cpu(cmd->fw_rev); 1632 priv->fw_rev = le32_to_cpu(cmd->fw_rev);
1673 priv->hw_rev = cmd->hw_rev; 1633 priv->hw_rev = cmd->hw_rev;
1674 priv->region_code = le16_to_cpu(cmd->region_code);
1675 } 1634 }
1676 1635
1677 kfree(cmd); 1636 kfree(cmd);
@@ -2150,7 +2109,6 @@ struct mwl8k_cmd_set_edca_params {
2150 __u8 txq; 2109 __u8 txq;
2151} __attribute__((packed)); 2110} __attribute__((packed));
2152 2111
2153#define MWL8K_GET_EDCA_ALL 0
2154#define MWL8K_SET_EDCA_CW 0x01 2112#define MWL8K_SET_EDCA_CW 0x01
2155#define MWL8K_SET_EDCA_TXOP 0x02 2113#define MWL8K_SET_EDCA_TXOP 0x02
2156#define MWL8K_SET_EDCA_AIFS 0x04 2114#define MWL8K_SET_EDCA_AIFS 0x04
@@ -2323,18 +2281,12 @@ static int mwl8k_cmd_update_sta_db(struct ieee80211_hw *hw,
2323/* 2281/*
2324 * CMD_SET_AID. 2282 * CMD_SET_AID.
2325 */ 2283 */
2326#define IEEE80211_OPMODE_DISABLED 0x00
2327#define IEEE80211_OPMODE_NON_MEMBER_PROT_MODE 0x01
2328#define IEEE80211_OPMODE_ONE_20MHZ_STA_PROT_MODE 0x02
2329#define IEEE80211_OPMODE_HTMIXED_PROT_MODE 0x03
2330
2331#define MWL8K_RATE_INDEX_MAX_ARRAY 14 2284#define MWL8K_RATE_INDEX_MAX_ARRAY 14
2332 2285
2333#define MWL8K_FRAME_PROT_DISABLED 0x00 2286#define MWL8K_FRAME_PROT_DISABLED 0x00
2334#define MWL8K_FRAME_PROT_11G 0x07 2287#define MWL8K_FRAME_PROT_11G 0x07
2335#define MWL8K_FRAME_PROT_11N_HT_40MHZ_ONLY 0x02 2288#define MWL8K_FRAME_PROT_11N_HT_40MHZ_ONLY 0x02
2336#define MWL8K_FRAME_PROT_11N_HT_ALL 0x06 2289#define MWL8K_FRAME_PROT_11N_HT_ALL 0x06
2337#define MWL8K_FRAME_PROT_MASK 0x07
2338 2290
2339struct mwl8k_cmd_update_set_aid { 2291struct mwl8k_cmd_update_set_aid {
2340 struct mwl8k_cmd_pkt header; 2292 struct mwl8k_cmd_pkt header;
@@ -2439,10 +2391,6 @@ static int mwl8k_update_rateset(struct ieee80211_hw *hw,
2439 */ 2391 */
2440#define MWL8K_RATE_TABLE_SIZE 8 2392#define MWL8K_RATE_TABLE_SIZE 8
2441#define MWL8K_UCAST_RATE 0 2393#define MWL8K_UCAST_RATE 0
2442#define MWL8K_MCAST_RATE 1
2443#define MWL8K_BCAST_RATE 2
2444
2445#define MWL8K_USE_FIXED_RATE 0x0001
2446#define MWL8K_USE_AUTO_RATE 0x0002 2394#define MWL8K_USE_AUTO_RATE 0x0002
2447 2395
2448struct mwl8k_rate_entry { 2396struct mwl8k_rate_entry {
@@ -2535,7 +2483,6 @@ static irqreturn_t mwl8k_interrupt(int irq, void *dev_id)
2535 status = ioread32(priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS); 2483 status = ioread32(priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS);
2536 iowrite32(~status, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS); 2484 iowrite32(~status, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS);
2537 2485
2538 status &= priv->int_mask;
2539 if (!status) 2486 if (!status)
2540 return IRQ_NONE; 2487 return IRQ_NONE;
2541 2488
@@ -2873,7 +2820,7 @@ static int mwl8k_start(struct ieee80211_hw *hw)
2873 } 2820 }
2874 2821
2875 /* Enable interrupts */ 2822 /* Enable interrupts */
2876 iowrite32(priv->int_mask, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK); 2823 iowrite32(MWL8K_A2H_EVENTS, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK);
2877 2824
2878 worker = kzalloc(sizeof(*worker), GFP_KERNEL); 2825 worker = kzalloc(sizeof(*worker), GFP_KERNEL);
2879 if (worker == NULL) { 2826 if (worker == NULL) {
@@ -3532,7 +3479,6 @@ static int __devinit mwl8k_probe(struct pci_dev *pdev,
3532 priv->hostcmd_wait = NULL; 3479 priv->hostcmd_wait = NULL;
3533 priv->tx_wait = NULL; 3480 priv->tx_wait = NULL;
3534 priv->inconfig = false; 3481 priv->inconfig = false;
3535 priv->wep_enabled = 0;
3536 priv->wmm_mode = false; 3482 priv->wmm_mode = false;
3537 priv->pending_tx_pkts = 0; 3483 priv->pending_tx_pkts = 0;
3538 strncpy(priv->name, MWL8K_NAME, sizeof(priv->name)); 3484 strncpy(priv->name, MWL8K_NAME, sizeof(priv->name));
@@ -3614,8 +3560,7 @@ static int __devinit mwl8k_probe(struct pci_dev *pdev,
3614 } 3560 }
3615 3561
3616 iowrite32(0, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS); 3562 iowrite32(0, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS);
3617 priv->int_mask = 0; 3563 iowrite32(0, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK);
3618 iowrite32(priv->int_mask, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK);
3619 iowrite32(0, priv->regs + MWL8K_HIU_A2H_INTERRUPT_CLEAR_SEL); 3564 iowrite32(0, priv->regs + MWL8K_HIU_A2H_INTERRUPT_CLEAR_SEL);
3620 iowrite32(0xffffffff, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS_MASK); 3565 iowrite32(0xffffffff, priv->regs + MWL8K_HIU_A2H_INTERRUPT_STATUS_MASK);
3621 3566
@@ -3652,9 +3597,7 @@ static int __devinit mwl8k_probe(struct pci_dev *pdev,
3652 * commands use interrupts and avoids polling. Disable 3597 * commands use interrupts and avoids polling. Disable
3653 * interrupts when done. 3598 * interrupts when done.
3654 */ 3599 */
3655 priv->int_mask |= MWL8K_A2H_EVENTS; 3600 iowrite32(MWL8K_A2H_EVENTS, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK);
3656
3657 iowrite32(priv->int_mask, priv->regs + MWL8K_HIU_A2H_INTERRUPT_MASK);
3658 3601
3659 /* Get config data, mac addrs etc */ 3602 /* Get config data, mac addrs etc */
3660 rc = mwl8k_cmd_get_hw_spec(hw); 3603 rc = mwl8k_cmd_get_hw_spec(hw);