blob: 9cc57bb5f1d0d3b890defdac9bdfe11a9f76fb5a [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 -0800746NanStatusType convertLegacyNanStatusTypeToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800747 legacy_hal::NanStatusType type) {
748 // values are identical - may need to do a mapping if they diverge in the future
749 return (NanStatusType) type;
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800750}
751
752bool convertHidlNanEnableRequestToLegacy(
753 const NanEnableRequest& hidl_request,
754 legacy_hal::NanEnableRequest* legacy_request) {
755 if (!legacy_request) {
756 return false;
757 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800758 memset(legacy_request, 0, sizeof(legacy_hal::NanEnableRequest));
759
760 // TODO: b/34059183 tracks missing configurations in legacy HAL or uknown defaults
761 legacy_request->config_2dot4g_support = 1;
762 legacy_request->support_2dot4g_val = hidl_request.operateInBand[
763 (size_t) NanBandIndex::NAN_BAND_24GHZ];
764 legacy_request->config_support_5g = 1;
765 legacy_request->support_5g_val = hidl_request.operateInBand[(size_t) NanBandIndex::NAN_BAND_5GHZ];
766 legacy_request->config_hop_count_limit = 0; // TODO: don't know default yet
767 legacy_request->hop_count_limit_val = hidl_request.hopCountMax;
768 legacy_request->master_pref = hidl_request.configParams.masterPref;
769 legacy_request->discovery_indication_cfg = 0;
770 legacy_request->discovery_indication_cfg |=
771 hidl_request.configParams.disableDiscoveryAddressChangeIndication ? 0x1 : 0x0;
772 legacy_request->discovery_indication_cfg |=
773 hidl_request.configParams.disableStartedClusterIndication ? 0x2 : 0x0;
774 legacy_request->discovery_indication_cfg |=
775 hidl_request.configParams.disableJoinedClusterIndication ? 0x4 : 0x0;
776 legacy_request->config_sid_beacon = 1;
777 if (hidl_request.configParams.numberOfServiceIdsInBeacon > 127) {
778 return false;
779 }
780 legacy_request->sid_beacon_val = (hidl_request.configParams.includeServiceIdsInBeacon ? 0x1 : 0x0)
781 | (hidl_request.configParams.numberOfServiceIdsInBeacon << 1);
782 legacy_request->config_rssi_window_size = 0; // TODO: don't know default yet
783 legacy_request->rssi_window_size_val = hidl_request.configParams.rssiWindowSize;
784 legacy_request->config_disc_mac_addr_randomization = 1;
785 legacy_request->disc_mac_addr_rand_interval_sec =
786 hidl_request.configParams.macAddressRandomizationIntervalSec;
787 legacy_request->config_responder_auto_response = 1;
788 legacy_request->ranging_auto_response_cfg = hidl_request.configParams.acceptRangingRequests ?
789 legacy_hal::NAN_RANGING_AUTO_RESPONSE_ENABLE : legacy_hal::NAN_RANGING_AUTO_RESPONSE_DISABLE;
790 legacy_request->config_2dot4g_rssi_close = 0; // TODO: don't know default yet
791 legacy_request->rssi_close_2dot4g_val =
792 hidl_request.configParams.bandSpecificConfig[
793 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiClose;
794 legacy_request->config_2dot4g_rssi_middle = 0; // TODO: don't know default yet
795 legacy_request->rssi_middle_2dot4g_val =
796 hidl_request.configParams.bandSpecificConfig[
797 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiMiddle;
798 legacy_request->config_2dot4g_rssi_proximity = 0; // TODO: don't know default yet
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800799 legacy_request->rssi_proximity_2dot4g_val =
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800800 hidl_request.configParams.bandSpecificConfig[
801 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiProximity;
802 legacy_request->config_scan_params = 0; // TODO: don't know default yet
803 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_24G_BAND] =
804 hidl_request.configParams.bandSpecificConfig[
805 (size_t) NanBandIndex::NAN_BAND_24GHZ].dwellTimeMs;
806 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_24G_BAND] =
807 hidl_request.configParams.bandSpecificConfig[
808 (size_t) NanBandIndex::NAN_BAND_24GHZ].scanPeriodSec;
809 legacy_request->config_dw.config_2dot4g_dw_band = hidl_request.configParams
810 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_24GHZ].validDiscoveryWindowIntervalVal;
811 legacy_request->config_dw.dw_2dot4g_interval_val = hidl_request.configParams
812 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_24GHZ].discoveryWindowIntervalVal;
813 legacy_request->config_5g_rssi_close = 0; // TODO: don't know default yet
814 legacy_request->rssi_close_5g_val =
815 hidl_request.configParams.bandSpecificConfig[
816 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiClose;
817 legacy_request->config_5g_rssi_middle = 0; // TODO: don't know default yet
818 legacy_request->rssi_middle_5g_val =
819 hidl_request.configParams.bandSpecificConfig[
820 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiMiddle;
821 legacy_request->config_5g_rssi_close_proximity = 0; // TODO: don't know default yet
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800822 legacy_request->rssi_close_proximity_5g_val =
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800823 hidl_request.configParams.bandSpecificConfig[
824 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiProximity;
825 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
826 hidl_request.configParams.bandSpecificConfig[
827 (size_t) NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
828 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
829 hidl_request.configParams.bandSpecificConfig[
830 (size_t) NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
831 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
832 hidl_request.configParams.bandSpecificConfig[
833 (size_t) NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
834 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
835 hidl_request.configParams.bandSpecificConfig[
836 (size_t) NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
837 legacy_request->config_dw.config_5g_dw_band = hidl_request.configParams
838 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_5GHZ].validDiscoveryWindowIntervalVal;
839 legacy_request->config_dw.dw_5g_interval_val = hidl_request.configParams
840 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_5GHZ].discoveryWindowIntervalVal;
841 if (hidl_request.debugConfigs.validClusterIdVals) {
842 legacy_request->cluster_low = hidl_request.debugConfigs.clusterIdLowVal;
843 legacy_request->cluster_high = hidl_request.debugConfigs.clusterIdHighVal;
844 } else { // need 'else' since not configurable in legacy HAL
845 legacy_request->cluster_low = 0x0000;
846 legacy_request->cluster_high = 0xFFFF;
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800847 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800848 legacy_request->config_intf_addr = hidl_request.debugConfigs.validIntfAddrVal;
849 memcpy(legacy_request->intf_addr_val, hidl_request.debugConfigs.intfAddrVal.data(), 6);
850 legacy_request->config_oui = hidl_request.debugConfigs.validOuiVal;
851 legacy_request->oui_val = hidl_request.debugConfigs.ouiVal;
852 legacy_request->config_random_factor_force = hidl_request.debugConfigs.validRandomFactorForceVal;
853 legacy_request->random_factor_force_val = hidl_request.debugConfigs.randomFactorForceVal;
854 legacy_request->config_hop_count_force = hidl_request.debugConfigs.validHopCountForceVal;
855 legacy_request->hop_count_force_val = hidl_request.debugConfigs.hopCountForceVal;
856 legacy_request->config_24g_channel = hidl_request.debugConfigs.validDiscoveryChannelVal;
857 legacy_request->channel_24g_val =
858 hidl_request.debugConfigs.discoveryChannelMhzVal[(size_t) NanBandIndex::NAN_BAND_24GHZ];
859 legacy_request->config_5g_channel = hidl_request.debugConfigs.validDiscoveryChannelVal;
860 legacy_request->channel_5g_val = hidl_request.debugConfigs
861 .discoveryChannelMhzVal[(size_t) NanBandIndex::NAN_BAND_5GHZ];
862 legacy_request->config_2dot4g_beacons = hidl_request.debugConfigs.validUseBeaconsInBandVal;
863 legacy_request->beacon_2dot4g_val = hidl_request.debugConfigs
864 .useBeaconsInBandVal[(size_t) NanBandIndex::NAN_BAND_24GHZ];
865 legacy_request->config_5g_beacons = hidl_request.debugConfigs.validUseBeaconsInBandVal;
866 legacy_request->beacon_5g_val = hidl_request.debugConfigs
867 .useBeaconsInBandVal[(size_t) NanBandIndex::NAN_BAND_5GHZ];
868 legacy_request->config_2dot4g_sdf = hidl_request.debugConfigs.validUseSdfInBandVal;
869 legacy_request->sdf_2dot4g_val = hidl_request.debugConfigs
870 .useSdfInBandVal[(size_t) NanBandIndex::NAN_BAND_24GHZ];
871 legacy_request->config_5g_sdf = hidl_request.debugConfigs.validUseSdfInBandVal;
872 legacy_request->sdf_5g_val = hidl_request.debugConfigs
873 .useSdfInBandVal[(size_t) NanBandIndex::NAN_BAND_5GHZ];
874
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800875 return true;
876}
877
878bool convertHidlNanPublishRequestToLegacy(
879 const NanPublishRequest& hidl_request,
880 legacy_hal::NanPublishRequest* legacy_request) {
881 if (!legacy_request) {
882 return false;
883 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800884 memset(&legacy_request, 0, sizeof(legacy_hal::NanPublishRequest));
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800885
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800886 legacy_request->publish_id = hidl_request.baseConfigs.sessionId;
887 legacy_request->ttl = hidl_request.baseConfigs.ttlSec;
888 legacy_request->period = hidl_request.baseConfigs.discoveryWindowPeriod;
889 legacy_request->publish_count = hidl_request.baseConfigs.discoveryCount;
890 legacy_request->service_name_len = hidl_request.baseConfigs.serviceName.size();
891 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
892 return false;
893 }
894 memcpy(legacy_request->service_name, hidl_request.baseConfigs.serviceName.c_str(),
895 legacy_request->service_name_len);
896 legacy_request->publish_match_indicator =
897 (legacy_hal::NanMatchAlg) hidl_request.baseConfigs.discoveryMatchIndicator;
898 legacy_request->service_specific_info_len = hidl_request.baseConfigs.serviceSpecificInfo.size();
899 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
900 return false;
901 }
902 memcpy(legacy_request->service_specific_info,
903 hidl_request.baseConfigs.serviceSpecificInfo.data(),
904 legacy_request->service_specific_info_len);
905 legacy_request->rx_match_filter_len = hidl_request.baseConfigs.rxMatchFilter.size();
906 if (legacy_request->rx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
907 return false;
908 }
909 memcpy(legacy_request->rx_match_filter,
910 hidl_request.baseConfigs.rxMatchFilter.data(),
911 legacy_request->rx_match_filter_len);
912 legacy_request->tx_match_filter_len = hidl_request.baseConfigs.txMatchFilter.size();
913 if (legacy_request->tx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
914 return false;
915 }
916 memcpy(legacy_request->tx_match_filter,
917 hidl_request.baseConfigs.txMatchFilter.data(),
918 legacy_request->tx_match_filter_len);
919 legacy_request->rssi_threshold_flag = hidl_request.baseConfigs.useRssiThreshold;
920 legacy_request->recv_indication_cfg = 0;
921 legacy_request->recv_indication_cfg |=
922 hidl_request.baseConfigs.disableDiscoveryTerminationIndication ? 0x1 : 0x0;
923 legacy_request->recv_indication_cfg |=
924 hidl_request.baseConfigs.disableMatchExpirationIndication ? 0x2 : 0x0;
925 legacy_request->recv_indication_cfg |=
926 hidl_request.baseConfigs.disableFollowupReceivedIndication ? 0x4 : 0x0;
927 legacy_request->cipher_type = hidl_request.baseConfigs.supportedCipherTypes;
928 legacy_request->pmk_len = hidl_request.baseConfigs.pmk.size();
929 if (legacy_request->pmk_len > NAN_PMK_INFO_LEN) {
930 return false;
931 }
932 memcpy(legacy_request->pmk,
933 hidl_request.baseConfigs.pmk.data(),
934 legacy_request->pmk_len);
935 legacy_request->sdea_params.security_cfg = hidl_request.baseConfigs.securityEnabledInNdp ?
936 legacy_hal::NAN_DP_CONFIG_SECURITY : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
937 legacy_request->sdea_params.ranging_state = hidl_request.baseConfigs.rangingRequired ?
938 legacy_hal::NAN_RANGING_ENABLE : legacy_hal::NAN_RANGING_DISABLE;
939 legacy_request->ranging_cfg.ranging_interval_msec = hidl_request.baseConfigs.rangingIntervalMsec;
940 legacy_request->ranging_cfg.config_ranging_indications =
941 hidl_request.baseConfigs.configRangingIndications;
942 legacy_request->ranging_cfg.distance_ingress_cm = hidl_request.baseConfigs.distanceIngressCm;
943 legacy_request->ranging_cfg.distance_egress_cm = hidl_request.baseConfigs.distanceEgressCm;
944 legacy_request->publish_type = (legacy_hal::NanPublishType) hidl_request.publishType;
945 legacy_request->tx_type = (legacy_hal::NanTxType) hidl_request.txType;
946
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800947 return true;
948}
949
950bool convertHidlNanSubscribeRequestToLegacy(
951 const NanSubscribeRequest& hidl_request,
952 legacy_hal::NanSubscribeRequest* legacy_request) {
953 if (!legacy_request) {
954 return false;
955 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800956 memset(&legacy_request, 0, sizeof(legacy_hal::NanSubscribeRequest));
957
958 legacy_request->subscribe_id = hidl_request.baseConfigs.sessionId;
959 legacy_request->ttl = hidl_request.baseConfigs.ttlSec;
960 legacy_request->period = hidl_request.baseConfigs.discoveryWindowPeriod;
961 legacy_request->subscribe_count = hidl_request.baseConfigs.discoveryCount;
962 legacy_request->service_name_len = hidl_request.baseConfigs.serviceName.size();
963 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
964 return false;
965 }
966 memcpy(legacy_request->service_name, hidl_request.baseConfigs.serviceName.c_str(),
967 legacy_request->service_name_len);
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800968 legacy_request->subscribe_match_indicator =
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800969 (legacy_hal::NanMatchAlg) hidl_request.baseConfigs.discoveryMatchIndicator;
970 legacy_request->service_specific_info_len = hidl_request.baseConfigs.serviceSpecificInfo.size();
971 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800972 return false;
973 }
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800974 memcpy(legacy_request->service_specific_info,
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800975 hidl_request.baseConfigs.serviceSpecificInfo.data(),
976 legacy_request->service_specific_info_len);
977 legacy_request->rx_match_filter_len = hidl_request.baseConfigs.rxMatchFilter.size();
978 if (legacy_request->rx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800979 return false;
980 }
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800981 memcpy(legacy_request->rx_match_filter,
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800982 hidl_request.baseConfigs.rxMatchFilter.data(),
983 legacy_request->rx_match_filter_len);
984 legacy_request->tx_match_filter_len = hidl_request.baseConfigs.txMatchFilter.size();
985 if (legacy_request->tx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800986 return false;
987 }
Roshan Piusf5f51fd2016-12-01 13:54:24 -0800988 memcpy(legacy_request->tx_match_filter,
Etan Cohenf01bcaa2016-12-25 09:42:21 -0800989 hidl_request.baseConfigs.txMatchFilter.data(),
990 legacy_request->tx_match_filter_len);
991 legacy_request->rssi_threshold_flag = hidl_request.baseConfigs.useRssiThreshold;
992 legacy_request->recv_indication_cfg = 0;
993 legacy_request->recv_indication_cfg |=
994 hidl_request.baseConfigs.disableDiscoveryTerminationIndication ? 0x1 : 0x0;
995 legacy_request->recv_indication_cfg |=
996 hidl_request.baseConfigs.disableMatchExpirationIndication ? 0x2 : 0x0;
997 legacy_request->recv_indication_cfg |=
998 hidl_request.baseConfigs.disableFollowupReceivedIndication ? 0x4 : 0x0;
999 legacy_request->cipher_type = hidl_request.baseConfigs.supportedCipherTypes;
1000 legacy_request->pmk_len = hidl_request.baseConfigs.pmk.size();
1001 if (legacy_request->pmk_len > NAN_PMK_INFO_LEN) {
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001002 return false;
1003 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001004 memcpy(legacy_request->pmk,
1005 hidl_request.baseConfigs.pmk.data(),
1006 legacy_request->pmk_len);
1007 legacy_request->sdea_params.security_cfg = hidl_request.baseConfigs.securityEnabledInNdp ?
1008 legacy_hal::NAN_DP_CONFIG_SECURITY : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
1009 legacy_request->sdea_params.ranging_state = hidl_request.baseConfigs.rangingRequired ?
1010 legacy_hal::NAN_RANGING_ENABLE : legacy_hal::NAN_RANGING_DISABLE;
1011 legacy_request->ranging_cfg.ranging_interval_msec = hidl_request.baseConfigs.rangingIntervalMsec;
1012 legacy_request->ranging_cfg.config_ranging_indications =
1013 hidl_request.baseConfigs.configRangingIndications;
1014 legacy_request->ranging_cfg.distance_ingress_cm = hidl_request.baseConfigs.distanceIngressCm;
1015 legacy_request->ranging_cfg.distance_egress_cm = hidl_request.baseConfigs.distanceEgressCm;
1016 legacy_request->subscribe_type = (legacy_hal::NanSubscribeType) hidl_request.subscribeType;
1017 legacy_request->serviceResponseFilter = (legacy_hal::NanSRFType) hidl_request.srfType;
1018 legacy_request->serviceResponseInclude = hidl_request.srfRespondIfInAddressSet ?
1019 legacy_hal::NAN_SRF_INCLUDE_RESPOND : legacy_hal::NAN_SRF_INCLUDE_DO_NOT_RESPOND;
1020 legacy_request->useServiceResponseFilter = hidl_request.shouldUseSrf ?
1021 legacy_hal::NAN_USE_SRF : legacy_hal::NAN_DO_NOT_USE_SRF;
1022 legacy_request->ssiRequiredForMatchIndication = hidl_request.isSsiRequiredForMatch ?
1023 legacy_hal::NAN_SSI_REQUIRED_IN_MATCH_IND : legacy_hal::NAN_SSI_NOT_REQUIRED_IN_MATCH_IND;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001024 legacy_request->num_intf_addr_present = hidl_request.intfAddr.size();
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001025 if (legacy_request->num_intf_addr_present > NAN_MAX_SUBSCRIBE_MAX_ADDRESS) {
1026 return false;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001027 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001028 for (int i = 0; i < legacy_request->num_intf_addr_present; i++) {
1029 memcpy(legacy_request->intf_addr[i], hidl_request.intfAddr[i].data(), 6);
1030 }
1031
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001032 return true;
1033}
1034
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001035bool convertHidlNanTransmitFollowupRequestToLegacy(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001036 const NanTransmitFollowupRequest& hidl_request,
1037 legacy_hal::NanTransmitFollowupRequest* legacy_request) {
1038 if (!legacy_request) {
1039 return false;
1040 }
1041 memset(&legacy_request, 0, sizeof(legacy_hal::NanTransmitFollowupRequest));
1042
1043 legacy_request->publish_subscribe_id = hidl_request.discoverySessionId;
1044 legacy_request->requestor_instance_id = hidl_request.peerId;
1045 memcpy(legacy_request->addr, hidl_request.addr.data(), 6);
1046 legacy_request->priority = hidl_request.isHighPriority ?
1047 legacy_hal::NAN_TX_PRIORITY_HIGH : legacy_hal::NAN_TX_PRIORITY_NORMAL;
1048 legacy_request->dw_or_faw = hidl_request.shouldUseDiscoveryWindow ?
1049 legacy_hal::NAN_TRANSMIT_IN_DW : legacy_hal::NAN_TRANSMIT_IN_FAW;
1050 legacy_request->service_specific_info_len = hidl_request.message.size();
1051 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
1052 return false;
1053 }
1054 memcpy(legacy_request->service_specific_info,
1055 hidl_request.message.data(),
1056 legacy_request->service_specific_info_len);
1057 legacy_request->recv_indication_cfg = hidl_request.disableFollowupResultIndication ? 0x1 : 0x0;
1058
1059 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001060}
1061
1062bool convertHidlNanConfigRequestToLegacy(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001063 const NanConfigRequest& hidl_request,
1064 legacy_hal::NanConfigRequest* legacy_request) {
1065 if (!legacy_request) {
1066 return false;
1067 }
1068 memset(&legacy_request, 0, sizeof(legacy_hal::NanConfigRequest));
1069
1070 // TODO: b/34059183 tracks missing configurations in legacy HAL or uknown defaults
1071 legacy_request->master_pref = hidl_request.masterPref;
1072 legacy_request->discovery_indication_cfg = 0;
1073 legacy_request->discovery_indication_cfg |=
1074 hidl_request.disableDiscoveryAddressChangeIndication ? 0x1 : 0x0;
1075 legacy_request->discovery_indication_cfg |=
1076 hidl_request.disableStartedClusterIndication ? 0x2 : 0x0;
1077 legacy_request->discovery_indication_cfg |=
1078 hidl_request.disableJoinedClusterIndication ? 0x4 : 0x0;
1079 legacy_request->config_sid_beacon = 1;
1080 if (hidl_request.numberOfServiceIdsInBeacon > 127) {
1081 return false;
1082 }
1083 legacy_request->sid_beacon = (hidl_request.includeServiceIdsInBeacon ? 0x1 : 0x0)
1084 | (hidl_request.numberOfServiceIdsInBeacon << 1);
1085 legacy_request->config_rssi_window_size = 0; // TODO: don't know default yet
1086 legacy_request->rssi_window_size_val = hidl_request.rssiWindowSize;
1087 legacy_request->config_disc_mac_addr_randomization = 1;
1088 legacy_request->disc_mac_addr_rand_interval_sec =
1089 hidl_request.macAddressRandomizationIntervalSec;
1090 legacy_request->config_responder_auto_response = 1;
1091 legacy_request->ranging_auto_response_cfg = hidl_request.acceptRangingRequests ?
1092 legacy_hal::NAN_RANGING_AUTO_RESPONSE_ENABLE : legacy_hal::NAN_RANGING_AUTO_RESPONSE_DISABLE;
1093 /* TODO : missing
1094 legacy_request->config_2dot4g_rssi_close = 0; // TODO: don't know default yet
1095 legacy_request->rssi_close_2dot4g_val =
1096 hidl_request.bandSpecificConfig[
1097 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiClose;
1098 legacy_request->config_2dot4g_rssi_middle = 0; // TODO: don't know default yet
1099 legacy_request->rssi_middle_2dot4g_val =
1100 hidl_request.bandSpecificConfig[
1101 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiMiddle;
1102 legacy_request->config_2dot4g_rssi_proximity = 0; // TODO: don't know default yet
1103 legacy_request->rssi_proximity_2dot4g_val =
1104 hidl_request.bandSpecificConfig[
1105 (size_t) NanBandIndex::NAN_BAND_24GHZ].rssiProximity;
1106 */
1107 legacy_request->config_scan_params = 0; // TODO: don't know default yet
1108 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_24G_BAND] =
1109 hidl_request.bandSpecificConfig[
1110 (size_t) NanBandIndex::NAN_BAND_24GHZ].dwellTimeMs;
1111 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_24G_BAND] =
1112 hidl_request.bandSpecificConfig[
1113 (size_t) NanBandIndex::NAN_BAND_24GHZ].scanPeriodSec;
1114 legacy_request->config_dw.config_2dot4g_dw_band = hidl_request
1115 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_24GHZ].validDiscoveryWindowIntervalVal;
1116 legacy_request->config_dw.dw_2dot4g_interval_val = hidl_request
1117 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_24GHZ].discoveryWindowIntervalVal;
1118 /* TODO: missing
1119 legacy_request->config_5g_rssi_close = 0; // TODO: don't know default yet
1120 legacy_request->rssi_close_5g_val =
1121 hidl_request.bandSpecificConfig[
1122 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiClose;
1123 legacy_request->config_5g_rssi_middle = 0; // TODO: don't know default yet
1124 legacy_request->rssi_middle_5g_val =
1125 hidl_request.bandSpecificConfig[
1126 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiMiddle;
1127 */
1128 legacy_request->config_5g_rssi_close_proximity = 0; // TODO: don't know default yet
1129 legacy_request->rssi_close_proximity_5g_val =
1130 hidl_request.bandSpecificConfig[
1131 (size_t) NanBandIndex::NAN_BAND_5GHZ].rssiProximity;
1132 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1133 hidl_request.bandSpecificConfig[
1134 (size_t) NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
1135 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1136 hidl_request.bandSpecificConfig[
1137 (size_t) NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
1138 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1139 hidl_request.bandSpecificConfig[
1140 (size_t) NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
1141 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1142 hidl_request.bandSpecificConfig[
1143 (size_t) NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
1144 legacy_request->config_dw.config_5g_dw_band = hidl_request
1145 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_5GHZ].validDiscoveryWindowIntervalVal;
1146 legacy_request->config_dw.dw_5g_interval_val = hidl_request
1147 .bandSpecificConfig[(size_t) NanBandIndex::NAN_BAND_5GHZ].discoveryWindowIntervalVal;
1148
1149 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001150}
1151
1152bool convertHidlNanBeaconSdfPayloadRequestToLegacy(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001153 const NanBeaconSdfPayloadRequest& hidl_request,
1154 legacy_hal::NanBeaconSdfPayloadRequest* legacy_request) {
1155 if (!legacy_request) {
1156 return false;
1157 }
1158 memset(&legacy_request, 0, sizeof(legacy_hal::NanBeaconSdfPayloadRequest));
1159
1160 legacy_request->vsa.payload_transmit_flag = hidl_request.transmitInNext16dws ? 1 : 0;
1161 legacy_request->vsa.tx_in_discovery_beacon = hidl_request.transmitInDiscoveryBeacon;
1162 legacy_request->vsa.tx_in_sync_beacon = hidl_request.transmitInSyncBeacon;
1163 legacy_request->vsa.tx_in_service_discovery = hidl_request.transmitInServiceDiscoveryFrame;
1164 legacy_request->vsa.vendor_oui = hidl_request.vendorOui;
1165 legacy_request->vsa.vsa_len = hidl_request.vsa.size();
1166 if (legacy_request->vsa.vsa_len > NAN_MAX_VSA_DATA_LEN) {
1167 return false;
1168 }
1169 memcpy(legacy_request->vsa.vsa, hidl_request.vsa.data(), legacy_request->vsa.vsa_len);
1170
1171 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001172}
1173
1174bool convertHidlNanDataPathInitiatorRequestToLegacy(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001175 const NanInitiateDataPathRequest& hidl_request,
1176 legacy_hal::NanDataPathInitiatorRequest* legacy_request) {
1177 if (!legacy_request) {
1178 return false;
1179 }
1180 memset(&legacy_request, 0, sizeof(legacy_hal::NanDataPathInitiatorRequest));
1181
1182 legacy_request->requestor_instance_id = hidl_request.peerId;
1183 memcpy(legacy_request->peer_disc_mac_addr, hidl_request.peerDiscMacAddr.data(), 6);
1184 legacy_request->channel_request_type =
1185 (legacy_hal::NanDataPathChannelCfg) hidl_request.channelRequestType;
1186 legacy_request->channel = hidl_request.channel;
1187 strcpy(legacy_request->ndp_iface, hidl_request.ifaceName.c_str());
1188 legacy_request->ndp_cfg.security_cfg = hidl_request.securityRequired ?
1189 legacy_hal::NAN_DP_CONFIG_SECURITY : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
1190 legacy_request->app_info.ndp_app_info_len = hidl_request.appInfo.size();
1191 if (legacy_request->app_info.ndp_app_info_len > NAN_DP_MAX_APP_INFO_LEN) {
1192 return false;
1193 }
1194 memcpy(legacy_request->app_info.ndp_app_info, hidl_request.appInfo.data(),
1195 legacy_request->app_info.ndp_app_info_len);
1196 legacy_request->cipher_type = hidl_request.supportedCipherTypes;
1197 legacy_request->pmk_len = hidl_request.pmk.size();
1198 if (legacy_request->pmk_len > NAN_PMK_INFO_LEN) {
1199 return false;
1200 }
1201 memcpy(legacy_request->pmk, hidl_request.pmk.data(), legacy_request->pmk_len);
1202
1203 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001204}
1205
1206bool convertHidlNanDataPathIndicationResponseToLegacy(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001207 const NanRespondToDataPathIndicationRequest& hidl_request,
1208 legacy_hal::NanDataPathIndicationResponse* legacy_request) {
1209 if (!legacy_request) {
1210 return false;
1211 }
1212 memset(&legacy_request, 0, sizeof(legacy_hal::NanDataPathIndicationResponse));
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001213
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001214 legacy_request->rsp_code = hidl_request.acceptRequest ?
1215 legacy_hal::NAN_DP_REQUEST_ACCEPT : legacy_hal::NAN_DP_REQUEST_REJECT;
1216 legacy_request->ndp_instance_id = hidl_request.ndpInstanceId;
1217 strcpy(legacy_request->ndp_iface, hidl_request.ifaceName.c_str());
1218 legacy_request->ndp_cfg.security_cfg = hidl_request.securityRequired ?
1219 legacy_hal::NAN_DP_CONFIG_SECURITY : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
1220 legacy_request->app_info.ndp_app_info_len = hidl_request.appInfo.size();
1221 if (legacy_request->app_info.ndp_app_info_len > NAN_DP_MAX_APP_INFO_LEN) {
1222 return false;
1223 }
1224 memcpy(legacy_request->app_info.ndp_app_info, hidl_request.appInfo.data(),
1225 legacy_request->app_info.ndp_app_info_len);
1226 legacy_request->cipher_type = hidl_request.supportedCipherTypes;
1227 legacy_request->pmk_len = hidl_request.pmk.size();
1228 if (legacy_request->pmk_len > NAN_PMK_INFO_LEN) {
1229 return false;
1230 }
1231 memcpy(legacy_request->pmk, hidl_request.pmk.data(), legacy_request->pmk_len);
1232
1233 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001234}
1235
1236bool convertLegacyNanResponseHeaderToHidl(
1237 const legacy_hal::NanResponseMsg& legacy_response,
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001238 WifiNanStatus* wifiNanStatus) {
1239 if (!wifiNanStatus) {
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001240 return false;
1241 }
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001242 wifiNanStatus->status = convertLegacyNanStatusTypeToHidl(legacy_response.status);
1243 wifiNanStatus->description = legacy_response.nan_error;
1244
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001245 return true;
1246}
1247
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001248bool convertLegacyNanCapabilitiesResponseToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001249 const legacy_hal::NanCapabilities& legacy_response,
1250 NanCapabilities* hidl_response) {
1251 if (!hidl_response) {
1252 return false;
1253 }
1254 hidl_response->maxConcurrentClusters = legacy_response.max_concurrent_nan_clusters;
1255 hidl_response->maxPublishes = legacy_response.max_publishes;
1256 hidl_response->maxSubscribes = legacy_response.max_subscribes;
1257 hidl_response->maxServiceNameLen = legacy_response.max_service_name_len;
1258 hidl_response->maxMatchFilterLen = legacy_response.max_match_filter_len;
1259 hidl_response->maxTotalMatchFilterLen = legacy_response.max_total_match_filter_len;
1260 hidl_response->maxServiceSpecificInfoLen = legacy_response.max_service_specific_info_len;
1261 hidl_response->maxVsaDataLen = legacy_response.max_vsa_data_len;
1262 hidl_response->maxNdiInterfaces = legacy_response.max_ndi_interfaces;
1263 hidl_response->maxNdpSessions = legacy_response.max_ndp_sessions;
1264 hidl_response->maxAppInfoLen = legacy_response.max_app_info_len;
1265 hidl_response->maxQueuedTransmitFollowupMsgs = legacy_response.max_queued_transmit_followup_msgs;
1266 // TODO: b/34059183 to add to underlying HAL
1267 hidl_response->maxSubscribeInterfaceAddresses = NAN_MAX_SUBSCRIBE_MAX_ADDRESS;
1268 hidl_response->supportedCipherSuites = legacy_response.cipher_suites_supported;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001269
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001270 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001271}
1272
1273bool convertLegacyNanMatchIndToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001274 const legacy_hal::NanMatchInd& legacy_ind,
1275 NanMatchInd* hidl_ind) {
1276 if (!hidl_ind) {
1277 return false;
1278 }
1279 hidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
1280 hidl_ind->peerId = legacy_ind.requestor_instance_id;
1281 hidl_ind->addr = hidl_array<uint8_t, 6>(legacy_ind.addr);
1282 hidl_ind->serviceSpecificInfo = std::vector<uint8_t>(legacy_ind.service_specific_info,
1283 legacy_ind.service_specific_info + legacy_ind.service_specific_info_len);
1284 hidl_ind->matchFilter = std::vector<uint8_t>(legacy_ind.sdf_match_filter,
1285 legacy_ind.sdf_match_filter + legacy_ind.sdf_match_filter_len);
1286 hidl_ind->matchOccuredInBeaconFlag = legacy_ind.match_occured_flag == 1;
1287 hidl_ind->outOfResourceFlag = legacy_ind.out_of_resource_flag == 1;
1288 hidl_ind->rssiValue = legacy_ind.rssi_value;
1289 hidl_ind->peerSupportedCipherTypes = legacy_ind.peer_cipher_type;
1290 hidl_ind->peerRequiresSecurityEnabledInNdp =
1291 legacy_ind.peer_sdea_params.security_cfg == legacy_hal::NAN_DP_CONFIG_SECURITY;
1292 hidl_ind->peerRequiresRanging =
1293 legacy_ind.peer_sdea_params.ranging_state == legacy_hal::NAN_RANGING_ENABLE;
1294 hidl_ind->rangingMeasurementInCm = legacy_ind.range_result.range_measurement_cm;
1295 hidl_ind->rangingIndicationType = legacy_ind.range_result.ranging_event_type;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001296
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001297 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001298}
1299
1300bool convertLegacyNanFollowupIndToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001301 const legacy_hal::NanFollowupInd& legacy_ind,
1302 NanFollowupReceivedInd* hidl_ind) {
1303 if (!hidl_ind) {
1304 return false;
1305 }
1306 hidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
1307 hidl_ind->peerId = legacy_ind.requestor_instance_id;
1308 hidl_ind->addr = hidl_array<uint8_t, 6>(legacy_ind.addr);
1309 hidl_ind->receivedInFaw = legacy_ind.dw_or_faw == 1;
1310 hidl_ind->message = std::vector<uint8_t>(legacy_ind.service_specific_info,
1311 legacy_ind.service_specific_info + legacy_ind.service_specific_info_len);
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001312
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001313 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001314}
1315
1316bool convertLegacyNanBeaconSdfPayloadIndToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001317 const legacy_hal::NanBeaconSdfPayloadInd& legacy_ind,
1318 NanBeaconSdfPayloadInd* hidl_ind) {
1319 if (!hidl_ind) {
1320 return false;
1321 }
1322 hidl_ind->addr = hidl_array<uint8_t, 6>(legacy_ind.addr);
1323 hidl_ind->isVsaReceived = legacy_ind.is_vsa_received == 1;
1324 hidl_ind->vsaReceivedOnFrames = legacy_ind.vsa.vsa_received_on;
1325 hidl_ind->vsaVendorOui = legacy_ind.vsa.vendor_oui;
1326 hidl_ind->vsa = std::vector<uint8_t>(legacy_ind.vsa.vsa,
1327 legacy_ind.vsa.vsa + legacy_ind.vsa.attr_len);
1328 hidl_ind->isBeaconSdfPayloadReceived = legacy_ind.is_beacon_sdf_payload_received == 1;
1329 hidl_ind->beaconSdfPayloadData = std::vector<uint8_t>(legacy_ind.data.frame_data,
1330 legacy_ind.data.frame_data + legacy_ind.data.frame_len);
1331
1332 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001333}
1334
1335bool convertLegacyNanDataPathRequestIndToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001336 const legacy_hal::NanDataPathRequestInd& legacy_ind,
1337 NanDataPathRequestInd* hidl_ind) {
1338 if (!hidl_ind) {
1339 return false;
1340 }
1341 hidl_ind->discoverySessionId = legacy_ind.service_instance_id;
1342 hidl_ind->peerDiscMacAddr = hidl_array<uint8_t, 6>(legacy_ind.peer_disc_mac_addr);
1343 hidl_ind->ndpInstanceId = legacy_ind.ndp_instance_id;
1344 hidl_ind->securityRequired =
1345 legacy_ind.ndp_cfg.security_cfg == legacy_hal::NAN_DP_CONFIG_SECURITY;
1346 hidl_ind->appInfo = std::vector<uint8_t>(legacy_ind.app_info.ndp_app_info,
1347 legacy_ind.app_info.ndp_app_info + legacy_ind.app_info.ndp_app_info_len);
1348
1349 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001350}
1351
1352bool convertLegacyNanDataPathConfirmIndToHidl(
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001353 const legacy_hal::NanDataPathConfirmInd& legacy_ind,
1354 NanDataPathConfirmInd* hidl_ind) {
1355 if (!hidl_ind) {
1356 return false;
1357 }
1358 hidl_ind->ndpInstanceId = legacy_ind.ndp_instance_id;
1359 hidl_ind->dataPathSetupSuccess = legacy_ind.rsp_code == legacy_hal::NAN_DP_REQUEST_ACCEPT;
1360 hidl_ind->peerNdiMacAddr = hidl_array<uint8_t, 6>(legacy_ind.peer_ndi_mac_addr);
1361 hidl_ind->appInfo = std::vector<uint8_t>(legacy_ind.app_info.ndp_app_info,
1362 legacy_ind.app_info.ndp_app_info + legacy_ind.app_info.ndp_app_info_len);
1363 hidl_ind->status.status = convertLegacyNanStatusTypeToHidl(legacy_ind.reason_code);
1364 hidl_ind->status.description = ""; // TODO: b/34059183
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001365
Etan Cohenf01bcaa2016-12-25 09:42:21 -08001366 return true;
Roshan Piusf5f51fd2016-12-01 13:54:24 -08001367}
Roshan Pius3fae9c82016-12-02 14:49:41 -08001368
1369legacy_hal::wifi_rtt_type convertHidlRttTypeToLegacy(RttType type) {
1370 switch (type) {
1371 case RttType::ONE_SIDED:
1372 return legacy_hal::RTT_TYPE_1_SIDED;
1373 case RttType::TWO_SIDED:
1374 return legacy_hal::RTT_TYPE_2_SIDED;
1375 };
1376 CHECK(false);
1377}
1378
1379RttType convertLegacyRttTypeToHidl(legacy_hal::wifi_rtt_type type) {
1380 switch (type) {
1381 case legacy_hal::RTT_TYPE_1_SIDED:
1382 return RttType::ONE_SIDED;
1383 case legacy_hal::RTT_TYPE_2_SIDED:
1384 return RttType::TWO_SIDED;
1385 };
1386 CHECK(false) << "Unknown legacy type: " << type;
1387}
1388
1389legacy_hal::rtt_peer_type convertHidlRttPeerTypeToLegacy(RttPeerType type) {
1390 switch (type) {
1391 case RttPeerType::AP:
1392 return legacy_hal::RTT_PEER_AP;
1393 case RttPeerType::STA:
1394 return legacy_hal::RTT_PEER_STA;
1395 case RttPeerType::P2P_GO:
1396 return legacy_hal::RTT_PEER_P2P_GO;
1397 case RttPeerType::P2P_CLIENT:
1398 return legacy_hal::RTT_PEER_P2P_CLIENT;
1399 case RttPeerType::NAN:
1400 return legacy_hal::RTT_PEER_NAN;
1401 };
1402 CHECK(false);
1403}
1404
1405legacy_hal::wifi_channel_width convertHidlWifiChannelWidthToLegacy(
1406 WifiChannelWidthInMhz type) {
1407 switch (type) {
1408 case WifiChannelWidthInMhz::WIDTH_20:
1409 return legacy_hal::WIFI_CHAN_WIDTH_20;
1410 case WifiChannelWidthInMhz::WIDTH_40:
1411 return legacy_hal::WIFI_CHAN_WIDTH_40;
1412 case WifiChannelWidthInMhz::WIDTH_80:
1413 return legacy_hal::WIFI_CHAN_WIDTH_80;
1414 case WifiChannelWidthInMhz::WIDTH_160:
1415 return legacy_hal::WIFI_CHAN_WIDTH_160;
1416 case WifiChannelWidthInMhz::WIDTH_80P80:
1417 return legacy_hal::WIFI_CHAN_WIDTH_80P80;
1418 case WifiChannelWidthInMhz::WIDTH_5:
1419 return legacy_hal::WIFI_CHAN_WIDTH_5;
1420 case WifiChannelWidthInMhz::WIDTH_10:
1421 return legacy_hal::WIFI_CHAN_WIDTH_10;
1422 case WifiChannelWidthInMhz::WIDTH_INVALID:
1423 return legacy_hal::WIFI_CHAN_WIDTH_INVALID;
1424 };
1425 CHECK(false);
1426}
1427
1428WifiChannelWidthInMhz convertLegacyWifiChannelWidthToHidl(
1429 legacy_hal::wifi_channel_width type) {
1430 switch (type) {
1431 case legacy_hal::WIFI_CHAN_WIDTH_20:
1432 return WifiChannelWidthInMhz::WIDTH_20;
1433 case legacy_hal::WIFI_CHAN_WIDTH_40:
1434 return WifiChannelWidthInMhz::WIDTH_40;
1435 case legacy_hal::WIFI_CHAN_WIDTH_80:
1436 return WifiChannelWidthInMhz::WIDTH_80;
1437 case legacy_hal::WIFI_CHAN_WIDTH_160:
1438 return WifiChannelWidthInMhz::WIDTH_160;
1439 case legacy_hal::WIFI_CHAN_WIDTH_80P80:
1440 return WifiChannelWidthInMhz::WIDTH_80P80;
1441 case legacy_hal::WIFI_CHAN_WIDTH_5:
1442 return WifiChannelWidthInMhz::WIDTH_5;
1443 case legacy_hal::WIFI_CHAN_WIDTH_10:
1444 return WifiChannelWidthInMhz::WIDTH_10;
1445 case legacy_hal::WIFI_CHAN_WIDTH_INVALID:
1446 return WifiChannelWidthInMhz::WIDTH_INVALID;
1447 };
1448 CHECK(false) << "Unknown legacy type: " << type;
1449}
1450
1451legacy_hal::wifi_rtt_preamble convertHidlRttPreambleToLegacy(RttPreamble type) {
1452 switch (type) {
1453 case RttPreamble::LEGACY:
1454 return legacy_hal::WIFI_RTT_PREAMBLE_LEGACY;
1455 case RttPreamble::HT:
1456 return legacy_hal::WIFI_RTT_PREAMBLE_HT;
1457 case RttPreamble::VHT:
1458 return legacy_hal::WIFI_RTT_PREAMBLE_VHT;
1459 };
1460 CHECK(false);
1461}
1462
1463RttPreamble convertLegacyRttPreambleToHidl(legacy_hal::wifi_rtt_preamble type) {
1464 switch (type) {
1465 case legacy_hal::WIFI_RTT_PREAMBLE_LEGACY:
1466 return RttPreamble::LEGACY;
1467 case legacy_hal::WIFI_RTT_PREAMBLE_HT:
1468 return RttPreamble::HT;
1469 case legacy_hal::WIFI_RTT_PREAMBLE_VHT:
1470 return RttPreamble::VHT;
1471 };
1472 CHECK(false) << "Unknown legacy type: " << type;
1473}
1474
1475legacy_hal::wifi_rtt_bw convertHidlRttBwToLegacy(RttBw type) {
1476 switch (type) {
1477 case RttBw::BW_5MHZ:
1478 return legacy_hal::WIFI_RTT_BW_5;
1479 case RttBw::BW_10MHZ:
1480 return legacy_hal::WIFI_RTT_BW_10;
1481 case RttBw::BW_20MHZ:
1482 return legacy_hal::WIFI_RTT_BW_20;
1483 case RttBw::BW_40MHZ:
1484 return legacy_hal::WIFI_RTT_BW_40;
1485 case RttBw::BW_80MHZ:
1486 return legacy_hal::WIFI_RTT_BW_80;
1487 case RttBw::BW_160MHZ:
1488 return legacy_hal::WIFI_RTT_BW_160;
1489 };
1490 CHECK(false);
1491}
1492
1493RttBw convertLegacyRttBwToHidl(legacy_hal::wifi_rtt_bw type) {
1494 switch (type) {
1495 case legacy_hal::WIFI_RTT_BW_5:
1496 return RttBw::BW_5MHZ;
1497 case legacy_hal::WIFI_RTT_BW_10:
1498 return RttBw::BW_10MHZ;
1499 case legacy_hal::WIFI_RTT_BW_20:
1500 return RttBw::BW_20MHZ;
1501 case legacy_hal::WIFI_RTT_BW_40:
1502 return RttBw::BW_40MHZ;
1503 case legacy_hal::WIFI_RTT_BW_80:
1504 return RttBw::BW_80MHZ;
1505 case legacy_hal::WIFI_RTT_BW_160:
1506 return RttBw::BW_160MHZ;
1507 };
1508 CHECK(false) << "Unknown legacy type: " << type;
1509}
1510
1511legacy_hal::wifi_motion_pattern convertHidlRttMotionPatternToLegacy(
1512 RttMotionPattern type) {
1513 switch (type) {
1514 case RttMotionPattern::NOT_EXPECTED:
1515 return legacy_hal::WIFI_MOTION_NOT_EXPECTED;
1516 case RttMotionPattern::EXPECTED:
1517 return legacy_hal::WIFI_MOTION_EXPECTED;
1518 case RttMotionPattern::UNKNOWN:
1519 return legacy_hal::WIFI_MOTION_UNKNOWN;
1520 };
1521 CHECK(false);
1522}
1523
1524WifiRatePreamble convertLegacyWifiRatePreambleToHidl(uint8_t preamble) {
1525 switch (preamble) {
1526 case 0:
1527 return WifiRatePreamble::OFDM;
1528 case 1:
1529 return WifiRatePreamble::CCK;
1530 case 2:
1531 return WifiRatePreamble::HT;
1532 case 3:
1533 return WifiRatePreamble::VHT;
1534 default:
1535 return WifiRatePreamble::RESERVED;
1536 };
1537 CHECK(false) << "Unknown legacy preamble: " << preamble;
1538}
1539
1540WifiRateNss convertLegacyWifiRateNssToHidl(uint8_t nss) {
1541 switch (nss) {
1542 case 0:
1543 return WifiRateNss::NSS_1x1;
1544 case 1:
1545 return WifiRateNss::NSS_2x2;
1546 case 2:
1547 return WifiRateNss::NSS_3x3;
1548 case 3:
1549 return WifiRateNss::NSS_4x4;
1550 };
1551 CHECK(false) << "Unknown legacy nss: " << nss;
1552 return {};
1553}
1554
1555RttStatus convertLegacyRttStatusToHidl(legacy_hal::wifi_rtt_status status) {
1556 switch (status) {
1557 case legacy_hal::RTT_STATUS_SUCCESS:
1558 return RttStatus::SUCCESS;
1559 case legacy_hal::RTT_STATUS_FAILURE:
1560 return RttStatus::FAILURE;
1561 case legacy_hal::RTT_STATUS_FAIL_NO_RSP:
1562 return RttStatus::FAIL_NO_RSP;
1563 case legacy_hal::RTT_STATUS_FAIL_REJECTED:
1564 return RttStatus::FAIL_REJECTED;
1565 case legacy_hal::RTT_STATUS_FAIL_NOT_SCHEDULED_YET:
1566 return RttStatus::FAIL_NOT_SCHEDULED_YET;
1567 case legacy_hal::RTT_STATUS_FAIL_TM_TIMEOUT:
1568 return RttStatus::FAIL_TM_TIMEOUT;
1569 case legacy_hal::RTT_STATUS_FAIL_AP_ON_DIFF_CHANNEL:
1570 return RttStatus::FAIL_AP_ON_DIFF_CHANNEL;
1571 case legacy_hal::RTT_STATUS_FAIL_NO_CAPABILITY:
1572 return RttStatus::FAIL_NO_CAPABILITY;
1573 case legacy_hal::RTT_STATUS_ABORTED:
1574 return RttStatus::ABORTED;
1575 case legacy_hal::RTT_STATUS_FAIL_INVALID_TS:
1576 return RttStatus::FAIL_INVALID_TS;
1577 case legacy_hal::RTT_STATUS_FAIL_PROTOCOL:
1578 return RttStatus::FAIL_PROTOCOL;
1579 case legacy_hal::RTT_STATUS_FAIL_SCHEDULE:
1580 return RttStatus::FAIL_SCHEDULE;
1581 case legacy_hal::RTT_STATUS_FAIL_BUSY_TRY_LATER:
1582 return RttStatus::FAIL_BUSY_TRY_LATER;
1583 case legacy_hal::RTT_STATUS_INVALID_REQ:
1584 return RttStatus::INVALID_REQ;
1585 case legacy_hal::RTT_STATUS_NO_WIFI:
1586 return RttStatus::NO_WIFI;
1587 case legacy_hal::RTT_STATUS_FAIL_FTM_PARAM_OVERRIDE:
1588 return RttStatus::FAIL_FTM_PARAM_OVERRIDE;
1589 };
1590 CHECK(false) << "Unknown legacy status: " << status;
1591}
1592
1593bool convertHidlWifiChannelInfoToLegacy(
1594 const WifiChannelInfo& hidl_info,
1595 legacy_hal::wifi_channel_info* legacy_info) {
1596 if (!legacy_info) {
1597 return false;
1598 }
1599 legacy_info->width = convertHidlWifiChannelWidthToLegacy(hidl_info.width);
1600 legacy_info->center_freq = hidl_info.centerFreq;
1601 legacy_info->center_freq0 = hidl_info.centerFreq0;
1602 legacy_info->center_freq1 = hidl_info.centerFreq1;
1603 return true;
1604}
1605
1606bool convertLegacyWifiChannelInfoToHidl(
1607 const legacy_hal::wifi_channel_info& legacy_info,
1608 WifiChannelInfo* hidl_info) {
1609 if (!hidl_info) {
1610 return false;
1611 }
1612 hidl_info->width = convertLegacyWifiChannelWidthToHidl(legacy_info.width);
1613 hidl_info->centerFreq = legacy_info.center_freq;
1614 hidl_info->centerFreq0 = legacy_info.center_freq0;
1615 hidl_info->centerFreq1 = legacy_info.center_freq1;
1616 return true;
1617}
1618
1619bool convertHidlRttConfigToLegacy(const RttConfig& hidl_config,
1620 legacy_hal::wifi_rtt_config* legacy_config) {
1621 if (!legacy_config) {
1622 return false;
1623 }
1624 CHECK(hidl_config.addr.size() == sizeof(legacy_config->addr));
1625 memcpy(legacy_config->addr, hidl_config.addr.data(), hidl_config.addr.size());
1626 legacy_config->type = convertHidlRttTypeToLegacy(hidl_config.type);
1627 legacy_config->peer = convertHidlRttPeerTypeToLegacy(hidl_config.peer);
1628 if (!convertHidlWifiChannelInfoToLegacy(hidl_config.channel,
1629 &legacy_config->channel)) {
1630 return false;
1631 }
1632 legacy_config->burst_period = hidl_config.burstPeriod;
1633 legacy_config->num_burst = hidl_config.numBurst;
1634 legacy_config->num_frames_per_burst = hidl_config.numFramesPerBurst;
1635 legacy_config->num_retries_per_rtt_frame = hidl_config.numRetriesPerRttFrame;
1636 legacy_config->num_retries_per_ftmr = hidl_config.numRetriesPerFtmr;
1637 legacy_config->LCI_request = hidl_config.mustRequestLci;
1638 legacy_config->LCR_request = hidl_config.mustRequestLcr;
1639 legacy_config->burst_duration = hidl_config.burstDuration;
1640 legacy_config->preamble =
1641 convertHidlRttPreambleToLegacy(hidl_config.preamble);
1642 legacy_config->bw = convertHidlRttBwToLegacy(hidl_config.bw);
1643 return true;
1644}
1645
Roshan Piuse3f72ff2016-12-05 16:18:43 -08001646bool convertHidlVectorOfRttConfigToLegacy(
1647 const std::vector<RttConfig>& hidl_configs,
1648 std::vector<legacy_hal::wifi_rtt_config>* legacy_configs) {
1649 if (!legacy_configs) {
1650 return false;
1651 }
1652 legacy_configs->clear();
1653 for (const auto& hidl_config : hidl_configs) {
1654 legacy_hal::wifi_rtt_config legacy_config;
1655 if (!convertHidlRttConfigToLegacy(hidl_config, &legacy_config)) {
1656 return false;
1657 }
1658 legacy_configs->push_back(legacy_config);
1659 }
1660 return true;
1661}
1662
Roshan Pius3fae9c82016-12-02 14:49:41 -08001663bool convertHidlRttLciInformationToLegacy(
1664 const RttLciInformation& hidl_info,
1665 legacy_hal::wifi_lci_information* legacy_info) {
1666 if (!legacy_info) {
1667 return false;
1668 }
1669 legacy_info->latitude = hidl_info.latitude;
1670 legacy_info->longitude = hidl_info.longitude;
1671 legacy_info->altitude = hidl_info.altitude;
1672 legacy_info->latitude_unc = hidl_info.latitudeUnc;
1673 legacy_info->longitude_unc = hidl_info.longitudeUnc;
1674 legacy_info->altitude_unc = hidl_info.altitudeUnc;
1675 legacy_info->motion_pattern =
1676 convertHidlRttMotionPatternToLegacy(hidl_info.motionPattern);
1677 legacy_info->floor = hidl_info.floor;
1678 legacy_info->height_above_floor = hidl_info.heightAboveFloor;
1679 legacy_info->height_unc = hidl_info.heightUnc;
1680 return true;
1681}
1682
1683bool convertHidlRttLcrInformationToLegacy(
1684 const RttLcrInformation& hidl_info,
1685 legacy_hal::wifi_lcr_information* legacy_info) {
1686 if (!legacy_info) {
1687 return false;
1688 }
1689 CHECK(hidl_info.countryCode.size() == sizeof(legacy_info->country_code));
1690 memcpy(legacy_info->country_code,
1691 hidl_info.countryCode.data(),
1692 hidl_info.countryCode.size());
1693 if (hidl_info.civicInfo.size() > sizeof(legacy_info->civic_info)) {
1694 return false;
1695 }
1696 legacy_info->length = hidl_info.civicInfo.size();
1697 memcpy(legacy_info->civic_info,
1698 hidl_info.civicInfo.c_str(),
1699 hidl_info.civicInfo.size());
1700 return true;
1701}
1702
1703bool convertHidlRttResponderToLegacy(
1704 const RttResponder& hidl_responder,
1705 legacy_hal::wifi_rtt_responder* legacy_responder) {
1706 if (!legacy_responder) {
1707 return false;
1708 }
1709 if (!convertHidlWifiChannelInfoToLegacy(hidl_responder.channel,
1710 &legacy_responder->channel)) {
1711 return false;
1712 }
1713 legacy_responder->preamble =
1714 convertHidlRttPreambleToLegacy(hidl_responder.preamble);
1715 return true;
1716}
1717
1718bool convertLegacyRttResponderToHidl(
1719 const legacy_hal::wifi_rtt_responder& legacy_responder,
1720 RttResponder* hidl_responder) {
1721 if (!hidl_responder) {
1722 return false;
1723 }
1724 if (!convertLegacyWifiChannelInfoToHidl(legacy_responder.channel,
1725 &hidl_responder->channel)) {
1726 return false;
1727 }
1728 hidl_responder->preamble =
1729 convertLegacyRttPreambleToHidl(legacy_responder.preamble);
1730 return true;
1731}
1732
1733bool convertLegacyRttCapabilitiesToHidl(
1734 const legacy_hal::wifi_rtt_capabilities& legacy_capabilities,
1735 RttCapabilities* hidl_capabilities) {
1736 if (!hidl_capabilities) {
1737 return false;
1738 }
1739 hidl_capabilities->rttOneSidedSupported =
1740 legacy_capabilities.rtt_one_sided_supported;
1741 hidl_capabilities->rttFtmSupported = legacy_capabilities.rtt_ftm_supported;
1742 hidl_capabilities->lciSupported = legacy_capabilities.lci_support;
1743 hidl_capabilities->lcrSupported = legacy_capabilities.lcr_support;
1744 hidl_capabilities->responderSupported =
1745 legacy_capabilities.responder_supported;
1746 for (const auto flag : {legacy_hal::WIFI_RTT_PREAMBLE_LEGACY,
1747 legacy_hal::WIFI_RTT_PREAMBLE_HT,
1748 legacy_hal::WIFI_RTT_PREAMBLE_VHT}) {
1749 if (legacy_capabilities.preamble_support & flag) {
1750 hidl_capabilities->preambleSupport |=
1751 static_cast<std::underlying_type<RttPreamble>::type>(
1752 convertLegacyRttPreambleToHidl(flag));
1753 }
1754 }
1755 for (const auto flag : {legacy_hal::WIFI_RTT_BW_5,
1756 legacy_hal::WIFI_RTT_BW_10,
1757 legacy_hal::WIFI_RTT_BW_20,
1758 legacy_hal::WIFI_RTT_BW_40,
1759 legacy_hal::WIFI_RTT_BW_80,
1760 legacy_hal::WIFI_RTT_BW_160}) {
1761 if (legacy_capabilities.bw_support & flag) {
1762 hidl_capabilities->bwSupport |=
1763 static_cast<std::underlying_type<RttBw>::type>(
1764 convertLegacyRttBwToHidl(flag));
1765 }
1766 }
1767 hidl_capabilities->mcVersion = legacy_capabilities.mc_version;
1768 return true;
1769}
1770
1771bool convertLegacyWifiRateInfoToHidl(const legacy_hal::wifi_rate& legacy_rate,
1772 WifiRateInfo* hidl_rate) {
1773 if (!hidl_rate) {
1774 return false;
1775 }
1776 hidl_rate->preamble =
1777 convertLegacyWifiRatePreambleToHidl(legacy_rate.preamble);
1778 hidl_rate->nss = convertLegacyWifiRateNssToHidl(legacy_rate.nss);
1779 hidl_rate->bw = convertLegacyWifiChannelWidthToHidl(
1780 static_cast<legacy_hal::wifi_channel_width>(legacy_rate.bw));
1781 hidl_rate->rateMcsIdx = legacy_rate.rateMcsIdx;
1782 hidl_rate->bitRateInKbps = legacy_rate.bitrate;
1783 return true;
1784}
1785
1786bool convertLegacyRttResultToHidl(
1787 const legacy_hal::wifi_rtt_result& legacy_result, RttResult* hidl_result) {
1788 if (!hidl_result) {
1789 return false;
1790 }
1791 CHECK(sizeof(legacy_result.addr) == hidl_result->addr.size());
1792 memcpy(
1793 hidl_result->addr.data(), legacy_result.addr, sizeof(legacy_result.addr));
1794 hidl_result->burstNum = legacy_result.burst_num;
1795 hidl_result->measurementNumber = legacy_result.measurement_number;
1796 hidl_result->successNumber = legacy_result.success_number;
1797 hidl_result->numberPerBurstPeer = legacy_result.number_per_burst_peer;
1798 hidl_result->status = convertLegacyRttStatusToHidl(legacy_result.status);
1799 hidl_result->retryAfterDuration = legacy_result.retry_after_duration;
1800 hidl_result->type = convertLegacyRttTypeToHidl(legacy_result.type);
1801 hidl_result->rssi = legacy_result.rssi;
1802 hidl_result->rssiSpread = legacy_result.rssi_spread;
1803 if (!convertLegacyWifiRateInfoToHidl(legacy_result.tx_rate,
1804 &hidl_result->txRate)) {
1805 return false;
1806 }
1807 if (!convertLegacyWifiRateInfoToHidl(legacy_result.rx_rate,
1808 &hidl_result->rxRate)) {
1809 return false;
1810 }
1811 hidl_result->rtt = legacy_result.rtt;
1812 hidl_result->rttSd = legacy_result.rtt_sd;
1813 hidl_result->rttSpread = legacy_result.rtt_spread;
1814 hidl_result->distanceInMm = legacy_result.distance_mm;
1815 hidl_result->distanceSdInMm = legacy_result.distance_sd_mm;
1816 hidl_result->distanceSpreadInMm = legacy_result.distance_spread_mm;
1817 hidl_result->timeStampInUs = legacy_result.ts;
1818 hidl_result->burstDurationInMs = legacy_result.burst_duration;
1819 hidl_result->negotiatedBurstNum = legacy_result.negotiated_burst_num;
1820 if (!convertLegacyIeToHidl(*legacy_result.LCI, &hidl_result->lci)) {
1821 return false;
1822 }
1823 if (!convertLegacyIeToHidl(*legacy_result.LCR, &hidl_result->lcr)) {
1824 return false;
1825 }
1826 return true;
1827}
Roshan Piuse3f72ff2016-12-05 16:18:43 -08001828
1829bool convertLegacyVectorOfRttResultToHidl(
1830 const std::vector<const legacy_hal::wifi_rtt_result*>& legacy_results,
1831 std::vector<RttResult>* hidl_results) {
1832 if (!hidl_results) {
1833 return false;
1834 }
1835 hidl_results->clear();
1836 for (const auto legacy_result : legacy_results) {
1837 RttResult hidl_result;
1838 if (!convertLegacyRttResultToHidl(*legacy_result, &hidl_result)) {
1839 return false;
1840 }
1841 hidl_results->push_back(hidl_result);
1842 }
1843 return true;
1844}
Roshan Piuse65edb12016-11-22 13:02:01 -08001845} // namespace hidl_struct_util
1846} // namespace implementation
1847} // namespace V1_0
1848} // namespace wifi
1849} // namespace hardware
1850} // namespace android