|
@@ -279,6 +279,25 @@ int wpas_rrm_send_neighbor_rep_request(struct wpa_supplicant *wpa_s,
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
+static int wpas_rrm_report_elem(struct wpabuf *buf, u8 token, u8 mode, u8 type,
|
|
|
|
+ const u8 *data, size_t data_len)
|
|
|
|
+{
|
|
|
|
+ if (wpabuf_tailroom(buf) < 5 + data_len)
|
|
|
|
+ return -1;
|
|
|
|
+
|
|
|
|
+ wpabuf_put_u8(buf, WLAN_EID_MEASURE_REPORT);
|
|
|
|
+ wpabuf_put_u8(buf, 3 + data_len);
|
|
|
|
+ wpabuf_put_u8(buf, token);
|
|
|
|
+ wpabuf_put_u8(buf, mode);
|
|
|
|
+ wpabuf_put_u8(buf, type);
|
|
|
|
+
|
|
|
|
+ if (data_len)
|
|
|
|
+ wpabuf_put_data(buf, data, data_len);
|
|
|
|
+
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+
|
|
static struct wpabuf * wpas_rrm_build_lci_report(struct wpa_supplicant *wpa_s,
|
|
static struct wpabuf * wpas_rrm_build_lci_report(struct wpa_supplicant *wpa_s,
|
|
const u8 *request, size_t len,
|
|
const u8 *request, size_t len,
|
|
struct wpabuf *report)
|
|
struct wpabuf *report)
|
|
@@ -397,11 +416,25 @@ wpas_rrm_handle_msr_req_element(
|
|
wpa_printf(MSG_DEBUG, "Measurement request type %d token %d",
|
|
wpa_printf(MSG_DEBUG, "Measurement request type %d token %d",
|
|
req->type, req->token);
|
|
req->type, req->token);
|
|
|
|
|
|
|
|
+ if (req->mode & MEASUREMENT_REQUEST_MODE_ENABLE) {
|
|
|
|
+ /* Enable bit is not supported for now */
|
|
|
|
+ wpa_printf(MSG_DEBUG, "RRM: Enable bit not supported, ignore");
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if ((req->mode & MEASUREMENT_REQUEST_MODE_PARALLEL) &&
|
|
|
|
+ req->type > MEASURE_TYPE_RPI_HIST) {
|
|
|
|
+ /* Parallel measurements are not supported for now */
|
|
|
|
+ wpa_printf(MSG_DEBUG,
|
|
|
|
+ "RRM: Parallel measurements are not supported, reject");
|
|
|
|
+ goto reject;
|
|
|
|
+ }
|
|
|
|
+
|
|
switch (req->type) {
|
|
switch (req->type) {
|
|
case MEASURE_TYPE_LCI:
|
|
case MEASURE_TYPE_LCI:
|
|
*buf = wpas_rrm_build_lci_report(wpa_s, &req->token, req->len,
|
|
*buf = wpas_rrm_build_lci_report(wpa_s, &req->token, req->len,
|
|
*buf);
|
|
*buf);
|
|
- break;
|
|
|
|
|
|
+ return 0;
|
|
default:
|
|
default:
|
|
wpa_printf(MSG_INFO,
|
|
wpa_printf(MSG_INFO,
|
|
"RRM: Unsupported radio measurement type %u",
|
|
"RRM: Unsupported radio measurement type %u",
|
|
@@ -409,6 +442,19 @@ wpas_rrm_handle_msr_req_element(
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+reject:
|
|
|
|
+ if (wpabuf_resize(buf, sizeof(struct rrm_measurement_report_element))) {
|
|
|
|
+ wpa_printf(MSG_DEBUG, "RRM: Memory allocation failed");
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (wpas_rrm_report_elem(*buf, req->token,
|
|
|
|
+ MEASUREMENT_REPORT_MODE_REJECT_INCAPABLE,
|
|
|
|
+ req->type, NULL, 0) < 0) {
|
|
|
|
+ wpa_printf(MSG_DEBUG, "RRM: Failed to add report element");
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|