Merge "qcacld-3.0: Add a flag check to remove the cmd in find req" into wlan-cld3.driver.lnx.2.0-dev
这个提交包含在:

提交者
Gerrit - the friendly Code Review server

当前提交
141b27102b
@@ -352,11 +352,13 @@ static struct wma_target_req *wma_find_remove_req_msgtype(tp_wma_handle wma,
|
||||
* @wma: wma handle
|
||||
* @vdev_id: vdev id
|
||||
* @type: request type
|
||||
* @remove_req_from_list: flag to indicate remove req or not.
|
||||
*
|
||||
* Return: return target request if found or NULL.
|
||||
*/
|
||||
static struct wma_target_req *wma_find_vdev_req(tp_wma_handle wma,
|
||||
uint8_t vdev_id, uint8_t type)
|
||||
uint8_t vdev_id, uint8_t type,
|
||||
bool remove_req_from_list)
|
||||
{
|
||||
struct wma_target_req *req_msg = NULL;
|
||||
bool found = false;
|
||||
@@ -381,12 +383,16 @@ static struct wma_target_req *wma_find_vdev_req(tp_wma_handle wma,
|
||||
continue;
|
||||
|
||||
found = true;
|
||||
status = qdf_list_remove_node(&wma->vdev_resp_queue, node1);
|
||||
if (QDF_STATUS_SUCCESS != status) {
|
||||
qdf_spin_unlock_bh(&wma->vdev_respq_lock);
|
||||
WMA_LOGD(FL("Failed to target req for vdev_id %d type %d"),
|
||||
vdev_id, type);
|
||||
return NULL;
|
||||
if (remove_req_from_list) {
|
||||
status = qdf_list_remove_node(&wma->vdev_resp_queue,
|
||||
node1);
|
||||
if (QDF_STATUS_SUCCESS != status) {
|
||||
qdf_spin_unlock_bh(&wma->vdev_respq_lock);
|
||||
WMA_LOGD(FL(
|
||||
"Failed to target req for vdev_id %d type %d"),
|
||||
vdev_id, type);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
break;
|
||||
} while (QDF_STATUS_SUCCESS ==
|
||||
@@ -452,7 +458,8 @@ static void wma_vdev_detach_callback(void *ctx)
|
||||
if (!WMI_SERVICE_IS_ENABLED(wma->wmi_service_bitmap,
|
||||
WMI_SERVICE_SYNC_DELETE_CMDS)) {
|
||||
req_msg = wma_find_vdev_req(wma, param->session_id,
|
||||
WMA_TARGET_REQ_TYPE_VDEV_DEL);
|
||||
WMA_TARGET_REQ_TYPE_VDEV_DEL,
|
||||
true);
|
||||
if (req_msg) {
|
||||
WMA_LOGD("%s: Found vdev request for vdev id %d",
|
||||
__func__, param->session_id);
|
||||
@@ -643,7 +650,7 @@ QDF_STATUS wma_vdev_detach(tp_wma_handle wma_handle,
|
||||
|
||||
if (qdf_atomic_read(&iface->bss_status) == WMA_BSS_STATUS_STARTED) {
|
||||
req_msg = wma_find_vdev_req(wma_handle, vdev_id,
|
||||
WMA_TARGET_REQ_TYPE_VDEV_STOP);
|
||||
WMA_TARGET_REQ_TYPE_VDEV_STOP, false);
|
||||
if (!req_msg)
|
||||
goto send_fail_rsp;
|
||||
if (req_msg->msg_type != WMA_DELETE_BSS_REQ)
|
||||
@@ -986,7 +993,8 @@ int wma_vdev_start_resp_handler(void *handle, uint8_t *cmd_param_info,
|
||||
iface = &wma->interfaces[resp_event->vdev_id];
|
||||
|
||||
req_msg = wma_find_vdev_req(wma, resp_event->vdev_id,
|
||||
WMA_TARGET_REQ_TYPE_VDEV_START);
|
||||
WMA_TARGET_REQ_TYPE_VDEV_START,
|
||||
true);
|
||||
|
||||
if (!req_msg) {
|
||||
WMA_LOGE("%s: Failed to lookup request message for vdev %d",
|
||||
@@ -1780,7 +1788,7 @@ int wma_vdev_stop_resp_handler(void *handle, uint8_t *cmd_param_info,
|
||||
resp_event = param_buf->fixed_param;
|
||||
|
||||
req_msg = wma_find_vdev_req(wma, resp_event->vdev_id,
|
||||
WMA_TARGET_REQ_TYPE_VDEV_STOP);
|
||||
WMA_TARGET_REQ_TYPE_VDEV_STOP, true);
|
||||
if (!req_msg) {
|
||||
WMA_LOGE("%s: Failed to lookup vdev request for vdev id %d",
|
||||
__func__, resp_event->vdev_id);
|
||||
@@ -2545,7 +2553,7 @@ int wma_vdev_delete_handler(void *handle, uint8_t *cmd_param_info,
|
||||
|
||||
WMA_LOGD("%s Vdev delete resp vdev id %d", __func__, event->vdev_id);
|
||||
req_msg = wma_find_vdev_req(wma, event->vdev_id,
|
||||
WMA_TARGET_REQ_TYPE_VDEV_DEL);
|
||||
WMA_TARGET_REQ_TYPE_VDEV_DEL, true);
|
||||
if (!req_msg) {
|
||||
WMA_LOGD(FL("Vdev delete resp is not handled! vdev id %d"),
|
||||
event->vdev_id);
|
||||
@@ -2896,7 +2904,7 @@ void wma_vdev_resp_timer(void *data)
|
||||
|
||||
WMA_LOGA("%s: request %d is timed out for vdev_id - %d", __func__,
|
||||
tgt_req->msg_type, tgt_req->vdev_id);
|
||||
msg = wma_find_vdev_req(wma, tgt_req->vdev_id, tgt_req->type);
|
||||
msg = wma_find_vdev_req(wma, tgt_req->vdev_id, tgt_req->type, true);
|
||||
|
||||
if (!msg) {
|
||||
WMA_LOGE("%s: Failed to lookup request message - %d",
|
||||
@@ -3145,7 +3153,7 @@ void wma_remove_vdev_req(tp_wma_handle wma, uint8_t vdev_id,
|
||||
{
|
||||
struct wma_target_req *req_msg;
|
||||
|
||||
req_msg = wma_find_vdev_req(wma, vdev_id, type);
|
||||
req_msg = wma_find_vdev_req(wma, vdev_id, type, true);
|
||||
if (!req_msg)
|
||||
return;
|
||||
|
||||
|
在新工单中引用
屏蔽一个用户