blob: 996f119fd50ab437a0490a4902c9698740bd53f0 [file] [log] [blame]
Roshan Piuse65edb12016-11-22 13:02:01 -08001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <android-base/logging.h>
18#include <utils/SystemClock.h>
19
20#include "hidl_struct_util.h"
21
22namespace android {
23namespace hardware {
24namespace wifi {
25namespace V1_0 {
26namespace implementation {
27namespace hidl_struct_util {
28
Roshan Piusf72df2e2016-12-04 10:49:38 -080029IWifiChip::ChipCapabilityMask convertLegacyLoggerFeatureToHidlChipCapability(
30 uint32_t feature) {
31 using HidlChipCaps = IWifiChip::ChipCapabilityMask;
32 switch (feature) {
33 case legacy_hal::WIFI_LOGGER_MEMORY_DUMP_SUPPORTED:
34 return HidlChipCaps::DEBUG_MEMORY_FIRMWARE_DUMP_SUPPORTED;
35 case legacy_hal::WIFI_LOGGER_DRIVER_DUMP_SUPPORTED:
36 return HidlChipCaps::DEBUG_MEMORY_DRIVER_DUMP_SUPPORTED;
37 case legacy_hal::WIFI_LOGGER_CONNECT_EVENT_SUPPORTED:
38 return HidlChipCaps::DEBUG_RING_BUFFER_CONNECT_EVENT_SUPPORTED;
39 case legacy_hal::WIFI_LOGGER_POWER_EVENT_SUPPORTED:
40 return HidlChipCaps::DEBUG_RING_BUFFER_POWER_EVENT_SUPPORTED;
41 case legacy_hal::WIFI_LOGGER_WAKE_LOCK_SUPPORTED:
42 return HidlChipCaps::DEBUG_RING_BUFFER_WAKELOCK_EVENT_SUPPORTED;
43 };
44 CHECK(false) << "Unknown legacy feature: " << feature;
45 return {};
46}
47
48IWifiStaIface::StaIfaceCapabilityMask
49convertLegacyLoggerFeatureToHidlStaIfaceCapability(uint32_t feature) {
50 using HidlStaIfaceCaps = IWifiStaIface::StaIfaceCapabilityMask;
51 switch (feature) {
52 case legacy_hal::WIFI_LOGGER_PACKET_FATE_SUPPORTED:
53 return HidlStaIfaceCaps::DEBUG_PACKET_FATE_SUPPORTED;
54 };
55 CHECK(false) << "Unknown legacy feature: " << feature;
56 return {};
57}
58
59IWifiStaIface::StaIfaceCapabilityMask
60convertLegacyFeatureToHidlStaIfaceCapability(uint32_t feature) {
61 using HidlStaIfaceCaps = IWifiStaIface::StaIfaceCapabilityMask;
62 switch (feature) {
63 case WIFI_FEATURE_GSCAN:
64 return HidlStaIfaceCaps::BACKGROUND_SCAN;
65 case WIFI_FEATURE_LINK_LAYER_STATS:
66 return HidlStaIfaceCaps::LINK_LAYER_STATS;
Roshan Piusd4767542016-12-06 10:04:05 -080067 case WIFI_FEATURE_RSSI_MONITOR:
68 return HidlStaIfaceCaps::RSSI_MONITOR;
Roshan Pius26801cb2016-12-13 14:25:45 -080069 case WIFI_FEATURE_CONTROL_ROAMING:
70 return HidlStaIfaceCaps::CONTROL_ROAMING;
71 case WIFI_FEATURE_IE_WHITELIST:
72 return HidlStaIfaceCaps::PROBE_IE_WHITELIST;
73 case WIFI_FEATURE_SCAN_RAND:
74 return HidlStaIfaceCaps::SCAN_RAND;
Roshan Piusf72df2e2016-12-04 10:49:38 -080075 };
76 CHECK(false) << "Unknown legacy feature: " << feature;
77 return {};
78}
79
80bool convertLegacyFeaturesToHidlChipCapabilities(
81 uint32_t legacy_logger_feature_set, uint32_t* hidl_caps) {
82 if (!hidl_caps) {
83 return false;
84 }
85 *hidl_caps = 0;
86 using HidlChipCaps = IWifiChip::ChipCapabilityMask;
87 for (const auto feature : {legacy_hal::WIFI_LOGGER_MEMORY_DUMP_SUPPORTED,
88 legacy_hal::WIFI_LOGGER_DRIVER_DUMP_SUPPORTED,
89 legacy_hal::WIFI_LOGGER_CONNECT_EVENT_SUPPORTED,
90 legacy_hal::WIFI_LOGGER_POWER_EVENT_SUPPORTED,
91 legacy_hal::WIFI_LOGGER_WAKE_LOCK_SUPPORTED}) {
92 if (feature & legacy_logger_feature_set) {
93 *hidl_caps |= convertLegacyLoggerFeatureToHidlChipCapability(feature);
94 }
95 }
96 // There is no flags for these 2 in the legacy feature set. Adding it to the
97 // set because all the current devices support it.
98 *hidl_caps |= HidlChipCaps::DEBUG_RING_BUFFER_VENDOR_DATA_SUPPORTED;
99 *hidl_caps |= HidlChipCaps::DEBUG_HOST_WAKE_REASON_STATS;
100 return true;
101}
102
103WifiDebugRingBufferFlags convertLegacyDebugRingBufferFlagsToHidl(
104 uint32_t flag) {
105 switch (flag) {
106 case WIFI_RING_BUFFER_FLAG_HAS_BINARY_ENTRIES:
107 return WifiDebugRingBufferFlags::HAS_BINARY_ENTRIES;
108 case WIFI_RING_BUFFER_FLAG_HAS_ASCII_ENTRIES:
109 return WifiDebugRingBufferFlags::HAS_ASCII_ENTRIES;
110 };
111 CHECK(false) << "Unknown legacy flag: " << flag;
112 return {};
113}
114
115bool convertLegacyDebugRingBufferStatusToHidl(
116 const legacy_hal::wifi_ring_buffer_status& legacy_status,
117 WifiDebugRingBufferStatus* hidl_status) {
118 if (!hidl_status) {
119 return false;
120 }
121 hidl_status->ringName = reinterpret_cast<const char*>(legacy_status.name);
122 for (const auto flag : {WIFI_RING_BUFFER_FLAG_HAS_BINARY_ENTRIES,
123 WIFI_RING_BUFFER_FLAG_HAS_ASCII_ENTRIES}) {
124 if (flag & legacy_status.flags) {
125 hidl_status->flags |=
126 static_cast<std::underlying_type<WifiDebugRingBufferFlags>::type>(
127 convertLegacyDebugRingBufferFlagsToHidl(flag));
128 }
129 }
130 hidl_status->ringId = legacy_status.ring_id;
131 hidl_status->sizeInBytes = legacy_status.ring_buffer_byte_size;
132 // Calculate free size of the ring the buffer. We don't need to send the
133 // exact read/write pointers that were there in the legacy HAL interface.
134 if (legacy_status.written_bytes >= legacy_status.read_bytes) {
135 hidl_status->freeSizeInBytes =
136 legacy_status.ring_buffer_byte_size -
137 (legacy_status.written_bytes - legacy_status.read_bytes);
138 } else {
139 hidl_status->freeSizeInBytes =
140 legacy_status.read_bytes - legacy_status.written_bytes;
141 }
142 hidl_status->verboseLevel = legacy_status.verbose_level;
143 return true;
144}
145
146bool convertLegacyVectorOfDebugRingBufferStatusToHidl(
147 const std::vector<legacy_hal::wifi_ring_buffer_status>& legacy_status_vec,
148 std::vector<WifiDebugRingBufferStatus>* hidl_status_vec) {
149 if (!hidl_status_vec) {
150 return false;
151 }
152 hidl_status_vec->clear();
153 for (const auto& legacy_status : legacy_status_vec) {
154 WifiDebugRingBufferStatus hidl_status;
155 if (!convertLegacyDebugRingBufferStatusToHidl(legacy_status,
156 &hidl_status)) {
157 return false;
158 }
159 hidl_status_vec->push_back(hidl_status);
160 }
161 return true;
162}
163
164bool convertLegacyWakeReasonStatsToHidl(
165 const legacy_hal::WakeReasonStats& legacy_stats,
166 WifiDebugHostWakeReasonStats* hidl_stats) {
167 if (!hidl_stats) {
168 return false;
169 }
170 hidl_stats->totalCmdEventWakeCnt =
171 legacy_stats.wake_reason_cnt.total_cmd_event_wake;
172 hidl_stats->cmdEventWakeCntPerType = legacy_stats.cmd_event_wake_cnt;
173 hidl_stats->totalDriverFwLocalWakeCnt =
174 legacy_stats.wake_reason_cnt.total_driver_fw_local_wake;
175 hidl_stats->driverFwLocalWakeCntPerType =
176 legacy_stats.driver_fw_local_wake_cnt;
177 hidl_stats->totalRxPacketWakeCnt =
178 legacy_stats.wake_reason_cnt.total_rx_data_wake;
179 hidl_stats->rxPktWakeDetails.rxUnicastCnt =
180 legacy_stats.wake_reason_cnt.rx_wake_details.rx_unicast_cnt;
181 hidl_stats->rxPktWakeDetails.rxMulticastCnt =
182 legacy_stats.wake_reason_cnt.rx_wake_details.rx_multicast_cnt;
183 hidl_stats->rxPktWakeDetails.rxBroadcastCnt =
184 legacy_stats.wake_reason_cnt.rx_wake_details.rx_broadcast_cnt;
185 hidl_stats->rxMulticastPkWakeDetails.ipv4RxMulticastAddrCnt =
186 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info
187 .ipv4_rx_multicast_addr_cnt;
188 hidl_stats->rxMulticastPkWakeDetails.ipv6RxMulticastAddrCnt =
189 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info
190 .ipv6_rx_multicast_addr_cnt;
191 hidl_stats->rxMulticastPkWakeDetails.otherRxMulticastAddrCnt =
192 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info
193 .other_rx_multicast_addr_cnt;
194 hidl_stats->rxIcmpPkWakeDetails.icmpPkt =
195 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp_pkt;
196 hidl_stats->rxIcmpPkWakeDetails.icmp6Pkt =
197 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_pkt;
198 hidl_stats->rxIcmpPkWakeDetails.icmp6Ra =
199 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_ra;
200 hidl_stats->rxIcmpPkWakeDetails.icmp6Na =
201 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_na;
202 hidl_stats->rxIcmpPkWakeDetails.icmp6Ns =
203 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_ns;
204 return true;
205}
206
207bool convertLegacyFeaturesToHidlStaCapabilities(
208 uint32_t legacy_feature_set,
209 uint32_t legacy_logger_feature_set,
210 uint32_t* hidl_caps) {
211 if (!hidl_caps) {
212 return false;
213 }
214 *hidl_caps = 0;
215 using HidlStaIfaceCaps = IWifiStaIface::StaIfaceCapabilityMask;
216 for (const auto feature : {legacy_hal::WIFI_LOGGER_PACKET_FATE_SUPPORTED}) {
217 if (feature & legacy_logger_feature_set) {
218 *hidl_caps |= convertLegacyLoggerFeatureToHidlStaIfaceCapability(feature);
219 }
220 }
Roshan Piusd4767542016-12-06 10:04:05 -0800221 for (const auto feature : {WIFI_FEATURE_GSCAN,
222 WIFI_FEATURE_LINK_LAYER_STATS,
Roshan Pius26801cb2016-12-13 14:25:45 -0800223 WIFI_FEATURE_RSSI_MONITOR,
224 WIFI_FEATURE_CONTROL_ROAMING,
225 WIFI_FEATURE_IE_WHITELIST,
226 WIFI_FEATURE_SCAN_RAND}) {
Roshan Piusf72df2e2016-12-04 10:49:38 -0800227 if (feature & legacy_feature_set) {
228 *hidl_caps |= convertLegacyFeatureToHidlStaIfaceCapability(feature);
229 }
230 }
231 // There is no flag for this one in the legacy feature set. Adding it to the
232 // set because all the current devices support it.
233 *hidl_caps |= HidlStaIfaceCaps::APF;
234 return true;
235}
236
237bool convertLegacyApfCapabilitiesToHidl(
238 const legacy_hal::PacketFilterCapabilities& legacy_caps,
239 StaApfPacketFilterCapabilities* hidl_caps) {
240 if (!hidl_caps) {
241 return false;
242 }
243 hidl_caps->version = legacy_caps.version;
244 hidl_caps->maxLength = legacy_caps.max_len;
245 return true;
246}
247
Roshan Pius881d1f72016-12-05 15:37:00 -0800248uint8_t convertHidlGscanReportEventFlagToLegacy(
249 StaBackgroundScanBucketEventReportSchemeMask hidl_flag) {
250 using HidlFlag = StaBackgroundScanBucketEventReportSchemeMask;
251 switch (hidl_flag) {
252 case HidlFlag::EACH_SCAN:
253 return REPORT_EVENTS_EACH_SCAN;
254 case HidlFlag::FULL_RESULTS:
255 return REPORT_EVENTS_FULL_RESULTS;
256 case HidlFlag::NO_BATCH:
257 return REPORT_EVENTS_NO_BATCH;
258 };
259 CHECK(false);
260}
261
262StaScanDataFlagMask convertLegacyGscanDataFlagToHidl(uint8_t legacy_flag) {
263 switch (legacy_flag) {
264 case legacy_hal::WIFI_SCAN_FLAG_INTERRUPTED:
265 return StaScanDataFlagMask::INTERRUPTED;
266 };
267 CHECK(false) << "Unknown legacy flag: " << legacy_flag;
268 // To silence the compiler warning about reaching the end of non-void
269 // function.
270 return {};
271}
272
273bool convertLegacyGscanCapabilitiesToHidl(
Roshan Piusf72df2e2016-12-04 10:49:38 -0800274 const legacy_hal::wifi_gscan_capabilities& legacy_caps,
275 StaBackgroundScanCapabilities* hidl_caps) {
276 if (!hidl_caps) {
277 return false;
278 }
279 hidl_caps->maxCacheSize = legacy_caps.max_scan_cache_size;
280 hidl_caps->maxBuckets = legacy_caps.max_scan_buckets;
281 hidl_caps->maxApCachePerScan = legacy_caps.max_ap_cache_per_scan;
282 hidl_caps->maxReportingThreshold = legacy_caps.max_scan_reporting_threshold;
283 return true;
Roshan Pius32d0ca92016-12-02 11:21:19 -0800284}
285
Roshan Pius881d1f72016-12-05 15:37:00 -0800286legacy_hal::wifi_band convertHidlGscanBandToLegacy(StaBackgroundScanBand band) {
287 switch (band) {
288 case StaBackgroundScanBand::BAND_UNSPECIFIED:
289 return legacy_hal::WIFI_BAND_UNSPECIFIED;
290 case StaBackgroundScanBand::BAND_24GHZ:
291 return legacy_hal::WIFI_BAND_BG;
292 case StaBackgroundScanBand::BAND_5GHZ:
293 return legacy_hal::WIFI_BAND_A;
294 case StaBackgroundScanBand::BAND_5GHZ_DFS:
295 return legacy_hal::WIFI_BAND_A_DFS;
296 case StaBackgroundScanBand::BAND_5GHZ_WITH_DFS:
297 return legacy_hal::WIFI_BAND_A_WITH_DFS;
298 case StaBackgroundScanBand::BAND_24GHZ_5GHZ:
299 return legacy_hal::WIFI_BAND_ABG;
300 case StaBackgroundScanBand::BAND_24GHZ_5GHZ_WITH_DFS:
301 return legacy_hal::WIFI_BAND_ABG_WITH_DFS;
302 };
303 CHECK(false);
304}
305
306bool convertHidlGscanParamsToLegacy(
Roshan Piuse65edb12016-11-22 13:02:01 -0800307 const StaBackgroundScanParameters& hidl_scan_params,
308 legacy_hal::wifi_scan_cmd_params* legacy_scan_params) {
309 if (!legacy_scan_params) {
310 return false;
311 }
312 legacy_scan_params->base_period = hidl_scan_params.basePeriodInMs;
313 legacy_scan_params->max_ap_per_scan = hidl_scan_params.maxApPerScan;
314 legacy_scan_params->report_threshold_percent =
315 hidl_scan_params.reportThresholdPercent;
316 legacy_scan_params->report_threshold_num_scans =
317 hidl_scan_params.reportThresholdNumScans;
318 // TODO(b/33194311): Expose these max limits in the HIDL interface.
319 if (hidl_scan_params.buckets.size() > MAX_BUCKETS) {
320 return false;
321 }
322 legacy_scan_params->num_buckets = hidl_scan_params.buckets.size();
323 for (uint32_t bucket_idx = 0; bucket_idx < hidl_scan_params.buckets.size();
324 bucket_idx++) {
325 const StaBackgroundScanBucketParameters& hidl_bucket_spec =
326 hidl_scan_params.buckets[bucket_idx];
327 legacy_hal::wifi_scan_bucket_spec& legacy_bucket_spec =
328 legacy_scan_params->buckets[bucket_idx];
329 legacy_bucket_spec.bucket = bucket_idx;
330 legacy_bucket_spec.band =
331 static_cast<legacy_hal::wifi_band>(hidl_bucket_spec.band);
332 legacy_bucket_spec.period = hidl_bucket_spec.periodInMs;
333 legacy_bucket_spec.max_period = hidl_bucket_spec.exponentialMaxPeriodInMs;
334 legacy_bucket_spec.base = hidl_bucket_spec.exponentialBase;
335 legacy_bucket_spec.step_count = hidl_bucket_spec.exponentialStepCount;
336 legacy_bucket_spec.report_events = 0;
337 using HidlFlag = StaBackgroundScanBucketEventReportSchemeMask;
338 for (const auto flag :
339 {HidlFlag::EACH_SCAN, HidlFlag::FULL_RESULTS, HidlFlag::NO_BATCH}) {
340 if (hidl_bucket_spec.eventReportScheme &
341 static_cast<std::underlying_type<HidlFlag>::type>(flag)) {
342 legacy_bucket_spec.report_events |=
Roshan Pius881d1f72016-12-05 15:37:00 -0800343 convertHidlGscanReportEventFlagToLegacy(flag);
Roshan Piuse65edb12016-11-22 13:02:01 -0800344 }
345 }
346 // TODO(b/33194311): Expose these max limits in the HIDL interface.
347 if (hidl_bucket_spec.frequencies.size() > MAX_CHANNELS) {
348 return false;
349 }
350 legacy_bucket_spec.num_channels = hidl_bucket_spec.frequencies.size();
351 for (uint32_t freq_idx = 0; freq_idx < hidl_bucket_spec.frequencies.size();
352 freq_idx++) {
353 legacy_bucket_spec.channels[freq_idx].channel =
354 hidl_bucket_spec.frequencies[freq_idx];
355 }
356 }
357 return true;
358}
359
Roshan Pius3fae9c82016-12-02 14:49:41 -0800360bool convertLegacyIeToHidl(
361 const legacy_hal::wifi_information_element& legacy_ie,
362 WifiInformationElement* hidl_ie) {
363 if (!hidl_ie) {
364 return false;
365 }
366 hidl_ie->id = legacy_ie.id;
367 hidl_ie->data =
368 std::vector<uint8_t>(legacy_ie.data, legacy_ie.data + legacy_ie.len);
369 return true;
370}
371
Roshan Piuse65edb12016-11-22 13:02:01 -0800372bool convertLegacyIeBlobToHidl(const uint8_t* ie_blob,
373 uint32_t ie_blob_len,
374 std::vector<WifiInformationElement>* hidl_ies) {
375 if (!ie_blob || !hidl_ies) {
376 return false;
377 }
378 const uint8_t* ies_begin = ie_blob;
379 const uint8_t* ies_end = ie_blob + ie_blob_len;
380 const uint8_t* next_ie = ies_begin;
381 using wifi_ie = legacy_hal::wifi_information_element;
382 constexpr size_t kIeHeaderLen = sizeof(wifi_ie);
383 // Each IE should atleast have the header (i.e |id| & |len| fields).
384 while (next_ie + kIeHeaderLen <= ies_end) {
385 const wifi_ie& legacy_ie = (*reinterpret_cast<const wifi_ie*>(next_ie));
386 uint32_t curr_ie_len = kIeHeaderLen + legacy_ie.len;
387 if (next_ie + curr_ie_len > ies_end) {
388 return false;
389 }
390 WifiInformationElement hidl_ie;
Roshan Pius3fae9c82016-12-02 14:49:41 -0800391 if (!convertLegacyIeToHidl(legacy_ie, &hidl_ie)) {
392 return false;
393 }
Roshan Piuse65edb12016-11-22 13:02:01 -0800394 hidl_ies->push_back(std::move(hidl_ie));
395 next_ie += curr_ie_len;
396 }
397 // Ensure that the blob has been fully consumed.
398 return (next_ie == ies_end);
399}
400
Roshan Pius881d1f72016-12-05 15:37:00 -0800401bool convertLegacyGscanResultToHidl(
Roshan Piuse65edb12016-11-22 13:02:01 -0800402 const legacy_hal::wifi_scan_result& legacy_scan_result,
403 bool has_ie_data,
404 StaScanResult* hidl_scan_result) {
405 if (!hidl_scan_result) {
406 return false;
407 }
408 hidl_scan_result->timeStampInUs = legacy_scan_result.ts;
409 hidl_scan_result->ssid = std::vector<uint8_t>(
410 legacy_scan_result.ssid,
411 legacy_scan_result.ssid + sizeof(legacy_scan_result.ssid));
412 memcpy(hidl_scan_result->bssid.data(),
413 legacy_scan_result.bssid,
414 hidl_scan_result->bssid.size());
415 hidl_scan_result->frequency = legacy_scan_result.channel;
416 hidl_scan_result->rssi = legacy_scan_result.rssi;
417 hidl_scan_result->beaconPeriodInMs = legacy_scan_result.beacon_period;
418 hidl_scan_result->capability = legacy_scan_result.capability;
419 if (has_ie_data) {
420 std::vector<WifiInformationElement> ies;
421 if (!convertLegacyIeBlobToHidl(
422 reinterpret_cast<const uint8_t*>(legacy_scan_result.ie_data),
423 legacy_scan_result.ie_length,
424 &ies)) {
425 return false;
426 }
427 hidl_scan_result->informationElements = std::move(ies);
428 }
429 return true;
430}
431
Roshan Pius881d1f72016-12-05 15:37:00 -0800432bool convertLegacyCachedGscanResultsToHidl(
Roshan Piuse65edb12016-11-22 13:02:01 -0800433 const legacy_hal::wifi_cached_scan_results& legacy_cached_scan_result,
434 StaScanData* hidl_scan_data) {
435 if (!hidl_scan_data) {
436 return false;
437 }
Roshan Pius32d0ca92016-12-02 11:21:19 -0800438 for (const auto flag : {legacy_hal::WIFI_SCAN_FLAG_INTERRUPTED}) {
439 if (legacy_cached_scan_result.flags & flag) {
440 hidl_scan_data->flags |=
441 static_cast<std::underlying_type<StaScanDataFlagMask>::type>(
Roshan Pius881d1f72016-12-05 15:37:00 -0800442 convertLegacyGscanDataFlagToHidl(flag));
Roshan Pius32d0ca92016-12-02 11:21:19 -0800443 }
444 }
Roshan Piuse65edb12016-11-22 13:02:01 -0800445 hidl_scan_data->bucketsScanned = legacy_cached_scan_result.buckets_scanned;
446
447 CHECK(legacy_cached_scan_result.num_results >= 0 &&
448 legacy_cached_scan_result.num_results <= MAX_AP_CACHE_PER_SCAN);
449 std::vector<StaScanResult> hidl_scan_results;
450 for (int32_t result_idx = 0;
451 result_idx < legacy_cached_scan_result.num_results;
452 result_idx++) {
453 StaScanResult hidl_scan_result;
Roshan Pius881d1f72016-12-05 15:37:00 -0800454 if (!convertLegacyGscanResultToHidl(
Roshan Piuse65edb12016-11-22 13:02:01 -0800455 legacy_cached_scan_result.results[result_idx],
456 false,
457 &hidl_scan_result)) {
458 return false;
459 }
460 hidl_scan_results.push_back(hidl_scan_result);
461 }
462 hidl_scan_data->results = std::move(hidl_scan_results);
463 return true;
464}
465
Roshan Pius881d1f72016-12-05 15:37:00 -0800466bool convertLegacyVectorOfCachedGscanResultsToHidl(
Roshan Piuse65edb12016-11-22 13:02:01 -0800467 const std::vector<legacy_hal::wifi_cached_scan_results>&
468 legacy_cached_scan_results,
469 std::vector<StaScanData>* hidl_scan_datas) {
470 if (!hidl_scan_datas) {
471 return false;
472 }
Roshan Pius881d1f72016-12-05 15:37:00 -0800473 hidl_scan_datas->clear();
Roshan Piuse65edb12016-11-22 13:02:01 -0800474 for (const auto& legacy_cached_scan_result : legacy_cached_scan_results) {
475 StaScanData hidl_scan_data;
Roshan Pius881d1f72016-12-05 15:37:00 -0800476 if (!convertLegacyCachedGscanResultsToHidl(legacy_cached_scan_result,
477 &hidl_scan_data)) {
Roshan Piuse65edb12016-11-22 13:02:01 -0800478 return false;
479 }
480 hidl_scan_datas->push_back(hidl_scan_data);
481 }
482 return true;
483}
484
Roshan Pius32d0ca92016-12-02 11:21:19 -0800485WifiDebugTxPacketFate convertLegacyDebugTxPacketFateToHidl(
486 legacy_hal::wifi_tx_packet_fate fate) {
487 switch (fate) {
488 case legacy_hal::TX_PKT_FATE_ACKED:
489 return WifiDebugTxPacketFate::ACKED;
490 case legacy_hal::TX_PKT_FATE_SENT:
491 return WifiDebugTxPacketFate::SENT;
492 case legacy_hal::TX_PKT_FATE_FW_QUEUED:
493 return WifiDebugTxPacketFate::FW_QUEUED;
494 case legacy_hal::TX_PKT_FATE_FW_DROP_INVALID:
495 return WifiDebugTxPacketFate::FW_DROP_INVALID;
496 case legacy_hal::TX_PKT_FATE_FW_DROP_NOBUFS:
497 return WifiDebugTxPacketFate::FW_DROP_NOBUFS;
498 case legacy_hal::TX_PKT_FATE_FW_DROP_OTHER:
499 return WifiDebugTxPacketFate::FW_DROP_OTHER;
500 case legacy_hal::TX_PKT_FATE_DRV_QUEUED:
501 return WifiDebugTxPacketFate::DRV_QUEUED;
502 case legacy_hal::TX_PKT_FATE_DRV_DROP_INVALID:
503 return WifiDebugTxPacketFate::DRV_DROP_INVALID;
504 case legacy_hal::TX_PKT_FATE_DRV_DROP_NOBUFS:
505 return WifiDebugTxPacketFate::DRV_DROP_NOBUFS;
506 case legacy_hal::TX_PKT_FATE_DRV_DROP_OTHER:
507 return WifiDebugTxPacketFate::DRV_DROP_OTHER;
508 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800509 CHECK(false) << "Unknown legacy fate type: " << fate;
Roshan Pius32d0ca92016-12-02 11:21:19 -0800510}
511
512WifiDebugRxPacketFate convertLegacyDebugRxPacketFateToHidl(
513 legacy_hal::wifi_rx_packet_fate fate) {
514 switch (fate) {
515 case legacy_hal::RX_PKT_FATE_SUCCESS:
516 return WifiDebugRxPacketFate::SUCCESS;
517 case legacy_hal::RX_PKT_FATE_FW_QUEUED:
518 return WifiDebugRxPacketFate::FW_QUEUED;
519 case legacy_hal::RX_PKT_FATE_FW_DROP_FILTER:
520 return WifiDebugRxPacketFate::FW_DROP_FILTER;
521 case legacy_hal::RX_PKT_FATE_FW_DROP_INVALID:
522 return WifiDebugRxPacketFate::FW_DROP_INVALID;
523 case legacy_hal::RX_PKT_FATE_FW_DROP_NOBUFS:
524 return WifiDebugRxPacketFate::FW_DROP_NOBUFS;
525 case legacy_hal::RX_PKT_FATE_FW_DROP_OTHER:
526 return WifiDebugRxPacketFate::FW_DROP_OTHER;
527 case legacy_hal::RX_PKT_FATE_DRV_QUEUED:
528 return WifiDebugRxPacketFate::DRV_QUEUED;
529 case legacy_hal::RX_PKT_FATE_DRV_DROP_FILTER:
530 return WifiDebugRxPacketFate::DRV_DROP_FILTER;
531 case legacy_hal::RX_PKT_FATE_DRV_DROP_INVALID:
532 return WifiDebugRxPacketFate::DRV_DROP_INVALID;
533 case legacy_hal::RX_PKT_FATE_DRV_DROP_NOBUFS:
534 return WifiDebugRxPacketFate::DRV_DROP_NOBUFS;
535 case legacy_hal::RX_PKT_FATE_DRV_DROP_OTHER:
536 return WifiDebugRxPacketFate::DRV_DROP_OTHER;
537 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800538 CHECK(false) << "Unknown legacy fate type: " << fate;
Roshan Pius32d0ca92016-12-02 11:21:19 -0800539}
540
541WifiDebugPacketFateFrameType convertLegacyDebugPacketFateFrameTypeToHidl(
542 legacy_hal::frame_type type) {
543 switch (type) {
544 case legacy_hal::FRAME_TYPE_UNKNOWN:
545 return WifiDebugPacketFateFrameType::UNKNOWN;
546 case legacy_hal::FRAME_TYPE_ETHERNET_II:
547 return WifiDebugPacketFateFrameType::ETHERNET_II;
548 case legacy_hal::FRAME_TYPE_80211_MGMT:
549 return WifiDebugPacketFateFrameType::MGMT_80211;
550 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800551 CHECK(false) << "Unknown legacy frame type: " << type;
Roshan Pius32d0ca92016-12-02 11:21:19 -0800552}
553
554bool convertLegacyDebugPacketFateFrameToHidl(
555 const legacy_hal::frame_info& legacy_frame,
556 WifiDebugPacketFateFrameInfo* hidl_frame) {
557 if (!hidl_frame) {
558 return false;
559 }
560 hidl_frame->frameType =
561 convertLegacyDebugPacketFateFrameTypeToHidl(legacy_frame.payload_type);
562 hidl_frame->frameLen = legacy_frame.frame_len;
563 hidl_frame->driverTimestampUsec = legacy_frame.driver_timestamp_usec;
564 hidl_frame->firmwareTimestampUsec = legacy_frame.firmware_timestamp_usec;
565 const uint8_t* frame_begin = reinterpret_cast<const uint8_t*>(
566 legacy_frame.frame_content.ethernet_ii_bytes);
567 hidl_frame->frameContent =
568 std::vector<uint8_t>(frame_begin, frame_begin + legacy_frame.frame_len);
569 return true;
570}
571
572bool convertLegacyDebugTxPacketFateToHidl(
573 const legacy_hal::wifi_tx_report& legacy_fate,
574 WifiDebugTxPacketFateReport* hidl_fate) {
575 if (!hidl_fate) {
576 return false;
577 }
578 hidl_fate->fate = convertLegacyDebugTxPacketFateToHidl(legacy_fate.fate);
579 return convertLegacyDebugPacketFateFrameToHidl(legacy_fate.frame_inf,
580 &hidl_fate->frameInfo);
581}
582
Roshan Piusf72df2e2016-12-04 10:49:38 -0800583bool convertLegacyVectorOfDebugTxPacketFateToHidl(
584 const std::vector<legacy_hal::wifi_tx_report>& legacy_fates,
585 std::vector<WifiDebugTxPacketFateReport>* hidl_fates) {
586 if (!hidl_fates) {
587 return false;
588 }
589 hidl_fates->clear();
590 for (const auto& legacy_fate : legacy_fates) {
591 WifiDebugTxPacketFateReport hidl_fate;
592 if (!convertLegacyDebugTxPacketFateToHidl(legacy_fate, &hidl_fate)) {
593 return false;
594 }
595 hidl_fates->push_back(hidl_fate);
596 }
597 return true;
598}
599
Roshan Pius32d0ca92016-12-02 11:21:19 -0800600bool convertLegacyDebugRxPacketFateToHidl(
601 const legacy_hal::wifi_rx_report& legacy_fate,
602 WifiDebugRxPacketFateReport* hidl_fate) {
603 if (!hidl_fate) {
604 return false;
605 }
606 hidl_fate->fate = convertLegacyDebugRxPacketFateToHidl(legacy_fate.fate);
607 return convertLegacyDebugPacketFateFrameToHidl(legacy_fate.frame_inf,
608 &hidl_fate->frameInfo);
609}
610
Roshan Piusf72df2e2016-12-04 10:49:38 -0800611bool convertLegacyVectorOfDebugRxPacketFateToHidl(
612 const std::vector<legacy_hal::wifi_rx_report>& legacy_fates,
613 std::vector<WifiDebugRxPacketFateReport>* hidl_fates) {
614 if (!hidl_fates) {
615 return false;
616 }
617 hidl_fates->clear();
618 for (const auto& legacy_fate : legacy_fates) {
619 WifiDebugRxPacketFateReport hidl_fate;
620 if (!convertLegacyDebugRxPacketFateToHidl(legacy_fate, &hidl_fate)) {
621 return false;
622 }
623 hidl_fates->push_back(hidl_fate);
624 }
625 return true;
626}
627
Roshan Piuse65edb12016-11-22 13:02:01 -0800628bool convertLegacyLinkLayerStatsToHidl(
629 const legacy_hal::LinkLayerStats& legacy_stats,
630 StaLinkLayerStats* hidl_stats) {
631 if (!hidl_stats) {
632 return false;
633 }
634 // iface legacy_stats conversion.
635 hidl_stats->iface.beaconRx = legacy_stats.iface.beacon_rx;
636 hidl_stats->iface.avgRssiMgmt = legacy_stats.iface.rssi_mgmt;
637 hidl_stats->iface.wmeBePktStats.rxMpdu =
638 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].rx_mpdu;
639 hidl_stats->iface.wmeBePktStats.txMpdu =
640 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].tx_mpdu;
641 hidl_stats->iface.wmeBePktStats.lostMpdu =
642 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].mpdu_lost;
643 hidl_stats->iface.wmeBePktStats.retries =
644 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].retries;
645 hidl_stats->iface.wmeBkPktStats.rxMpdu =
646 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].rx_mpdu;
647 hidl_stats->iface.wmeBkPktStats.txMpdu =
648 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].tx_mpdu;
649 hidl_stats->iface.wmeBkPktStats.lostMpdu =
650 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].mpdu_lost;
651 hidl_stats->iface.wmeBkPktStats.retries =
652 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].retries;
653 hidl_stats->iface.wmeViPktStats.rxMpdu =
654 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].rx_mpdu;
655 hidl_stats->iface.wmeViPktStats.txMpdu =
656 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].tx_mpdu;
657 hidl_stats->iface.wmeViPktStats.lostMpdu =
658 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].mpdu_lost;
659 hidl_stats->iface.wmeViPktStats.retries =
660 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].retries;
661 hidl_stats->iface.wmeVoPktStats.rxMpdu =
662 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].rx_mpdu;
663 hidl_stats->iface.wmeVoPktStats.txMpdu =
664 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].tx_mpdu;
665 hidl_stats->iface.wmeVoPktStats.lostMpdu =
666 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].mpdu_lost;
667 hidl_stats->iface.wmeVoPktStats.retries =
668 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].retries;
669 // radio legacy_stats conversion.
670 hidl_stats->radio.onTimeInMs = legacy_stats.radio.on_time;
671 hidl_stats->radio.txTimeInMs = legacy_stats.radio.tx_time;
672 hidl_stats->radio.rxTimeInMs = legacy_stats.radio.rx_time;
673 hidl_stats->radio.onTimeInMsForScan = legacy_stats.radio.on_time_scan;
674 hidl_stats->radio.txTimeInMsPerLevel = legacy_stats.radio_tx_time_per_levels;
675 // Timestamp in the HAL wrapper here since it's not provided in the legacy
676 // HAL API.
677 hidl_stats->timeStampInMs = uptimeMillis();
678 return true;
679}
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800680
Roshan Pius26801cb2016-12-13 14:25:45 -0800681bool convertLegacyRoamingCapabilitiesToHidl(
682 const legacy_hal::wifi_roaming_capabilities& legacy_caps,
683 StaRoamingCapabilities* hidl_caps) {
684 if (!hidl_caps) {
685 return false;
686 }
687 hidl_caps->maxBlacklistSize = legacy_caps.max_blacklist_size;
688 hidl_caps->maxWhitelistSize = legacy_caps.max_whitelist_size;
689 return true;
690}
691
692bool convertHidlRoamingConfigToLegacy(
693 const StaRoamingConfig& hidl_config,
694 legacy_hal::wifi_roaming_config* legacy_config) {
695 if (!legacy_config) {
696 return false;
697 }
698 if (hidl_config.bssidBlacklist.size() > MAX_BLACKLIST_BSSID ||
699 hidl_config.ssidWhitelist.size() > MAX_WHITELIST_SSID) {
700 return false;
701 }
702 legacy_config->num_blacklist_bssid = hidl_config.bssidBlacklist.size();
703 uint32_t i = 0;
704 for (const auto& bssid : hidl_config.bssidBlacklist) {
705 CHECK(bssid.size() == sizeof(legacy_hal::mac_addr));
706 memcpy(legacy_config->blacklist_bssid[i++], bssid.data(), bssid.size());
707 }
708 legacy_config->num_whitelist_ssid = hidl_config.ssidWhitelist.size();
709 i = 0;
710 for (const auto& ssid : hidl_config.ssidWhitelist) {
711 CHECK(ssid.size() <= sizeof(legacy_hal::ssid_t::ssid_str));
712 legacy_config->whitelist_ssid[i].length = ssid.size();
713 memcpy(legacy_config->whitelist_ssid[i].ssid_str, ssid.data(), ssid.size());
714 i++;
715 }
716 return true;
717}
718
719legacy_hal::fw_roaming_state_t convertHidlRoamingStateToLegacy(
720 StaRoamingState state) {
721 switch (state) {
722 case StaRoamingState::ENABLED:
723 return legacy_hal::ROAMING_ENABLE;
724 case StaRoamingState::DISABLED:
725 return legacy_hal::ROAMING_DISABLE;
726 };
727 CHECK(false);
728}
729
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800730legacy_hal::NanPublishType convertHidlNanPublishTypeToLegacy(
731 NanPublishType type) {
732 switch (type) {
733 case NanPublishType::UNSOLICITED:
734 return legacy_hal::NAN_PUBLISH_TYPE_UNSOLICITED;
735 case NanPublishType::SOLICITED:
736 return legacy_hal::NAN_PUBLISH_TYPE_SOLICITED;
737 case NanPublishType::UNSOLICITED_SOLICITED:
738 return legacy_hal::NAN_PUBLISH_TYPE_UNSOLICITED_SOLICITED;
739 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800740 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800741}
742
743legacy_hal::NanTxType convertHidlNanTxTypeToLegacy(NanTxType type) {
744 switch (type) {
745 case NanTxType::BROADCAST:
746 return legacy_hal::NAN_TX_TYPE_BROADCAST;
747 case NanTxType::UNICAST:
748 return legacy_hal::NAN_TX_TYPE_UNICAST;
749 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800750 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800751}
752
753legacy_hal::NanMatchAlg convertHidlNanMatchAlgToLegacy(NanMatchAlg type) {
754 switch (type) {
755 case NanMatchAlg::MATCH_ONCE:
756 return legacy_hal::NAN_MATCH_ALG_MATCH_ONCE;
757 case NanMatchAlg::MATCH_CONTINUOUS:
758 return legacy_hal::NAN_MATCH_ALG_MATCH_CONTINUOUS;
759 case NanMatchAlg::MATCH_NEVER:
760 return legacy_hal::NAN_MATCH_ALG_MATCH_NEVER;
761 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800762 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800763}
764
765legacy_hal::NanSubscribeType convertHidlNanSubscribeTypeToLegacy(
766 NanSubscribeType type) {
767 switch (type) {
768 case NanSubscribeType::ACTIVE:
769 return legacy_hal::NAN_SUBSCRIBE_TYPE_ACTIVE;
770 case NanSubscribeType::PASSIVE:
771 return legacy_hal::NAN_SUBSCRIBE_TYPE_PASSIVE;
772 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800773 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800774}
775
776legacy_hal::NanSRFType convertHidlNanSrfTypeToLegacy(NanSrfType type) {
777 switch (type) {
778 case NanSrfType::BLOOM_FILTER:
779 return legacy_hal::NAN_SRF_ATTR_BLOOM_FILTER;
780 case NanSrfType::PARTIAL_MAC_ADDR:
781 return legacy_hal::NAN_SRF_ATTR_PARTIAL_MAC_ADDR;
782 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800783 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800784}
785
786legacy_hal::NanSRFIncludeType convertHidlNanSrfIncludeTypeToLegacy(
787 NanSrfIncludeType type) {
788 switch (type) {
789 case NanSrfIncludeType::DO_NOT_RESPOND:
790 return legacy_hal::NAN_SRF_INCLUDE_DO_NOT_RESPOND;
791 case NanSrfIncludeType::RESPOND:
792 return legacy_hal::NAN_SRF_INCLUDE_RESPOND;
793 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800794 CHECK(false);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800795}
796
797NanStatusType convertLegacyNanStatusTypeToHidl(
798 legacy_hal::NanStatusType /* type */) {
799 // TODO: The |NanStatusType| has changed in legacy HAL and no longer in sync
800 // with the HIDL interface.
801 return NanStatusType::SUCCESS;
802}
803
804NanResponseType convertLegacyNanResponseTypeToHidl(
805 legacy_hal::NanResponseType type) {
806 switch (type) {
807 case legacy_hal::NAN_RESPONSE_ENABLED:
808 return NanResponseType::ENABLED;
809 case legacy_hal::NAN_RESPONSE_DISABLED:
810 return NanResponseType::DISABLED;
811 case legacy_hal::NAN_RESPONSE_PUBLISH:
812 return NanResponseType::PUBLISH;
813 case legacy_hal::NAN_RESPONSE_PUBLISH_CANCEL:
814 return NanResponseType::PUBLISH_CANCEL;
815 case legacy_hal::NAN_RESPONSE_TRANSMIT_FOLLOWUP:
816 return NanResponseType::TRANSMIT_FOLLOWUP;
817 case legacy_hal::NAN_RESPONSE_SUBSCRIBE:
818 return NanResponseType::SUBSCRIBE;
819 case legacy_hal::NAN_RESPONSE_SUBSCRIBE_CANCEL:
820 return NanResponseType::SUBSCRIBE_CANCEL;
821 case legacy_hal::NAN_RESPONSE_STATS:
822 // Not present in HIDL. Is going to be deprecated in legacy HAL as well.
823 CHECK(0);
824 case legacy_hal::NAN_RESPONSE_CONFIG:
825 return NanResponseType::CONFIG;
826 case legacy_hal::NAN_RESPONSE_TCA:
827 // Not present in HIDL. Is going to be deprecated in legacy HAL as well.
828 CHECK(0);
829 case legacy_hal::NAN_RESPONSE_ERROR:
830 return NanResponseType::ERROR;
831 case legacy_hal::NAN_RESPONSE_BEACON_SDF_PAYLOAD:
832 return NanResponseType::BEACON_SDF_PAYLOAD;
833 case legacy_hal::NAN_GET_CAPABILITIES:
834 return NanResponseType::GET_CAPABILITIES;
835 case legacy_hal::NAN_DP_INTERFACE_CREATE:
836 return NanResponseType::DP_INTERFACE_CREATE;
837 case legacy_hal::NAN_DP_INTERFACE_DELETE:
838 return NanResponseType::DP_INTERFACE_DELETE;
839 case legacy_hal::NAN_DP_INITIATOR_RESPONSE:
840 return NanResponseType::DP_INITIATOR_RESPONSE;
841 case legacy_hal::NAN_DP_RESPONDER_RESPONSE:
842 return NanResponseType::DP_RESPONDER_RESPONSE;
843 case legacy_hal::NAN_DP_END:
844 return NanResponseType::DP_END;
845 };
Roshan Pius3fae9c82016-12-02 14:49:41 -0800846 CHECK(false) << "Unknown legacy type: " << type;
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800847}
848
849bool convertHidlNanEnableRequestToLegacy(
850 const NanEnableRequest& hidl_request,
851 legacy_hal::NanEnableRequest* legacy_request) {
852 if (!legacy_request) {
853 return false;
854 }
855 legacy_request->master_pref = hidl_request.masterPref;
856 legacy_request->cluster_low = hidl_request.clusterLow;
857 legacy_request->cluster_high = hidl_request.clusterHigh;
858 legacy_request->config_support_5g = hidl_request.validSupport5gVal;
859 legacy_request->support_5g_val = hidl_request.support5gVal;
860 legacy_request->config_sid_beacon = hidl_request.validSidBeaconVal;
861 legacy_request->sid_beacon_val = hidl_request.sidBeaconVal;
862 legacy_request->config_2dot4g_rssi_close =
863 hidl_request.valid2dot4gRssiCloseVal;
864 legacy_request->rssi_close_2dot4g_val = hidl_request.rssiClose2dot4gVal;
865 legacy_request->config_2dot4g_rssi_middle =
866 hidl_request.valid2dot4gRssiMiddleVal;
867 legacy_request->rssi_middle_2dot4g_val = hidl_request.rssiMiddle2dot4gVal;
868 legacy_request->config_2dot4g_rssi_proximity =
869 hidl_request.valid2dot4gRssiProximityVal;
870 legacy_request->rssi_proximity_2dot4g_val =
871 hidl_request.rssiProximity2dot4gVal;
872 legacy_request->config_hop_count_limit = hidl_request.validHopCountLimitVal;
873 legacy_request->hop_count_limit_val = hidl_request.hopCountLimitVal;
874 legacy_request->config_2dot4g_support = hidl_request.valid2dot4gSupportVal;
875 legacy_request->support_2dot4g_val = hidl_request.support2dot4gVal;
876 legacy_request->config_2dot4g_beacons = hidl_request.valid2dot4gBeaconsVal;
877 legacy_request->beacon_2dot4g_val = hidl_request.beacon2dot4gVal;
878 legacy_request->config_2dot4g_sdf = hidl_request.valid2dot4gSdfVal;
879 legacy_request->sdf_2dot4g_val = hidl_request.sdf2dot4gVal;
880 legacy_request->config_5g_beacons = hidl_request.valid5gBeaconsVal;
881 legacy_request->beacon_5g_val = hidl_request.beacon5gVal;
882 legacy_request->config_5g_sdf = hidl_request.valid5gSdfVal;
883 legacy_request->sdf_5g_val = hidl_request.sdf5gVal;
884 legacy_request->config_5g_rssi_close = hidl_request.valid5gRssiCloseVal;
885 legacy_request->rssi_close_5g_val = hidl_request.rssiClose5gVal;
886 legacy_request->config_5g_rssi_middle = hidl_request.valid5gRssiMiddleVal;
887 legacy_request->rssi_middle_5g_val = hidl_request.rssiMiddle5gVal;
888 legacy_request->config_5g_rssi_close_proximity =
889 hidl_request.valid5gRssiCloseProximityVal;
890 legacy_request->rssi_close_proximity_5g_val =
891 hidl_request.rssiCloseProximity5gVal;
892 legacy_request->config_rssi_window_size = hidl_request.validRssiWindowSizeVal;
893 legacy_request->rssi_window_size_val = hidl_request.rssiWindowSizeVal;
894 legacy_request->config_oui = hidl_request.validOuiVal;
895 legacy_request->oui_val = hidl_request.ouiVal;
896 legacy_request->config_intf_addr = hidl_request.validIntfAddrVal;
897 CHECK(hidl_request.intfAddrVal.size() ==
898 sizeof(legacy_request->intf_addr_val));
899 memcpy(legacy_request->intf_addr_val,
900 hidl_request.intfAddrVal.data(),
901 hidl_request.intfAddrVal.size());
902 legacy_request->config_cluster_attribute_val =
903 hidl_request.configClusterAttributeVal;
904 legacy_request->config_scan_params = hidl_request.validScanParamsVal;
905 if (hidl_request.scanParamsVal.dwellTime.size() >
906 sizeof(legacy_request->scan_params_val.dwell_time)) {
907 return false;
908 }
909 memcpy(legacy_request->scan_params_val.dwell_time,
910 hidl_request.scanParamsVal.dwellTime.data(),
911 hidl_request.scanParamsVal.dwellTime.size());
912 if (hidl_request.scanParamsVal.scanPeriod.size() >
913 sizeof(legacy_request->scan_params_val.scan_period)) {
914 return false;
915 }
916 memcpy(legacy_request->scan_params_val.scan_period,
917 hidl_request.scanParamsVal.scanPeriod.data(),
918 hidl_request.scanParamsVal.scanPeriod.size());
919 legacy_request->config_random_factor_force =
920 hidl_request.validRandomFactorForceVal;
921 legacy_request->random_factor_force_val = hidl_request.randomFactorForceVal;
922 legacy_request->config_hop_count_force = hidl_request.validHopCountLimitVal;
923 legacy_request->hop_count_force_val = hidl_request.hopCountLimitVal;
924 legacy_request->config_24g_channel = hidl_request.valid24gChannelVal;
925 legacy_request->channel_24g_val = hidl_request.channel24gVal;
926 legacy_request->config_5g_channel = hidl_request.valid5gChannelVal;
927 legacy_request->channel_5g_val = hidl_request.channel5gVal;
928 return true;
929}
930
931bool convertHidlNanPublishRequestToLegacy(
932 const NanPublishRequest& hidl_request,
933 legacy_hal::NanPublishRequest* legacy_request) {
934 if (!legacy_request) {
935 return false;
936 }
937 legacy_request->publish_id = hidl_request.publishId;
938 legacy_request->ttl = hidl_request.ttl;
939 legacy_request->period = hidl_request.period;
940 legacy_request->publish_type =
941 convertHidlNanPublishTypeToLegacy(hidl_request.publishType);
942 legacy_request->tx_type = convertHidlNanTxTypeToLegacy(hidl_request.txType);
943 legacy_request->publish_count = hidl_request.publishCount;
944 if (hidl_request.serviceName.size() > sizeof(legacy_request->service_name)) {
945 return false;
946 }
947 legacy_request->service_name_len = hidl_request.serviceName.size();
948 memcpy(legacy_request->service_name,
949 hidl_request.serviceName.c_str(),
950 hidl_request.serviceName.size());
951 legacy_request->publish_match_indicator =
952 convertHidlNanMatchAlgToLegacy(hidl_request.publishMatchIndicator);
953 if (hidl_request.serviceSpecificInfo.size() >
954 sizeof(legacy_request->service_specific_info)) {
955 return false;
956 }
957 legacy_request->service_specific_info_len =
958 hidl_request.serviceSpecificInfo.size();
959 memcpy(legacy_request->service_specific_info,
960 hidl_request.serviceSpecificInfo.data(),
961 hidl_request.serviceSpecificInfo.size());
962 if (hidl_request.rxMatchFilter.size() >
963 sizeof(legacy_request->rx_match_filter)) {
964 return false;
965 }
966 legacy_request->rx_match_filter_len = hidl_request.rxMatchFilter.size();
967 memcpy(legacy_request->rx_match_filter,
968 hidl_request.rxMatchFilter.data(),
969 hidl_request.rxMatchFilter.size());
970 if (hidl_request.txMatchFilter.size() >
971 sizeof(legacy_request->tx_match_filter)) {
972 return false;
973 }
974 legacy_request->tx_match_filter_len = hidl_request.txMatchFilter.size();
975 memcpy(legacy_request->tx_match_filter,
976 hidl_request.txMatchFilter.data(),
977 hidl_request.txMatchFilter.size());
978 legacy_request->rssi_threshold_flag = hidl_request.useRssiThreshold;
979 legacy_request->connmap = hidl_request.connmap;
980 legacy_request->recv_indication_cfg = hidl_request.recvIndicationCfg;
981 return true;
982}
983
984bool convertHidlNanPublishCancelRequestToLegacy(
985 const NanPublishCancelRequest& hidl_request,
986 legacy_hal::NanPublishCancelRequest* legacy_request) {
987 legacy_request->publish_id = hidl_request.publishId;
988 return true;
989}
990
991bool convertHidlNanSubscribeRequestToLegacy(
992 const NanSubscribeRequest& hidl_request,
993 legacy_hal::NanSubscribeRequest* legacy_request) {
994 if (!legacy_request) {
995 return false;
996 }
997 legacy_request->subscribe_id = hidl_request.subscribeId;
998 legacy_request->ttl = hidl_request.ttl;
999 legacy_request->period = hidl_request.period;
1000 legacy_request->subscribe_type =
1001 convertHidlNanSubscribeTypeToLegacy(hidl_request.subscribeType);
1002 legacy_request->serviceResponseFilter =
1003 convertHidlNanSrfTypeToLegacy(hidl_request.serviceResponseFilter);
1004 legacy_request->serviceResponseInclude =
1005 convertHidlNanSrfIncludeTypeToLegacy(hidl_request.serviceResponseInclude);
1006 legacy_request->useServiceResponseFilter =
1007 hidl_request.shouldUseServiceResponseFilter
1008 ? legacy_hal::NAN_USE_SRF
1009 : legacy_hal::NAN_DO_NOT_USE_SRF;
1010 legacy_request->ssiRequiredForMatchIndication =
1011 hidl_request.isSsiRequiredForMatchIndication
1012 ? legacy_hal::NAN_SSI_REQUIRED_IN_MATCH_IND
1013 : legacy_hal::NAN_SSI_NOT_REQUIRED_IN_MATCH_IND;
1014 legacy_request->subscribe_match_indicator =
1015 convertHidlNanMatchAlgToLegacy(hidl_request.subscribeMatchIndicator);
1016 legacy_request->subscribe_count = hidl_request.subscribeCount;
1017 if (hidl_request.serviceName.size() > sizeof(legacy_request->service_name)) {
1018 return false;
1019 }
1020 legacy_request->service_name_len = hidl_request.serviceName.size();
1021 memcpy(legacy_request->service_name,
1022 hidl_request.serviceName.c_str(),
1023 hidl_request.serviceName.size());
1024 if (hidl_request.serviceSpecificInfo.size() >
1025 sizeof(legacy_request->service_specific_info)) {
1026 return false;
1027 }
1028 legacy_request->service_specific_info_len =
1029 hidl_request.serviceSpecificInfo.size();
1030 memcpy(legacy_request->service_specific_info,
1031 hidl_request.serviceSpecificInfo.data(),
1032 hidl_request.serviceSpecificInfo.size());
1033 if (hidl_request.rxMatchFilter.size() >
1034 sizeof(legacy_request->rx_match_filter)) {
1035 return false;
1036 }
1037 legacy_request->rx_match_filter_len = hidl_request.rxMatchFilter.size();
1038 memcpy(legacy_request->rx_match_filter,
1039 hidl_request.rxMatchFilter.data(),
1040 hidl_request.rxMatchFilter.size());
1041 if (hidl_request.txMatchFilter.size() >
1042 sizeof(legacy_request->tx_match_filter)) {
1043 return false;
1044 }
1045 legacy_request->tx_match_filter_len = hidl_request.txMatchFilter.size();
1046 memcpy(legacy_request->tx_match_filter,
1047 hidl_request.txMatchFilter.data(),
1048 hidl_request.txMatchFilter.size());
1049 legacy_request->rssi_threshold_flag = hidl_request.useRssiThreshold;
1050 legacy_request->connmap = hidl_request.connmap;
1051 if (hidl_request.intfAddr.size() > NAN_MAX_SUBSCRIBE_MAX_ADDRESS) {
1052 return false;
1053 }
1054 legacy_request->num_intf_addr_present = hidl_request.intfAddr.size();
1055 for (uint32_t i = 0; i < hidl_request.intfAddr.size(); i++) {
1056 CHECK(hidl_request.intfAddr[i].size() ==
1057 sizeof(legacy_request->intf_addr[i]));
1058 memcpy(legacy_request->intf_addr[i],
1059 hidl_request.intfAddr[i].data(),
1060 hidl_request.intfAddr[i].size());
1061 }
1062 legacy_request->recv_indication_cfg = hidl_request.recvIndicationCfg;
1063 return true;
1064}
1065
1066bool convertHidlNanSubscribeCancelRequestToLegacy(
1067 const NanSubscribeCancelRequest& /* hidl_request */,
1068 legacy_hal::NanSubscribeCancelRequest* /* legacy_request */) {
1069 return false;
1070}
1071
1072bool convertHidlNanTransmitFollowupRequestToLegacy(
1073 const NanTransmitFollowupRequest& /* hidl_request */,
1074 legacy_hal::NanTransmitFollowupRequest* /* legacy_request */) {
1075 return false;
1076}
1077
1078bool convertHidlNanConfigRequestToLegacy(
1079 const NanConfigRequest& /* hidl_request */,
1080 legacy_hal::NanConfigRequest* /* legacy_request */) {
1081 return false;
1082}
1083
1084bool convertHidlNanBeaconSdfPayloadRequestToLegacy(
1085 const NanBeaconSdfPayloadRequest& /* hidl_request */,
1086 legacy_hal::NanBeaconSdfPayloadRequest* /* legacy_request */) {
1087 return false;
1088}
1089
1090bool convertHidlNanDataPathInitiatorRequestToLegacy(
1091 const NanDataPathInitiatorRequest& /* hidl_request */,
1092 legacy_hal::NanDataPathInitiatorRequest* /* legacy_request */) {
1093 return false;
1094}
1095
1096bool convertHidlNanDataPathIndicationResponseToLegacy(
1097 const NanDataPathIndicationResponse& /* hidl_response */,
1098 legacy_hal::NanDataPathIndicationResponse* /* legacy_response */) {
1099 return false;
1100}
1101
1102bool convertHidlNanDataPathEndRequestToLegacy(
1103 const NanDataPathEndRequest& /* hidl_request */,
1104 legacy_hal::NanDataPathEndRequest* /* legacy_request */) {
1105 return false;
1106}
1107
1108bool convertLegacyNanResponseHeaderToHidl(
1109 const legacy_hal::NanResponseMsg& legacy_response,
1110 NanResponseMsgHeader* hidl_response) {
1111 if (!hidl_response) {
1112 return false;
1113 }
1114 hidl_response->status =
1115 convertLegacyNanStatusTypeToHidl(legacy_response.status);
1116 hidl_response->value = legacy_response.value;
1117 hidl_response->responseType =
1118 convertLegacyNanResponseTypeToHidl(legacy_response.response_type);
1119 return true;
1120}
1121
1122bool convertLegacyNanPublishResponseToHidl(
1123 const legacy_hal::NanPublishResponse& /* legacy_response */,
1124 NanPublishResponse* /* hidl_response */) {
1125 return false;
1126}
1127
1128bool convertLegacyNanSubscribeResponseToHidl(
1129 const legacy_hal::NanSubscribeResponse& /* legacy_response */,
1130 NanSubscribeResponse* /* hidl_response */) {
1131 return false;
1132}
1133
1134bool convertLegacyNanDataPathResponseToHidl(
1135 const legacy_hal::NanDataPathRequestResponse& /* legacy_response */,
1136 NanDataPathResponse* /* hidl_response */) {
1137 return false;
1138}
1139
1140bool convertLegacyNanCapabilitiesResponseToHidl(
1141 const legacy_hal::NanCapabilities& /* legacy_response */,
1142 NanCapabilitiesResponse* /* hidl_response */) {
1143 return false;
1144}
1145
1146bool convertLegacyNanPublishTerminatedIndToHidl(
1147 const legacy_hal::NanPublishTerminatedInd& /* legacy_ind */,
1148 NanPublishTerminatedInd* /* hidl_ind */) {
1149 return false;
1150}
1151
1152bool convertLegacyNanMatchIndToHidl(
1153 const legacy_hal::NanMatchInd& /* legacy_ind */,
1154 NanMatchInd* /* hidl_ind */) {
1155 return false;
1156}
1157
1158bool convertLegacyNanMatchExpiredIndToHidl(
1159 const legacy_hal::NanMatchExpiredInd& /* legacy_ind */,
1160 NanMatchExpiredInd* /* hidl_ind */) {
1161 return false;
1162}
1163
1164bool convertLegacyNanSubscribeTerminatedIndToHidl(
1165 const legacy_hal::NanSubscribeTerminatedInd& /* legacy_ind */,
1166 NanSubscribeTerminatedInd* /* hidl_ind */) {
1167 return false;
1168}
1169
1170bool convertLegacyNanFollowupIndToHidl(
1171 const legacy_hal::NanFollowupInd& /* legacy_ind */,
1172 NanFollowupInd* /* hidl_ind */) {
1173 return false;
1174}
1175
1176bool convertLegacyNanDiscEngEventIndToHidl(
1177 const legacy_hal::NanDiscEngEventInd& /* legacy_ind */,
1178 NanDiscEngEventInd* /* hidl_ind */) {
1179 return false;
1180}
1181
1182bool convertLegacyNanDisabledIndToHidl(
1183 const legacy_hal::NanDisabledInd& /* legacy_ind */,
1184 NanDisabledInd* /* hidl_ind */) {
1185 return false;
1186}
1187
1188bool convertLegacyNanBeaconSdfPayloadIndToHidl(
1189 const legacy_hal::NanBeaconSdfPayloadInd& /* legacy_ind */,
1190 NanBeaconSdfPayloadInd* /* hidl_ind */) {
1191 return false;
1192}
1193
1194bool convertLegacyNanDataPathRequestIndToHidl(
1195 const legacy_hal::NanDataPathRequestInd& /* legacy_ind */,
1196 NanDataPathRequestInd* /* hidl_ind */) {
1197 return false;
1198}
1199
1200bool convertLegacyNanDataPathConfirmIndToHidl(
1201 const legacy_hal::NanDataPathConfirmInd& /* legacy_ind */,
1202 NanDataPathConfirmInd* /* hidl_ind */) {
1203 return false;
1204}
1205
1206bool convertLegacyNanDataPathEndIndToHidl(
1207 const legacy_hal::NanDataPathEndInd& /* legacy_ind */,
1208 NanDataPathEndInd* /* hidl_ind */) {
1209 return false;
1210}
1211
1212bool convertLegacyNanTransmitFollowupIndToHidl(
1213 const legacy_hal::NanTransmitFollowupInd& /* legacy_ind */,
1214 NanTransmitFollowupInd* /* hidl_ind */) {
1215 return false;
1216}
Roshan Pius3fae9c82016-12-02 14:49:41 -08001217
1218legacy_hal::wifi_rtt_type convertHidlRttTypeToLegacy(RttType type) {
1219 switch (type) {
1220 case RttType::ONE_SIDED:
1221 return legacy_hal::RTT_TYPE_1_SIDED;
1222 case RttType::TWO_SIDED:
1223 return legacy_hal::RTT_TYPE_2_SIDED;
1224 };
1225 CHECK(false);
1226}
1227
1228RttType convertLegacyRttTypeToHidl(legacy_hal::wifi_rtt_type type) {
1229 switch (type) {
1230 case legacy_hal::RTT_TYPE_1_SIDED:
1231 return RttType::ONE_SIDED;
1232 case legacy_hal::RTT_TYPE_2_SIDED:
1233 return RttType::TWO_SIDED;
1234 };
1235 CHECK(false) << "Unknown legacy type: " << type;
1236}
1237
1238legacy_hal::rtt_peer_type convertHidlRttPeerTypeToLegacy(RttPeerType type) {
1239 switch (type) {
1240 case RttPeerType::AP:
1241 return legacy_hal::RTT_PEER_AP;
1242 case RttPeerType::STA:
1243 return legacy_hal::RTT_PEER_STA;
1244 case RttPeerType::P2P_GO:
1245 return legacy_hal::RTT_PEER_P2P_GO;
1246 case RttPeerType::P2P_CLIENT:
1247 return legacy_hal::RTT_PEER_P2P_CLIENT;
1248 case RttPeerType::NAN:
1249 return legacy_hal::RTT_PEER_NAN;
1250 };
1251 CHECK(false);
1252}
1253
1254legacy_hal::wifi_channel_width convertHidlWifiChannelWidthToLegacy(
1255 WifiChannelWidthInMhz type) {
1256 switch (type) {
1257 case WifiChannelWidthInMhz::WIDTH_20:
1258 return legacy_hal::WIFI_CHAN_WIDTH_20;
1259 case WifiChannelWidthInMhz::WIDTH_40:
1260 return legacy_hal::WIFI_CHAN_WIDTH_40;
1261 case WifiChannelWidthInMhz::WIDTH_80:
1262 return legacy_hal::WIFI_CHAN_WIDTH_80;
1263 case WifiChannelWidthInMhz::WIDTH_160:
1264 return legacy_hal::WIFI_CHAN_WIDTH_160;
1265 case WifiChannelWidthInMhz::WIDTH_80P80:
1266 return legacy_hal::WIFI_CHAN_WIDTH_80P80;
1267 case WifiChannelWidthInMhz::WIDTH_5:
1268 return legacy_hal::WIFI_CHAN_WIDTH_5;
1269 case WifiChannelWidthInMhz::WIDTH_10:
1270 return legacy_hal::WIFI_CHAN_WIDTH_10;
1271 case WifiChannelWidthInMhz::WIDTH_INVALID:
1272 return legacy_hal::WIFI_CHAN_WIDTH_INVALID;
1273 };
1274 CHECK(false);
1275}
1276
1277WifiChannelWidthInMhz convertLegacyWifiChannelWidthToHidl(
1278 legacy_hal::wifi_channel_width type) {
1279 switch (type) {
1280 case legacy_hal::WIFI_CHAN_WIDTH_20:
1281 return WifiChannelWidthInMhz::WIDTH_20;
1282 case legacy_hal::WIFI_CHAN_WIDTH_40:
1283 return WifiChannelWidthInMhz::WIDTH_40;
1284 case legacy_hal::WIFI_CHAN_WIDTH_80:
1285 return WifiChannelWidthInMhz::WIDTH_80;
1286 case legacy_hal::WIFI_CHAN_WIDTH_160:
1287 return WifiChannelWidthInMhz::WIDTH_160;
1288 case legacy_hal::WIFI_CHAN_WIDTH_80P80:
1289 return WifiChannelWidthInMhz::WIDTH_80P80;
1290 case legacy_hal::WIFI_CHAN_WIDTH_5:
1291 return WifiChannelWidthInMhz::WIDTH_5;
1292 case legacy_hal::WIFI_CHAN_WIDTH_10:
1293 return WifiChannelWidthInMhz::WIDTH_10;
1294 case legacy_hal::WIFI_CHAN_WIDTH_INVALID:
1295 return WifiChannelWidthInMhz::WIDTH_INVALID;
1296 };
1297 CHECK(false) << "Unknown legacy type: " << type;
1298}
1299
1300legacy_hal::wifi_rtt_preamble convertHidlRttPreambleToLegacy(RttPreamble type) {
1301 switch (type) {
1302 case RttPreamble::LEGACY:
1303 return legacy_hal::WIFI_RTT_PREAMBLE_LEGACY;
1304 case RttPreamble::HT:
1305 return legacy_hal::WIFI_RTT_PREAMBLE_HT;
1306 case RttPreamble::VHT:
1307 return legacy_hal::WIFI_RTT_PREAMBLE_VHT;
1308 };
1309 CHECK(false);
1310}
1311
1312RttPreamble convertLegacyRttPreambleToHidl(legacy_hal::wifi_rtt_preamble type) {
1313 switch (type) {
1314 case legacy_hal::WIFI_RTT_PREAMBLE_LEGACY:
1315 return RttPreamble::LEGACY;
1316 case legacy_hal::WIFI_RTT_PREAMBLE_HT:
1317 return RttPreamble::HT;
1318 case legacy_hal::WIFI_RTT_PREAMBLE_VHT:
1319 return RttPreamble::VHT;
1320 };
1321 CHECK(false) << "Unknown legacy type: " << type;
1322}
1323
1324legacy_hal::wifi_rtt_bw convertHidlRttBwToLegacy(RttBw type) {
1325 switch (type) {
1326 case RttBw::BW_5MHZ:
1327 return legacy_hal::WIFI_RTT_BW_5;
1328 case RttBw::BW_10MHZ:
1329 return legacy_hal::WIFI_RTT_BW_10;
1330 case RttBw::BW_20MHZ:
1331 return legacy_hal::WIFI_RTT_BW_20;
1332 case RttBw::BW_40MHZ:
1333 return legacy_hal::WIFI_RTT_BW_40;
1334 case RttBw::BW_80MHZ:
1335 return legacy_hal::WIFI_RTT_BW_80;
1336 case RttBw::BW_160MHZ:
1337 return legacy_hal::WIFI_RTT_BW_160;
1338 };
1339 CHECK(false);
1340}
1341
1342RttBw convertLegacyRttBwToHidl(legacy_hal::wifi_rtt_bw type) {
1343 switch (type) {
1344 case legacy_hal::WIFI_RTT_BW_5:
1345 return RttBw::BW_5MHZ;
1346 case legacy_hal::WIFI_RTT_BW_10:
1347 return RttBw::BW_10MHZ;
1348 case legacy_hal::WIFI_RTT_BW_20:
1349 return RttBw::BW_20MHZ;
1350 case legacy_hal::WIFI_RTT_BW_40:
1351 return RttBw::BW_40MHZ;
1352 case legacy_hal::WIFI_RTT_BW_80:
1353 return RttBw::BW_80MHZ;
1354 case legacy_hal::WIFI_RTT_BW_160:
1355 return RttBw::BW_160MHZ;
1356 };
1357 CHECK(false) << "Unknown legacy type: " << type;
1358}
1359
1360legacy_hal::wifi_motion_pattern convertHidlRttMotionPatternToLegacy(
1361 RttMotionPattern type) {
1362 switch (type) {
1363 case RttMotionPattern::NOT_EXPECTED:
1364 return legacy_hal::WIFI_MOTION_NOT_EXPECTED;
1365 case RttMotionPattern::EXPECTED:
1366 return legacy_hal::WIFI_MOTION_EXPECTED;
1367 case RttMotionPattern::UNKNOWN:
1368 return legacy_hal::WIFI_MOTION_UNKNOWN;
1369 };
1370 CHECK(false);
1371}
1372
1373WifiRatePreamble convertLegacyWifiRatePreambleToHidl(uint8_t preamble) {
1374 switch (preamble) {
1375 case 0:
1376 return WifiRatePreamble::OFDM;
1377 case 1:
1378 return WifiRatePreamble::CCK;
1379 case 2:
1380 return WifiRatePreamble::HT;
1381 case 3:
1382 return WifiRatePreamble::VHT;
1383 default:
1384 return WifiRatePreamble::RESERVED;
1385 };
1386 CHECK(false) << "Unknown legacy preamble: " << preamble;
1387}
1388
1389WifiRateNss convertLegacyWifiRateNssToHidl(uint8_t nss) {
1390 switch (nss) {
1391 case 0:
1392 return WifiRateNss::NSS_1x1;
1393 case 1:
1394 return WifiRateNss::NSS_2x2;
1395 case 2:
1396 return WifiRateNss::NSS_3x3;
1397 case 3:
1398 return WifiRateNss::NSS_4x4;
1399 };
1400 CHECK(false) << "Unknown legacy nss: " << nss;
1401 return {};
1402}
1403
1404RttStatus convertLegacyRttStatusToHidl(legacy_hal::wifi_rtt_status status) {
1405 switch (status) {
1406 case legacy_hal::RTT_STATUS_SUCCESS:
1407 return RttStatus::SUCCESS;
1408 case legacy_hal::RTT_STATUS_FAILURE:
1409 return RttStatus::FAILURE;
1410 case legacy_hal::RTT_STATUS_FAIL_NO_RSP:
1411 return RttStatus::FAIL_NO_RSP;
1412 case legacy_hal::RTT_STATUS_FAIL_REJECTED:
1413 return RttStatus::FAIL_REJECTED;
1414 case legacy_hal::RTT_STATUS_FAIL_NOT_SCHEDULED_YET:
1415 return RttStatus::FAIL_NOT_SCHEDULED_YET;
1416 case legacy_hal::RTT_STATUS_FAIL_TM_TIMEOUT:
1417 return RttStatus::FAIL_TM_TIMEOUT;
1418 case legacy_hal::RTT_STATUS_FAIL_AP_ON_DIFF_CHANNEL:
1419 return RttStatus::FAIL_AP_ON_DIFF_CHANNEL;
1420 case legacy_hal::RTT_STATUS_FAIL_NO_CAPABILITY:
1421 return RttStatus::FAIL_NO_CAPABILITY;
1422 case legacy_hal::RTT_STATUS_ABORTED:
1423 return RttStatus::ABORTED;
1424 case legacy_hal::RTT_STATUS_FAIL_INVALID_TS:
1425 return RttStatus::FAIL_INVALID_TS;
1426 case legacy_hal::RTT_STATUS_FAIL_PROTOCOL:
1427 return RttStatus::FAIL_PROTOCOL;
1428 case legacy_hal::RTT_STATUS_FAIL_SCHEDULE:
1429 return RttStatus::FAIL_SCHEDULE;
1430 case legacy_hal::RTT_STATUS_FAIL_BUSY_TRY_LATER:
1431 return RttStatus::FAIL_BUSY_TRY_LATER;
1432 case legacy_hal::RTT_STATUS_INVALID_REQ:
1433 return RttStatus::INVALID_REQ;
1434 case legacy_hal::RTT_STATUS_NO_WIFI:
1435 return RttStatus::NO_WIFI;
1436 case legacy_hal::RTT_STATUS_FAIL_FTM_PARAM_OVERRIDE:
1437 return RttStatus::FAIL_FTM_PARAM_OVERRIDE;
1438 };
1439 CHECK(false) << "Unknown legacy status: " << status;
1440}
1441
1442bool convertHidlWifiChannelInfoToLegacy(
1443 const WifiChannelInfo& hidl_info,
1444 legacy_hal::wifi_channel_info* legacy_info) {
1445 if (!legacy_info) {
1446 return false;
1447 }
1448 legacy_info->width = convertHidlWifiChannelWidthToLegacy(hidl_info.width);
1449 legacy_info->center_freq = hidl_info.centerFreq;
1450 legacy_info->center_freq0 = hidl_info.centerFreq0;
1451 legacy_info->center_freq1 = hidl_info.centerFreq1;
1452 return true;
1453}
1454
1455bool convertLegacyWifiChannelInfoToHidl(
1456 const legacy_hal::wifi_channel_info& legacy_info,
1457 WifiChannelInfo* hidl_info) {
1458 if (!hidl_info) {
1459 return false;
1460 }
1461 hidl_info->width = convertLegacyWifiChannelWidthToHidl(legacy_info.width);
1462 hidl_info->centerFreq = legacy_info.center_freq;
1463 hidl_info->centerFreq0 = legacy_info.center_freq0;
1464 hidl_info->centerFreq1 = legacy_info.center_freq1;
1465 return true;
1466}
1467
1468bool convertHidlRttConfigToLegacy(const RttConfig& hidl_config,
1469 legacy_hal::wifi_rtt_config* legacy_config) {
1470 if (!legacy_config) {
1471 return false;
1472 }
1473 CHECK(hidl_config.addr.size() == sizeof(legacy_config->addr));
1474 memcpy(legacy_config->addr, hidl_config.addr.data(), hidl_config.addr.size());
1475 legacy_config->type = convertHidlRttTypeToLegacy(hidl_config.type);
1476 legacy_config->peer = convertHidlRttPeerTypeToLegacy(hidl_config.peer);
1477 if (!convertHidlWifiChannelInfoToLegacy(hidl_config.channel,
1478 &legacy_config->channel)) {
1479 return false;
1480 }
1481 legacy_config->burst_period = hidl_config.burstPeriod;
1482 legacy_config->num_burst = hidl_config.numBurst;
1483 legacy_config->num_frames_per_burst = hidl_config.numFramesPerBurst;
1484 legacy_config->num_retries_per_rtt_frame = hidl_config.numRetriesPerRttFrame;
1485 legacy_config->num_retries_per_ftmr = hidl_config.numRetriesPerFtmr;
1486 legacy_config->LCI_request = hidl_config.mustRequestLci;
1487 legacy_config->LCR_request = hidl_config.mustRequestLcr;
1488 legacy_config->burst_duration = hidl_config.burstDuration;
1489 legacy_config->preamble =
1490 convertHidlRttPreambleToLegacy(hidl_config.preamble);
1491 legacy_config->bw = convertHidlRttBwToLegacy(hidl_config.bw);
1492 return true;
1493}
1494
Roshan Piuse3f72ff2016-12-05 16:18:43 -08001495bool convertHidlVectorOfRttConfigToLegacy(
1496 const std::vector<RttConfig>& hidl_configs,
1497 std::vector<legacy_hal::wifi_rtt_config>* legacy_configs) {
1498 if (!legacy_configs) {
1499 return false;
1500 }
1501 legacy_configs->clear();
1502 for (const auto& hidl_config : hidl_configs) {
1503 legacy_hal::wifi_rtt_config legacy_config;
1504 if (!convertHidlRttConfigToLegacy(hidl_config, &legacy_config)) {
1505 return false;
1506 }
1507 legacy_configs->push_back(legacy_config);
1508 }
1509 return true;
1510}
1511
Roshan Pius3fae9c82016-12-02 14:49:41 -08001512bool convertHidlRttLciInformationToLegacy(
1513 const RttLciInformation& hidl_info,
1514 legacy_hal::wifi_lci_information* legacy_info) {
1515 if (!legacy_info) {
1516 return false;
1517 }
1518 legacy_info->latitude = hidl_info.latitude;
1519 legacy_info->longitude = hidl_info.longitude;
1520 legacy_info->altitude = hidl_info.altitude;
1521 legacy_info->latitude_unc = hidl_info.latitudeUnc;
1522 legacy_info->longitude_unc = hidl_info.longitudeUnc;
1523 legacy_info->altitude_unc = hidl_info.altitudeUnc;
1524 legacy_info->motion_pattern =
1525 convertHidlRttMotionPatternToLegacy(hidl_info.motionPattern);
1526 legacy_info->floor = hidl_info.floor;
1527 legacy_info->height_above_floor = hidl_info.heightAboveFloor;
1528 legacy_info->height_unc = hidl_info.heightUnc;
1529 return true;
1530}
1531
1532bool convertHidlRttLcrInformationToLegacy(
1533 const RttLcrInformation& hidl_info,
1534 legacy_hal::wifi_lcr_information* legacy_info) {
1535 if (!legacy_info) {
1536 return false;
1537 }
1538 CHECK(hidl_info.countryCode.size() == sizeof(legacy_info->country_code));
1539 memcpy(legacy_info->country_code,
1540 hidl_info.countryCode.data(),
1541 hidl_info.countryCode.size());
1542 if (hidl_info.civicInfo.size() > sizeof(legacy_info->civic_info)) {
1543 return false;
1544 }
1545 legacy_info->length = hidl_info.civicInfo.size();
1546 memcpy(legacy_info->civic_info,
1547 hidl_info.civicInfo.c_str(),
1548 hidl_info.civicInfo.size());
1549 return true;
1550}
1551
1552bool convertHidlRttResponderToLegacy(
1553 const RttResponder& hidl_responder,
1554 legacy_hal::wifi_rtt_responder* legacy_responder) {
1555 if (!legacy_responder) {
1556 return false;
1557 }
1558 if (!convertHidlWifiChannelInfoToLegacy(hidl_responder.channel,
1559 &legacy_responder->channel)) {
1560 return false;
1561 }
1562 legacy_responder->preamble =
1563 convertHidlRttPreambleToLegacy(hidl_responder.preamble);
1564 return true;
1565}
1566
1567bool convertLegacyRttResponderToHidl(
1568 const legacy_hal::wifi_rtt_responder& legacy_responder,
1569 RttResponder* hidl_responder) {
1570 if (!hidl_responder) {
1571 return false;
1572 }
1573 if (!convertLegacyWifiChannelInfoToHidl(legacy_responder.channel,
1574 &hidl_responder->channel)) {
1575 return false;
1576 }
1577 hidl_responder->preamble =
1578 convertLegacyRttPreambleToHidl(legacy_responder.preamble);
1579 return true;
1580}
1581
1582bool convertLegacyRttCapabilitiesToHidl(
1583 const legacy_hal::wifi_rtt_capabilities& legacy_capabilities,
1584 RttCapabilities* hidl_capabilities) {
1585 if (!hidl_capabilities) {
1586 return false;
1587 }
1588 hidl_capabilities->rttOneSidedSupported =
1589 legacy_capabilities.rtt_one_sided_supported;
1590 hidl_capabilities->rttFtmSupported = legacy_capabilities.rtt_ftm_supported;
1591 hidl_capabilities->lciSupported = legacy_capabilities.lci_support;
1592 hidl_capabilities->lcrSupported = legacy_capabilities.lcr_support;
1593 hidl_capabilities->responderSupported =
1594 legacy_capabilities.responder_supported;
1595 for (const auto flag : {legacy_hal::WIFI_RTT_PREAMBLE_LEGACY,
1596 legacy_hal::WIFI_RTT_PREAMBLE_HT,
1597 legacy_hal::WIFI_RTT_PREAMBLE_VHT}) {
1598 if (legacy_capabilities.preamble_support & flag) {
1599 hidl_capabilities->preambleSupport |=
1600 static_cast<std::underlying_type<RttPreamble>::type>(
1601 convertLegacyRttPreambleToHidl(flag));
1602 }
1603 }
1604 for (const auto flag : {legacy_hal::WIFI_RTT_BW_5,
1605 legacy_hal::WIFI_RTT_BW_10,
1606 legacy_hal::WIFI_RTT_BW_20,
1607 legacy_hal::WIFI_RTT_BW_40,
1608 legacy_hal::WIFI_RTT_BW_80,
1609 legacy_hal::WIFI_RTT_BW_160}) {
1610 if (legacy_capabilities.bw_support & flag) {
1611 hidl_capabilities->bwSupport |=
1612 static_cast<std::underlying_type<RttBw>::type>(
1613 convertLegacyRttBwToHidl(flag));
1614 }
1615 }
1616 hidl_capabilities->mcVersion = legacy_capabilities.mc_version;
1617 return true;
1618}
1619
1620bool convertLegacyWifiRateInfoToHidl(const legacy_hal::wifi_rate& legacy_rate,
1621 WifiRateInfo* hidl_rate) {
1622 if (!hidl_rate) {
1623 return false;
1624 }
1625 hidl_rate->preamble =
1626 convertLegacyWifiRatePreambleToHidl(legacy_rate.preamble);
1627 hidl_rate->nss = convertLegacyWifiRateNssToHidl(legacy_rate.nss);
1628 hidl_rate->bw = convertLegacyWifiChannelWidthToHidl(
1629 static_cast<legacy_hal::wifi_channel_width>(legacy_rate.bw));
1630 hidl_rate->rateMcsIdx = legacy_rate.rateMcsIdx;
1631 hidl_rate->bitRateInKbps = legacy_rate.bitrate;
1632 return true;
1633}
1634
1635bool convertLegacyRttResultToHidl(
1636 const legacy_hal::wifi_rtt_result& legacy_result, RttResult* hidl_result) {
1637 if (!hidl_result) {
1638 return false;
1639 }
1640 CHECK(sizeof(legacy_result.addr) == hidl_result->addr.size());
1641 memcpy(
1642 hidl_result->addr.data(), legacy_result.addr, sizeof(legacy_result.addr));
1643 hidl_result->burstNum = legacy_result.burst_num;
1644 hidl_result->measurementNumber = legacy_result.measurement_number;
1645 hidl_result->successNumber = legacy_result.success_number;
1646 hidl_result->numberPerBurstPeer = legacy_result.number_per_burst_peer;
1647 hidl_result->status = convertLegacyRttStatusToHidl(legacy_result.status);
1648 hidl_result->retryAfterDuration = legacy_result.retry_after_duration;
1649 hidl_result->type = convertLegacyRttTypeToHidl(legacy_result.type);
1650 hidl_result->rssi = legacy_result.rssi;
1651 hidl_result->rssiSpread = legacy_result.rssi_spread;
1652 if (!convertLegacyWifiRateInfoToHidl(legacy_result.tx_rate,
1653 &hidl_result->txRate)) {
1654 return false;
1655 }
1656 if (!convertLegacyWifiRateInfoToHidl(legacy_result.rx_rate,
1657 &hidl_result->rxRate)) {
1658 return false;
1659 }
1660 hidl_result->rtt = legacy_result.rtt;
1661 hidl_result->rttSd = legacy_result.rtt_sd;
1662 hidl_result->rttSpread = legacy_result.rtt_spread;
1663 hidl_result->distanceInMm = legacy_result.distance_mm;
1664 hidl_result->distanceSdInMm = legacy_result.distance_sd_mm;
1665 hidl_result->distanceSpreadInMm = legacy_result.distance_spread_mm;
1666 hidl_result->timeStampInUs = legacy_result.ts;
1667 hidl_result->burstDurationInMs = legacy_result.burst_duration;
1668 hidl_result->negotiatedBurstNum = legacy_result.negotiated_burst_num;
1669 if (!convertLegacyIeToHidl(*legacy_result.LCI, &hidl_result->lci)) {
1670 return false;
1671 }
1672 if (!convertLegacyIeToHidl(*legacy_result.LCR, &hidl_result->lcr)) {
1673 return false;
1674 }
1675 return true;
1676}
Roshan Piuse3f72ff2016-12-05 16:18:43 -08001677
1678bool convertLegacyVectorOfRttResultToHidl(
1679 const std::vector<const legacy_hal::wifi_rtt_result*>& legacy_results,
1680 std::vector<RttResult>* hidl_results) {
1681 if (!hidl_results) {
1682 return false;
1683 }
1684 hidl_results->clear();
1685 for (const auto legacy_result : legacy_results) {
1686 RttResult hidl_result;
1687 if (!convertLegacyRttResultToHidl(*legacy_result, &hidl_result)) {
1688 return false;
1689 }
1690 hidl_results->push_back(hidl_result);
1691 }
1692 return true;
1693}
Roshan Piuse65edb12016-11-22 13:02:01 -08001694} // namespace hidl_struct_util
1695} // namespace implementation
1696} // namespace V1_0
1697} // namespace wifi
1698} // namespace hardware
1699} // namespace android