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