diff options
Diffstat (limited to 'drivers/net/wireless/mwifiex/cmdevt.c')
| -rw-r--r-- | drivers/net/wireless/mwifiex/cmdevt.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/drivers/net/wireless/mwifiex/cmdevt.c b/drivers/net/wireless/mwifiex/cmdevt.c index 20a6c5555873..b5c8b962ce12 100644 --- a/drivers/net/wireless/mwifiex/cmdevt.c +++ b/drivers/net/wireless/mwifiex/cmdevt.c | |||
| @@ -157,6 +157,20 @@ static int mwifiex_dnld_cmd_to_fw(struct mwifiex_private *priv, | |||
| 157 | return -1; | 157 | return -1; |
| 158 | } | 158 | } |
| 159 | 159 | ||
| 160 | cmd_code = le16_to_cpu(host_cmd->command); | ||
| 161 | cmd_size = le16_to_cpu(host_cmd->size); | ||
| 162 | |||
| 163 | if (adapter->hw_status == MWIFIEX_HW_STATUS_RESET && | ||
| 164 | cmd_code != HostCmd_CMD_FUNC_SHUTDOWN && | ||
| 165 | cmd_code != HostCmd_CMD_FUNC_INIT) { | ||
| 166 | dev_err(adapter->dev, | ||
| 167 | "DNLD_CMD: FW in reset state, ignore cmd %#x\n", | ||
| 168 | cmd_code); | ||
| 169 | mwifiex_complete_cmd(adapter, cmd_node); | ||
| 170 | mwifiex_insert_cmd_to_free_q(adapter, cmd_node); | ||
| 171 | return -1; | ||
| 172 | } | ||
| 173 | |||
| 160 | /* Set command sequence number */ | 174 | /* Set command sequence number */ |
| 161 | adapter->seq_num++; | 175 | adapter->seq_num++; |
| 162 | host_cmd->seq_num = cpu_to_le16(HostCmd_SET_SEQ_NO_BSS_INFO | 176 | host_cmd->seq_num = cpu_to_le16(HostCmd_SET_SEQ_NO_BSS_INFO |
| @@ -168,9 +182,6 @@ static int mwifiex_dnld_cmd_to_fw(struct mwifiex_private *priv, | |||
| 168 | adapter->curr_cmd = cmd_node; | 182 | adapter->curr_cmd = cmd_node; |
| 169 | spin_unlock_irqrestore(&adapter->mwifiex_cmd_lock, flags); | 183 | spin_unlock_irqrestore(&adapter->mwifiex_cmd_lock, flags); |
| 170 | 184 | ||
| 171 | cmd_code = le16_to_cpu(host_cmd->command); | ||
| 172 | cmd_size = le16_to_cpu(host_cmd->size); | ||
| 173 | |||
| 174 | /* Adjust skb length */ | 185 | /* Adjust skb length */ |
| 175 | if (cmd_node->cmd_skb->len > cmd_size) | 186 | if (cmd_node->cmd_skb->len > cmd_size) |
| 176 | /* | 187 | /* |
| @@ -484,8 +495,6 @@ int mwifiex_send_cmd_sync(struct mwifiex_private *priv, uint16_t cmd_no, | |||
| 484 | 495 | ||
| 485 | ret = mwifiex_send_cmd_async(priv, cmd_no, cmd_action, cmd_oid, | 496 | ret = mwifiex_send_cmd_async(priv, cmd_no, cmd_action, cmd_oid, |
| 486 | data_buf); | 497 | data_buf); |
| 487 | if (!ret) | ||
| 488 | ret = mwifiex_wait_queue_complete(adapter); | ||
| 489 | 498 | ||
| 490 | return ret; | 499 | return ret; |
| 491 | } | 500 | } |
| @@ -588,9 +597,10 @@ int mwifiex_send_cmd_async(struct mwifiex_private *priv, uint16_t cmd_no, | |||
| 588 | if (cmd_no == HostCmd_CMD_802_11_SCAN) { | 597 | if (cmd_no == HostCmd_CMD_802_11_SCAN) { |
| 589 | mwifiex_queue_scan_cmd(priv, cmd_node); | 598 | mwifiex_queue_scan_cmd(priv, cmd_node); |
| 590 | } else { | 599 | } else { |
| 591 | adapter->cmd_queued = cmd_node; | ||
| 592 | mwifiex_insert_cmd_to_pending_q(adapter, cmd_node, true); | 600 | mwifiex_insert_cmd_to_pending_q(adapter, cmd_node, true); |
| 593 | queue_work(adapter->workqueue, &adapter->main_work); | 601 | queue_work(adapter->workqueue, &adapter->main_work); |
| 602 | if (cmd_node->wait_q_enabled) | ||
| 603 | ret = mwifiex_wait_queue_complete(adapter, cmd_node); | ||
| 594 | } | 604 | } |
| 595 | 605 | ||
| 596 | return ret; | 606 | return ret; |
