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