qcacmn: Fix vdev reference in NDP commands

Assign the vdev in NDP request message and hold the vdev reference till
the command is processed. Else the consumer of message will fail when
trying to take reference since vdev was not set in request packet.

Change-Id: I4c7e50690eff1f92f151f00209ec786a03252e76
CRs-Fixed: 2252035
This commit is contained in:
Naveen Rawat
2018-05-31 10:40:32 -07:00
committed by nshrivas
szülő 5811d874a6
commit b4a29b7a42
2 fájl változott, egészen pontosan 14 új sor hozzáadva és 18 régi sor törölve

Fájl megtekintése

@@ -341,7 +341,8 @@ static int os_if_nan_process_ndp_initiator_req(struct wlan_objmgr_psoc *psoc,
if (nan_vdev->vdev_mlme.vdev_opmode != QDF_NDI_MODE) {
cfg80211_err("Interface found is not NDI");
return -EINVAL;
ret = -EINVAL;
goto initiator_req_failed;
}
state = ucfg_nan_get_ndi_state(nan_vdev);
@@ -422,10 +423,12 @@ static int os_if_nan_process_ndp_initiator_req(struct wlan_objmgr_psoc *psoc,
req.service_instance_id, req.ndp_info.ndp_app_info_len,
req.ncs_sk_type, req.peer_discovery_mac_addr.bytes);
req.vdev = nan_vdev;
status = ucfg_nan_req_processor(nan_vdev, &req, NDP_INITIATOR_REQ);
ret = qdf_status_to_os_return(status);
initiator_req_failed:
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
if (ret)
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
return ret;
}
@@ -461,8 +464,7 @@ static int os_if_nan_process_ndp_responder_req(struct wlan_objmgr_psoc *psoc,
if (!tb[QCA_WLAN_VENDOR_ATTR_NDP_RESPONSE_CODE]) {
cfg80211_err("ndp_rsp is unavailable");
ret = -EINVAL;
goto responder_req_failed;
return -EINVAL;
}
req.ndp_rsp = nla_get_u32(tb[QCA_WLAN_VENDOR_ATTR_NDP_RESPONSE_CODE]);
@@ -484,7 +486,8 @@ static int os_if_nan_process_ndp_responder_req(struct wlan_objmgr_psoc *psoc,
if (nan_vdev->vdev_mlme.vdev_opmode != QDF_NDI_MODE) {
cfg80211_err("Interface found is not NDI");
return -ENODEV;
ret = -ENODEV;
goto responder_req_failed;
}
} else {
@@ -513,8 +516,6 @@ static int os_if_nan_process_ndp_responder_req(struct wlan_objmgr_psoc *psoc,
goto responder_req_failed;
}
req.vdev = nan_vdev;
if (!tb[QCA_WLAN_VENDOR_ATTR_NDP_TRANSACTION_ID]) {
cfg80211_err("Transaction ID is unavailable");
ret = -EINVAL;
@@ -562,11 +563,13 @@ static int os_if_nan_process_ndp_responder_req(struct wlan_objmgr_psoc *psoc,
req.ndp_instance_id, req.ndp_info.ndp_app_info_len,
req.ncs_sk_type);
req.vdev = nan_vdev;
status = ucfg_nan_req_processor(nan_vdev, &req, NDP_RESPONDER_REQ);
ret = qdf_status_to_os_return(status);
responder_req_failed:
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
if (ret)
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
return ret;
@@ -623,9 +626,11 @@ static int os_if_nan_process_ndp_end_req(struct wlan_objmgr_psoc *psoc,
return -EINVAL;
}
req.vdev = nan_vdev;
status = ucfg_nan_req_processor(nan_vdev, &req, NDP_END_REQ);
ret = qdf_status_to_os_return(status);
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
if (ret)
wlan_objmgr_vdev_release_ref(nan_vdev, WLAN_NAN_ID);
return ret;
}