|
@@ -3257,6 +3257,28 @@ static int brcmf_start_internal_escan(struct brcmf_if *ifp,
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static struct brcmf_pno_net_info_le *
|
|
|
|
+brcmf_get_netinfo_array(struct brcmf_pno_scanresults_le *pfn_v1)
|
|
|
|
+{
|
|
|
|
+ struct brcmf_pno_scanresults_v2_le *pfn_v2;
|
|
|
|
+ struct brcmf_pno_net_info_le *netinfo;
|
|
|
|
+
|
|
|
|
+ switch (pfn_v1->version) {
|
|
|
|
+ default:
|
|
|
|
+ WARN_ON(1);
|
|
|
|
+ /* fall-thru */
|
|
|
|
+ case cpu_to_le32(1):
|
|
|
|
+ netinfo = (struct brcmf_pno_net_info_le *)(pfn_v1 + 1);
|
|
|
|
+ break;
|
|
|
|
+ case cpu_to_le32(2):
|
|
|
|
+ pfn_v2 = (struct brcmf_pno_scanresults_v2_le *)pfn_v1;
|
|
|
|
+ netinfo = (struct brcmf_pno_net_info_le *)(pfn_v2 + 1);
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return netinfo;
|
|
|
|
+}
|
|
|
|
+
|
|
/* PFN result doesn't have all the info which are required by the supplicant
|
|
/* PFN result doesn't have all the info which are required by the supplicant
|
|
* (For e.g IEs) Do a target Escan so that sched scan results are reported
|
|
* (For e.g IEs) Do a target Escan so that sched scan results are reported
|
|
* via wl_inform_single_bss in the required format. Escan does require the
|
|
* via wl_inform_single_bss in the required format. Escan does require the
|
|
@@ -3309,7 +3331,7 @@ brcmf_notify_sched_scan_results(struct brcmf_if *ifp,
|
|
}
|
|
}
|
|
|
|
|
|
data += sizeof(struct brcmf_pno_scanresults_le);
|
|
data += sizeof(struct brcmf_pno_scanresults_le);
|
|
- netinfo_start = (struct brcmf_pno_net_info_le *)data;
|
|
|
|
|
|
+ netinfo_start = brcmf_get_netinfo_array(pfn_result);
|
|
|
|
|
|
for (i = 0; i < result_count; i++) {
|
|
for (i = 0; i < result_count; i++) {
|
|
netinfo = &netinfo_start[i];
|
|
netinfo = &netinfo_start[i];
|