qcacld-3.0: Send scan results to kernel as and when driver receives

Currently scan results are first cached in SME and then they are
updated to kernel using results in SME cache. This may result in
updation of stale entries to kernel. Fix this by sending scan results
to kernel as and when driver receives them.

Also, add changes to send ext scan results to kernel.

Change-Id: I18f4b36cf3a9fc2e191352c868f69d797eb0a786
CRs-Fixed: 1098411
This commit is contained in:
Padma, Santhosh Kumar
2017-01-16 19:34:45 +05:30
committed by qcabuildsw
parent be22d10f2f
commit 31bac74c81
5 changed files with 54 additions and 11 deletions

View File

@@ -1605,6 +1605,7 @@ struct hdd_context_s {
unsigned long tdls_source_bitmap; unsigned long tdls_source_bitmap;
/* tdls source timer to enable/disable TDLS on p2p listen */ /* tdls source timer to enable/disable TDLS on p2p listen */
qdf_mc_timer_t tdls_source_timer; qdf_mc_timer_t tdls_source_timer;
uint8_t beacon_probe_rsp_cnt_per_scan;
}; };
/* /*

View File

@@ -11320,6 +11320,7 @@ struct cfg80211_bss *wlan_hdd_cfg80211_inform_bss_frame(hdd_adapter_t *pAdapter,
bss_status = bss_status =
cfg80211_inform_bss_frame(wiphy, chan, mgmt, frame_len, rssi, cfg80211_inform_bss_frame(wiphy, chan, mgmt, frame_len, rssi,
GFP_KERNEL); GFP_KERNEL);
pHddCtx->beacon_probe_rsp_cnt_per_scan++;
kfree(mgmt); kfree(mgmt);
return bss_status; return bss_status;
} }

View File

@@ -1217,9 +1217,15 @@ static QDF_STATUS hdd_cfg80211_scan_done_callback(tHalHandle halHandle,
goto allow_suspend; goto allow_suspend;
} }
ret = wlan_hdd_cfg80211_update_bss((WLAN_HDD_GET_CTX(pAdapter))->wiphy, /*
pAdapter, scan_time); * cfg80211_scan_done informing NL80211 about completion
if (0 > ret) { * of scanning
*/
if (status == eCSR_SCAN_ABORT || status == eCSR_SCAN_FAILURE) {
aborted = true;
}
if (!aborted && !hddctx->beacon_probe_rsp_cnt_per_scan) {
hdd_notice("NO SCAN result"); hdd_notice("NO SCAN result");
if (hddctx->config->bug_report_for_no_scan_results) { if (hddctx->config->bug_report_for_no_scan_results) {
current_timestamp = jiffies_to_msecs(jiffies); current_timestamp = jiffies_to_msecs(jiffies);
@@ -1241,14 +1247,7 @@ static QDF_STATUS hdd_cfg80211_scan_done_callback(tHalHandle halHandle,
} }
} }
} }
hddctx->beacon_probe_rsp_cnt_per_scan = 0;
/*
* cfg80211_scan_done informing NL80211 about completion
* of scanning
*/
if (status == eCSR_SCAN_ABORT || status == eCSR_SCAN_FAILURE) {
aborted = true;
}
if (!wlan_hdd_is_scan_pending(pAdapter)) { if (!wlan_hdd_is_scan_pending(pAdapter)) {
/* Scan is no longer pending */ /* Scan is no longer pending */
@@ -1864,6 +1863,7 @@ static int __wlan_hdd_cfg80211_scan(struct wiphy *wiphy,
wlan_hdd_scan_request_enqueue(pAdapter, request, source, wlan_hdd_scan_request_enqueue(pAdapter, request, source,
scan_req.scan_id, scan_req.timestamp); scan_req.scan_id, scan_req.timestamp);
pAdapter->scan_info.mScanPending = true; pAdapter->scan_info.mScanPending = true;
pHddCtx->beacon_probe_rsp_cnt_per_scan = 0;
free_mem: free_mem:
if (scan_req.SSIDs.SSIDList) if (scan_req.SSIDs.SSIDList)

View File

@@ -509,6 +509,8 @@ __lim_ext_scan_forward_bcn_probe_rsp(tpAniSirGlobal pmac, uint8_t *rx_pkt_info,
uint8_t *body; uint8_t *body;
struct scheduler_msg mmh_msg; struct scheduler_msg mmh_msg;
tpSirMacMgmtHdr hdr; tpSirMacMgmtHdr hdr;
uint32_t frame_len;
tSirBssDescription *bssdescr;
result = qdf_mem_malloc(sizeof(*result) + ie_len); result = qdf_mem_malloc(sizeof(*result) + ie_len);
if (NULL == result) { if (NULL == result) {
@@ -542,6 +544,31 @@ __lim_ext_scan_forward_bcn_probe_rsp(tpAniSirGlobal pmac, uint8_t *rx_pkt_info,
qdf_mem_copy((uint8_t *) &result->ap.ieData, qdf_mem_copy((uint8_t *) &result->ap.ieData,
body + SIR_MAC_B_PR_SSID_OFFSET, ie_len); body + SIR_MAC_B_PR_SSID_OFFSET, ie_len);
frame_len = sizeof(*bssdescr) + ie_len - sizeof(bssdescr->ieFields[1]);
bssdescr = (tSirBssDescription *) qdf_mem_malloc(frame_len);
if (NULL == bssdescr) {
lim_log(pmac, LOGE,
FL("qdf_mem_malloc(length=%d) failed"), frame_len);
return;
}
qdf_mem_zero(bssdescr, frame_len);
lim_collect_bss_description(pmac, bssdescr, frame, rx_pkt_info, false);
/*
* Send the beacon to CSR with registered callback routine.
* scan_id and flags parameters are currently unused and set to 0.
* EXT scan results will also be added to scan cache in SME
*/
if (pmac->lim.add_bssdescr_callback) {
(pmac->lim.add_bssdescr_callback) (pmac, bssdescr, 0, 0);
} else {
lim_log(pmac, LOGE,
FL("No CSR callback routine to send beacon/probe response"));
}
qdf_mem_free(bssdescr);
mmh_msg.type = msg_type; mmh_msg.type = msg_type;
mmh_msg.bodyptr = result; mmh_msg.bodyptr = result;
mmh_msg.bodyval = 0; mmh_msg.bodyval = 0;

View File

@@ -4661,6 +4661,7 @@ QDF_STATUS csr_scan_process_single_bssdescr(tpAniSirGlobal mac_ctx,
uint8_t *chanlist = NULL; uint8_t *chanlist = NULL;
uint8_t cnt_channels = 0; uint8_t cnt_channels = 0;
uint32_t len = sizeof(mac_ctx->roam.validChannelList); uint32_t len = sizeof(mac_ctx->roam.validChannelList);
tCsrRoamInfo *roam_info;
sms_log(mac_ctx, LOG4, "CSR: Processing single bssdescr"); sms_log(mac_ctx, LOG4, "CSR: Processing single bssdescr");
if (QDF_IS_STATUS_SUCCESS( if (QDF_IS_STATUS_SUCCESS(
@@ -4678,6 +4679,19 @@ QDF_STATUS csr_scan_process_single_bssdescr(tpAniSirGlobal mac_ctx,
if (csr_scan_validate_scan_result(mac_ctx, chanlist, if (csr_scan_validate_scan_result(mac_ctx, chanlist,
cnt_channels, bssdescr, &ies)) { cnt_channels, bssdescr, &ies)) {
roam_info = qdf_mem_malloc(sizeof(*roam_info));
if (roam_info) {
qdf_mem_zero(roam_info, sizeof(*roam_info));
roam_info->pBssDesc = bssdescr;
csr_roam_call_callback(mac_ctx, 0, roam_info, 0,
eCSR_ROAM_UPDATE_SCAN_RESULT,
eCSR_ROAM_RESULT_NONE);
qdf_mem_free(roam_info);
} else {
sms_log(mac_ctx, LOG1, "qdf_mem_malloc failed");
}
csr_scan_remove_dup_bss_description_from_interim_list csr_scan_remove_dup_bss_description_from_interim_list
(mac_ctx, bssdescr, ies); (mac_ctx, bssdescr, ies);
csr_scan_save_bss_description_to_interim_list csr_scan_save_bss_description_to_interim_list