|
@@ -362,10 +362,28 @@ int mwifiex_cmd_11n_addba_rsp_gen(struct mwifiex_private *priv,
|
|
|
*cmd_addba_req)
|
|
|
{
|
|
|
struct host_cmd_ds_11n_addba_rsp *add_ba_rsp = &cmd->params.add_ba_rsp;
|
|
|
+ struct mwifiex_sta_node *sta_ptr;
|
|
|
+ u32 rx_win_size = priv->add_ba_param.rx_win_size;
|
|
|
u8 tid;
|
|
|
int win_size;
|
|
|
uint16_t block_ack_param_set;
|
|
|
|
|
|
+ if ((GET_BSS_ROLE(priv) == MWIFIEX_BSS_ROLE_STA) &&
|
|
|
+ ISSUPP_TDLS_ENABLED(priv->adapter->fw_cap_info) &&
|
|
|
+ priv->adapter->is_hw_11ac_capable &&
|
|
|
+ memcmp(priv->cfg_bssid, cmd_addba_req->peer_mac_addr, ETH_ALEN)) {
|
|
|
+ sta_ptr = mwifiex_get_sta_entry(priv,
|
|
|
+ cmd_addba_req->peer_mac_addr);
|
|
|
+ if (!sta_ptr) {
|
|
|
+ dev_warn(priv->adapter->dev,
|
|
|
+ "BA setup with unknown TDLS peer %pM!\n",
|
|
|
+ cmd_addba_req->peer_mac_addr);
|
|
|
+ return -1;
|
|
|
+ }
|
|
|
+ if (sta_ptr->is_11ac_enabled)
|
|
|
+ rx_win_size = MWIFIEX_11AC_STA_AMPDU_DEF_RXWINSIZE;
|
|
|
+ }
|
|
|
+
|
|
|
cmd->command = cpu_to_le16(HostCmd_CMD_11N_ADDBA_RSP);
|
|
|
cmd->size = cpu_to_le16(sizeof(*add_ba_rsp) + S_DS_GEN);
|
|
|
|
|
@@ -382,8 +400,7 @@ int mwifiex_cmd_11n_addba_rsp_gen(struct mwifiex_private *priv,
|
|
|
block_ack_param_set &= ~IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
|
|
|
/* We donot support AMSDU inside AMPDU, hence reset the bit */
|
|
|
block_ack_param_set &= ~BLOCKACKPARAM_AMSDU_SUPP_MASK;
|
|
|
- block_ack_param_set |= (priv->add_ba_param.rx_win_size <<
|
|
|
- BLOCKACKPARAM_WINSIZE_POS);
|
|
|
+ block_ack_param_set |= rx_win_size << BLOCKACKPARAM_WINSIZE_POS;
|
|
|
add_ba_rsp->block_ack_param_set = cpu_to_le16(block_ack_param_set);
|
|
|
win_size = (le16_to_cpu(add_ba_rsp->block_ack_param_set)
|
|
|
& IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK)
|