blob: 7bc2eeb349c698d589012f752f93f62014a4a071 [file] [log] [blame]
Gabriel Birenf3262f92022-07-15 23:25:39 +00001/*
2 * Copyright (C) 2022 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 "aidl_struct_util.h"
21
22namespace aidl {
23namespace android {
24namespace hardware {
25namespace wifi {
26namespace aidl_struct_util {
27
28WifiChannelWidthInMhz convertLegacyWifiChannelWidthToAidl(legacy_hal::wifi_channel_width type);
29
30std::string safeConvertChar(const char* str, size_t max_len) {
31 const char* c = str;
32 size_t size = 0;
33 while (*c && (unsigned char)*c < 128 && size < max_len) {
34 ++size;
35 ++c;
36 }
37 return std::string(str, size);
38}
39
40inline std::vector<int32_t> uintToIntVec(const std::vector<uint32_t>& in) {
41 return std::vector<int32_t>(in.begin(), in.end());
42}
43
Gabriel Biren2f862492023-03-09 19:13:07 +000044IWifiChip::FeatureSetMask convertLegacyChipFeatureToAidl(uint64_t feature) {
Gabriel Birenf3262f92022-07-15 23:25:39 +000045 switch (feature) {
46 case WIFI_FEATURE_SET_TX_POWER_LIMIT:
Gabriel Biren2f862492023-03-09 19:13:07 +000047 return IWifiChip::FeatureSetMask::SET_TX_POWER_LIMIT;
Gabriel Birenf3262f92022-07-15 23:25:39 +000048 case WIFI_FEATURE_USE_BODY_HEAD_SAR:
Gabriel Biren2f862492023-03-09 19:13:07 +000049 return IWifiChip::FeatureSetMask::USE_BODY_HEAD_SAR;
Gabriel Birenf3262f92022-07-15 23:25:39 +000050 case WIFI_FEATURE_D2D_RTT:
Gabriel Biren2f862492023-03-09 19:13:07 +000051 return IWifiChip::FeatureSetMask::D2D_RTT;
Gabriel Birenf3262f92022-07-15 23:25:39 +000052 case WIFI_FEATURE_D2AP_RTT:
Gabriel Biren2f862492023-03-09 19:13:07 +000053 return IWifiChip::FeatureSetMask::D2AP_RTT;
Gabriel Birenf3262f92022-07-15 23:25:39 +000054 case WIFI_FEATURE_INFRA_60G:
Gabriel Biren2f862492023-03-09 19:13:07 +000055 return IWifiChip::FeatureSetMask::WIGIG;
Gabriel Birenf3262f92022-07-15 23:25:39 +000056 case WIFI_FEATURE_SET_LATENCY_MODE:
Gabriel Biren2f862492023-03-09 19:13:07 +000057 return IWifiChip::FeatureSetMask::SET_LATENCY_MODE;
Gabriel Birenf3262f92022-07-15 23:25:39 +000058 case WIFI_FEATURE_P2P_RAND_MAC:
Gabriel Biren2f862492023-03-09 19:13:07 +000059 return IWifiChip::FeatureSetMask::P2P_RAND_MAC;
Oscar Shu79e826d2023-01-27 21:50:17 +000060 case WIFI_FEATURE_AFC_CHANNEL:
Gabriel Biren2f862492023-03-09 19:13:07 +000061 return IWifiChip::FeatureSetMask::SET_AFC_CHANNEL_ALLOWANCE;
Gabriel Birenf3262f92022-07-15 23:25:39 +000062 };
63 CHECK(false) << "Unknown legacy feature: " << feature;
64 return {};
65}
66
Gabriel Biren2f862492023-03-09 19:13:07 +000067IWifiStaIface::FeatureSetMask convertLegacyStaIfaceFeatureToAidl(uint64_t feature) {
Gabriel Birenf3262f92022-07-15 23:25:39 +000068 switch (feature) {
69 case WIFI_FEATURE_GSCAN:
Gabriel Biren2f862492023-03-09 19:13:07 +000070 return IWifiStaIface::FeatureSetMask::BACKGROUND_SCAN;
Gabriel Birenf3262f92022-07-15 23:25:39 +000071 case WIFI_FEATURE_LINK_LAYER_STATS:
Gabriel Biren2f862492023-03-09 19:13:07 +000072 return IWifiStaIface::FeatureSetMask::LINK_LAYER_STATS;
Gabriel Birenf3262f92022-07-15 23:25:39 +000073 case WIFI_FEATURE_RSSI_MONITOR:
Gabriel Biren2f862492023-03-09 19:13:07 +000074 return IWifiStaIface::FeatureSetMask::RSSI_MONITOR;
Gabriel Birenf3262f92022-07-15 23:25:39 +000075 case WIFI_FEATURE_CONTROL_ROAMING:
Gabriel Biren2f862492023-03-09 19:13:07 +000076 return IWifiStaIface::FeatureSetMask::CONTROL_ROAMING;
Gabriel Birenf3262f92022-07-15 23:25:39 +000077 case WIFI_FEATURE_IE_WHITELIST:
Gabriel Biren2f862492023-03-09 19:13:07 +000078 return IWifiStaIface::FeatureSetMask::PROBE_IE_ALLOWLIST;
Gabriel Birenf3262f92022-07-15 23:25:39 +000079 case WIFI_FEATURE_SCAN_RAND:
Gabriel Biren2f862492023-03-09 19:13:07 +000080 return IWifiStaIface::FeatureSetMask::SCAN_RAND;
Gabriel Birenf3262f92022-07-15 23:25:39 +000081 case WIFI_FEATURE_INFRA_5G:
Gabriel Biren2f862492023-03-09 19:13:07 +000082 return IWifiStaIface::FeatureSetMask::STA_5G;
Gabriel Birenf3262f92022-07-15 23:25:39 +000083 case WIFI_FEATURE_HOTSPOT:
Gabriel Biren2f862492023-03-09 19:13:07 +000084 return IWifiStaIface::FeatureSetMask::HOTSPOT;
Gabriel Birenf3262f92022-07-15 23:25:39 +000085 case WIFI_FEATURE_PNO:
Gabriel Biren2f862492023-03-09 19:13:07 +000086 return IWifiStaIface::FeatureSetMask::PNO;
Gabriel Birenf3262f92022-07-15 23:25:39 +000087 case WIFI_FEATURE_TDLS:
Gabriel Biren2f862492023-03-09 19:13:07 +000088 return IWifiStaIface::FeatureSetMask::TDLS;
Gabriel Birenf3262f92022-07-15 23:25:39 +000089 case WIFI_FEATURE_TDLS_OFFCHANNEL:
Gabriel Biren2f862492023-03-09 19:13:07 +000090 return IWifiStaIface::FeatureSetMask::TDLS_OFFCHANNEL;
Gabriel Birenf3262f92022-07-15 23:25:39 +000091 case WIFI_FEATURE_CONFIG_NDO:
Gabriel Biren2f862492023-03-09 19:13:07 +000092 return IWifiStaIface::FeatureSetMask::ND_OFFLOAD;
Gabriel Birenf3262f92022-07-15 23:25:39 +000093 case WIFI_FEATURE_MKEEP_ALIVE:
Gabriel Biren2f862492023-03-09 19:13:07 +000094 return IWifiStaIface::FeatureSetMask::KEEP_ALIVE;
Gabriel Birenf3262f92022-07-15 23:25:39 +000095 };
96 CHECK(false) << "Unknown legacy feature: " << feature;
97 return {};
98}
99
Gabriel Biren2f862492023-03-09 19:13:07 +0000100bool convertLegacyChipFeaturesToAidl(uint64_t legacy_feature_set, uint32_t* aidl_feature_set) {
101 if (!aidl_feature_set) {
Gabriel Birenf3262f92022-07-15 23:25:39 +0000102 return false;
103 }
Gabriel Biren2f862492023-03-09 19:13:07 +0000104 *aidl_feature_set = 0;
Gabriel Birenf3262f92022-07-15 23:25:39 +0000105 std::vector<uint64_t> features = {WIFI_FEATURE_SET_TX_POWER_LIMIT,
106 WIFI_FEATURE_USE_BODY_HEAD_SAR,
107 WIFI_FEATURE_D2D_RTT,
108 WIFI_FEATURE_D2AP_RTT,
109 WIFI_FEATURE_INFRA_60G,
110 WIFI_FEATURE_SET_LATENCY_MODE,
Oscar Shu79e826d2023-01-27 21:50:17 +0000111 WIFI_FEATURE_P2P_RAND_MAC,
112 WIFI_FEATURE_AFC_CHANNEL};
Gabriel Birenf3262f92022-07-15 23:25:39 +0000113 for (const auto feature : features) {
114 if (feature & legacy_feature_set) {
Gabriel Biren2f862492023-03-09 19:13:07 +0000115 *aidl_feature_set |= static_cast<uint32_t>(convertLegacyChipFeatureToAidl(feature));
Gabriel Birenf3262f92022-07-15 23:25:39 +0000116 }
117 }
118
Gabriel Birenf3262f92022-07-15 23:25:39 +0000119 return true;
120}
121
122WifiDebugRingBufferFlags convertLegacyDebugRingBufferFlagsToAidl(uint32_t flag) {
123 switch (flag) {
124 case WIFI_RING_BUFFER_FLAG_HAS_BINARY_ENTRIES:
125 return WifiDebugRingBufferFlags::HAS_BINARY_ENTRIES;
126 case WIFI_RING_BUFFER_FLAG_HAS_ASCII_ENTRIES:
127 return WifiDebugRingBufferFlags::HAS_ASCII_ENTRIES;
128 };
129 CHECK(false) << "Unknown legacy flag: " << flag;
130 return {};
131}
132
133bool convertLegacyDebugRingBufferStatusToAidl(
134 const legacy_hal::wifi_ring_buffer_status& legacy_status,
135 WifiDebugRingBufferStatus* aidl_status) {
136 if (!aidl_status) {
137 return false;
138 }
139 *aidl_status = {};
140 aidl_status->ringName = safeConvertChar(reinterpret_cast<const char*>(legacy_status.name),
141 sizeof(legacy_status.name));
142 aidl_status->flags = 0;
143 for (const auto flag :
144 {WIFI_RING_BUFFER_FLAG_HAS_BINARY_ENTRIES, WIFI_RING_BUFFER_FLAG_HAS_ASCII_ENTRIES}) {
145 if (flag & legacy_status.flags) {
146 aidl_status->flags |= static_cast<std::underlying_type<WifiDebugRingBufferFlags>::type>(
147 convertLegacyDebugRingBufferFlagsToAidl(flag));
148 }
149 }
150 aidl_status->ringId = legacy_status.ring_id;
151 aidl_status->sizeInBytes = legacy_status.ring_buffer_byte_size;
152 // Calculate free size of the ring the buffer. We don't need to send the
153 // exact read/write pointers that were there in the legacy HAL interface.
154 if (legacy_status.written_bytes >= legacy_status.read_bytes) {
155 aidl_status->freeSizeInBytes = legacy_status.ring_buffer_byte_size -
156 (legacy_status.written_bytes - legacy_status.read_bytes);
157 } else {
158 aidl_status->freeSizeInBytes = legacy_status.read_bytes - legacy_status.written_bytes;
159 }
160 aidl_status->verboseLevel = legacy_status.verbose_level;
161 return true;
162}
163
164bool convertLegacyVectorOfDebugRingBufferStatusToAidl(
165 const std::vector<legacy_hal::wifi_ring_buffer_status>& legacy_status_vec,
166 std::vector<WifiDebugRingBufferStatus>* aidl_status_vec) {
167 if (!aidl_status_vec) {
168 return false;
169 }
170 *aidl_status_vec = {};
171 for (const auto& legacy_status : legacy_status_vec) {
172 WifiDebugRingBufferStatus aidl_status;
173 if (!convertLegacyDebugRingBufferStatusToAidl(legacy_status, &aidl_status)) {
174 return false;
175 }
176 aidl_status_vec->push_back(aidl_status);
177 }
178 return true;
179}
180
181bool convertLegacyWakeReasonStatsToAidl(const legacy_hal::WakeReasonStats& legacy_stats,
182 WifiDebugHostWakeReasonStats* aidl_stats) {
183 if (!aidl_stats) {
184 return false;
185 }
186 *aidl_stats = {};
187 aidl_stats->totalCmdEventWakeCnt = legacy_stats.wake_reason_cnt.total_cmd_event_wake;
188 aidl_stats->cmdEventWakeCntPerType = uintToIntVec(legacy_stats.cmd_event_wake_cnt);
189 aidl_stats->totalDriverFwLocalWakeCnt = legacy_stats.wake_reason_cnt.total_driver_fw_local_wake;
190 aidl_stats->driverFwLocalWakeCntPerType = uintToIntVec(legacy_stats.driver_fw_local_wake_cnt);
191 aidl_stats->totalRxPacketWakeCnt = legacy_stats.wake_reason_cnt.total_rx_data_wake;
192 aidl_stats->rxPktWakeDetails.rxUnicastCnt =
193 legacy_stats.wake_reason_cnt.rx_wake_details.rx_unicast_cnt;
194 aidl_stats->rxPktWakeDetails.rxMulticastCnt =
195 legacy_stats.wake_reason_cnt.rx_wake_details.rx_multicast_cnt;
196 aidl_stats->rxPktWakeDetails.rxBroadcastCnt =
197 legacy_stats.wake_reason_cnt.rx_wake_details.rx_broadcast_cnt;
198 aidl_stats->rxMulticastPkWakeDetails.ipv4RxMulticastAddrCnt =
199 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info.ipv4_rx_multicast_addr_cnt;
200 aidl_stats->rxMulticastPkWakeDetails.ipv6RxMulticastAddrCnt =
201 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info.ipv6_rx_multicast_addr_cnt;
202 aidl_stats->rxMulticastPkWakeDetails.otherRxMulticastAddrCnt =
203 legacy_stats.wake_reason_cnt.rx_multicast_wake_pkt_info.other_rx_multicast_addr_cnt;
204 aidl_stats->rxIcmpPkWakeDetails.icmpPkt =
205 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp_pkt;
206 aidl_stats->rxIcmpPkWakeDetails.icmp6Pkt =
207 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_pkt;
208 aidl_stats->rxIcmpPkWakeDetails.icmp6Ra =
209 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_ra;
210 aidl_stats->rxIcmpPkWakeDetails.icmp6Na =
211 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_na;
212 aidl_stats->rxIcmpPkWakeDetails.icmp6Ns =
213 legacy_stats.wake_reason_cnt.rx_wake_pkt_classification_info.icmp6_ns;
214 return true;
215}
216
217legacy_hal::wifi_power_scenario convertAidlTxPowerScenarioToLegacy(
218 IWifiChip::TxPowerScenario aidl_scenario) {
219 switch (aidl_scenario) {
220 case IWifiChip::TxPowerScenario::VOICE_CALL:
221 return legacy_hal::WIFI_POWER_SCENARIO_VOICE_CALL;
222 case IWifiChip::TxPowerScenario::ON_HEAD_CELL_OFF:
223 return legacy_hal::WIFI_POWER_SCENARIO_ON_HEAD_CELL_OFF;
224 case IWifiChip::TxPowerScenario::ON_HEAD_CELL_ON:
225 return legacy_hal::WIFI_POWER_SCENARIO_ON_HEAD_CELL_ON;
226 case IWifiChip::TxPowerScenario::ON_BODY_CELL_OFF:
227 return legacy_hal::WIFI_POWER_SCENARIO_ON_BODY_CELL_OFF;
228 case IWifiChip::TxPowerScenario::ON_BODY_CELL_ON:
229 return legacy_hal::WIFI_POWER_SCENARIO_ON_BODY_CELL_ON;
230 };
231 CHECK(false);
232}
233
234legacy_hal::wifi_latency_mode convertAidlLatencyModeToLegacy(
235 IWifiChip::LatencyMode aidl_latency_mode) {
236 switch (aidl_latency_mode) {
237 case IWifiChip::LatencyMode::NORMAL:
238 return legacy_hal::WIFI_LATENCY_MODE_NORMAL;
239 case IWifiChip::LatencyMode::LOW:
240 return legacy_hal::WIFI_LATENCY_MODE_LOW;
241 }
242 CHECK(false);
243}
244
245bool convertLegacyWifiMacInfoToAidl(const legacy_hal::WifiMacInfo& legacy_mac_info,
246 IWifiChipEventCallback::RadioModeInfo* aidl_radio_mode_info) {
247 if (!aidl_radio_mode_info) {
248 return false;
249 }
250 *aidl_radio_mode_info = {};
251
252 aidl_radio_mode_info->radioId = legacy_mac_info.wlan_mac_id;
253 // Convert from bitmask of bands in the legacy HAL to enum value in
254 // the AIDL interface.
255 if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_6_0_BAND &&
256 legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_5_0_BAND &&
257 legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_2_4_BAND) {
258 aidl_radio_mode_info->bandInfo = WifiBand::BAND_24GHZ_5GHZ_6GHZ;
259 } else if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_6_0_BAND &&
260 legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_5_0_BAND) {
261 aidl_radio_mode_info->bandInfo = WifiBand::BAND_5GHZ_6GHZ;
262 } else if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_6_0_BAND) {
263 aidl_radio_mode_info->bandInfo = WifiBand::BAND_6GHZ;
264 } else if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_2_4_BAND &&
265 legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_5_0_BAND) {
266 aidl_radio_mode_info->bandInfo = WifiBand::BAND_24GHZ_5GHZ;
267 } else if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_2_4_BAND) {
268 aidl_radio_mode_info->bandInfo = WifiBand::BAND_24GHZ;
269 } else if (legacy_mac_info.mac_band & legacy_hal::WLAN_MAC_5_0_BAND) {
270 aidl_radio_mode_info->bandInfo = WifiBand::BAND_5GHZ;
271 } else {
272 aidl_radio_mode_info->bandInfo = WifiBand::BAND_UNSPECIFIED;
273 }
274 std::vector<IWifiChipEventCallback::IfaceInfo> iface_info_vec;
275 for (const auto& legacy_iface_info : legacy_mac_info.iface_infos) {
276 IWifiChipEventCallback::IfaceInfo iface_info;
277 iface_info.name = legacy_iface_info.name;
278 iface_info.channel = legacy_iface_info.channel;
279 iface_info_vec.push_back(iface_info);
280 }
281 aidl_radio_mode_info->ifaceInfos = iface_info_vec;
282 return true;
283}
284
285uint32_t convertAidlWifiBandToLegacyMacBand(WifiBand aidl_band) {
286 switch (aidl_band) {
287 case WifiBand::BAND_24GHZ:
288 return legacy_hal::WLAN_MAC_2_4_BAND;
289 case WifiBand::BAND_5GHZ:
290 case WifiBand::BAND_5GHZ_DFS:
291 case WifiBand::BAND_5GHZ_WITH_DFS:
292 return legacy_hal::WLAN_MAC_5_0_BAND;
293 case WifiBand::BAND_24GHZ_5GHZ:
294 case WifiBand::BAND_24GHZ_5GHZ_WITH_DFS:
295 return (legacy_hal::WLAN_MAC_2_4_BAND | legacy_hal::WLAN_MAC_5_0_BAND);
296 case WifiBand::BAND_6GHZ:
297 return legacy_hal::WLAN_MAC_6_0_BAND;
298 case WifiBand::BAND_5GHZ_6GHZ:
299 return (legacy_hal::WLAN_MAC_5_0_BAND | legacy_hal::WLAN_MAC_6_0_BAND);
300 case WifiBand::BAND_24GHZ_5GHZ_6GHZ:
301 case WifiBand::BAND_24GHZ_5GHZ_WITH_DFS_6GHZ:
302 return (legacy_hal::WLAN_MAC_2_4_BAND | legacy_hal::WLAN_MAC_5_0_BAND |
303 legacy_hal::WLAN_MAC_6_0_BAND);
304 case WifiBand::BAND_60GHZ:
305 return legacy_hal::WLAN_MAC_60_0_BAND;
306 default:
307 return (legacy_hal::WLAN_MAC_2_4_BAND | legacy_hal::WLAN_MAC_5_0_BAND |
308 legacy_hal::WLAN_MAC_6_0_BAND | legacy_hal::WLAN_MAC_60_0_BAND);
309 }
310}
311
312WifiBand convertLegacyMacBandToAidlWifiBand(uint32_t band) {
313 switch (band) {
314 case legacy_hal::WLAN_MAC_2_4_BAND:
315 return WifiBand::BAND_24GHZ;
316 case legacy_hal::WLAN_MAC_5_0_BAND:
317 return WifiBand::BAND_5GHZ;
318 case legacy_hal::WLAN_MAC_6_0_BAND:
319 return WifiBand::BAND_6GHZ;
320 case legacy_hal::WLAN_MAC_60_0_BAND:
321 return WifiBand::BAND_60GHZ;
322 default:
323 return WifiBand::BAND_UNSPECIFIED;
324 }
325}
326
327uint32_t convertAidlWifiIfaceModeToLegacy(uint32_t aidl_iface_mask) {
328 uint32_t legacy_iface_mask = 0;
329 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_STA)) {
330 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_STA);
331 }
332 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_SOFTAP)) {
333 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_SOFTAP);
334 }
335 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_P2P_CLIENT)) {
336 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_P2P_CLIENT);
337 }
338 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_P2P_GO)) {
339 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_P2P_GO);
340 }
341 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_NAN)) {
342 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_NAN);
343 }
344 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_TDLS)) {
345 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_TDLS);
346 }
347 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_MESH)) {
348 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_MESH);
349 }
350 if (aidl_iface_mask & static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_IBSS)) {
351 legacy_iface_mask |= (1 << legacy_hal::WIFI_INTERFACE_IBSS);
352 }
353 return legacy_iface_mask;
354}
355
356uint32_t convertLegacyWifiInterfaceModeToAidl(uint32_t legacy_iface_mask) {
357 uint32_t aidl_iface_mask = 0;
358 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_STA)) {
359 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_STA);
360 }
361 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_SOFTAP)) {
362 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_SOFTAP);
363 }
364 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_P2P_CLIENT)) {
365 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_P2P_CLIENT);
366 }
367 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_P2P_GO)) {
368 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_P2P_GO);
369 }
370 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_NAN)) {
371 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_NAN);
372 }
373 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_TDLS)) {
374 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_TDLS);
375 }
376 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_MESH)) {
377 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_MESH);
378 }
379 if (legacy_iface_mask & (1 << legacy_hal::WIFI_INTERFACE_IBSS)) {
380 aidl_iface_mask |= static_cast<int32_t>(WifiIfaceMode::IFACE_MODE_IBSS);
381 }
382 return aidl_iface_mask;
383}
384
385uint32_t convertAidlUsableChannelFilterToLegacy(uint32_t aidl_filter_mask) {
386 uint32_t legacy_filter_mask = 0;
387 if (aidl_filter_mask &
388 static_cast<int32_t>(IWifiChip::UsableChannelFilter::CELLULAR_COEXISTENCE)) {
389 legacy_filter_mask |= legacy_hal::WIFI_USABLE_CHANNEL_FILTER_CELLULAR_COEXISTENCE;
390 }
391 if (aidl_filter_mask & static_cast<int32_t>(IWifiChip::UsableChannelFilter::CONCURRENCY)) {
392 legacy_filter_mask |= legacy_hal::WIFI_USABLE_CHANNEL_FILTER_CONCURRENCY;
393 }
394 if (aidl_filter_mask & static_cast<int32_t>(IWifiChip::UsableChannelFilter::NAN_INSTANT_MODE)) {
395 legacy_filter_mask |= WIFI_USABLE_CHANNEL_FILTER_NAN_INSTANT_MODE;
396 }
397 return legacy_filter_mask;
398}
399
400bool convertLegacyWifiUsableChannelToAidl(
401 const legacy_hal::wifi_usable_channel& legacy_usable_channel,
402 WifiUsableChannel* aidl_usable_channel) {
403 if (!aidl_usable_channel) {
404 return false;
405 }
406 *aidl_usable_channel = {};
407 aidl_usable_channel->channel = legacy_usable_channel.freq;
408 aidl_usable_channel->channelBandwidth =
409 convertLegacyWifiChannelWidthToAidl(legacy_usable_channel.width);
Gabriel Biren3b86a782023-02-04 00:42:53 +0000410 aidl_usable_channel->ifaceModeMask =
411 convertLegacyWifiInterfaceModeToAidl(legacy_usable_channel.iface_mode_mask);
Gabriel Birenf3262f92022-07-15 23:25:39 +0000412
413 return true;
414}
415
416bool convertLegacyWifiUsableChannelsToAidl(
417 const std::vector<legacy_hal::wifi_usable_channel>& legacy_usable_channels,
418 std::vector<WifiUsableChannel>* aidl_usable_channels) {
419 if (!aidl_usable_channels) {
420 return false;
421 }
422 *aidl_usable_channels = {};
423 for (const auto& legacy_usable_channel : legacy_usable_channels) {
424 WifiUsableChannel aidl_usable_channel;
425 if (!convertLegacyWifiUsableChannelToAidl(legacy_usable_channel, &aidl_usable_channel)) {
426 return false;
427 }
428 aidl_usable_channels->push_back(aidl_usable_channel);
429 }
430 return true;
431}
432
433bool convertLegacyWifiMacInfosToAidl(
434 const std::vector<legacy_hal::WifiMacInfo>& legacy_mac_infos,
435 std::vector<IWifiChipEventCallback::RadioModeInfo>* aidl_radio_mode_infos) {
436 if (!aidl_radio_mode_infos) {
437 return false;
438 }
439 *aidl_radio_mode_infos = {};
440
441 for (const auto& legacy_mac_info : legacy_mac_infos) {
442 IWifiChipEventCallback::RadioModeInfo aidl_radio_mode_info;
443 if (!convertLegacyWifiMacInfoToAidl(legacy_mac_info, &aidl_radio_mode_info)) {
444 return false;
445 }
446 aidl_radio_mode_infos->push_back(aidl_radio_mode_info);
447 }
448 return true;
449}
450
Gabriel Biren2f862492023-03-09 19:13:07 +0000451bool convertLegacyStaIfaceFeaturesToAidl(uint64_t legacy_feature_set, uint32_t* aidl_feature_set) {
452 if (!aidl_feature_set) {
Gabriel Birenf3262f92022-07-15 23:25:39 +0000453 return false;
454 }
Gabriel Biren2f862492023-03-09 19:13:07 +0000455 *aidl_feature_set = 0;
Gabriel Birenf3262f92022-07-15 23:25:39 +0000456 for (const auto feature :
457 {WIFI_FEATURE_GSCAN, WIFI_FEATURE_LINK_LAYER_STATS, WIFI_FEATURE_RSSI_MONITOR,
458 WIFI_FEATURE_CONTROL_ROAMING, WIFI_FEATURE_IE_WHITELIST, WIFI_FEATURE_SCAN_RAND,
459 WIFI_FEATURE_INFRA_5G, WIFI_FEATURE_HOTSPOT, WIFI_FEATURE_PNO, WIFI_FEATURE_TDLS,
460 WIFI_FEATURE_TDLS_OFFCHANNEL, WIFI_FEATURE_CONFIG_NDO, WIFI_FEATURE_MKEEP_ALIVE}) {
461 if (feature & legacy_feature_set) {
Gabriel Biren2f862492023-03-09 19:13:07 +0000462 *aidl_feature_set |= static_cast<uint32_t>(convertLegacyStaIfaceFeatureToAidl(feature));
Gabriel Birenf3262f92022-07-15 23:25:39 +0000463 }
464 }
465 // There is no flag for this one in the legacy feature set. Adding it to the
466 // set because all the current devices support it.
Gabriel Biren2f862492023-03-09 19:13:07 +0000467 *aidl_feature_set |= static_cast<uint32_t>(IWifiStaIface::FeatureSetMask::APF);
Gabriel Birenf3262f92022-07-15 23:25:39 +0000468 return true;
469}
470
471bool convertLegacyApfCapabilitiesToAidl(const legacy_hal::PacketFilterCapabilities& legacy_caps,
472 StaApfPacketFilterCapabilities* aidl_caps) {
473 if (!aidl_caps) {
474 return false;
475 }
476 *aidl_caps = {};
477 aidl_caps->version = legacy_caps.version;
478 aidl_caps->maxLength = legacy_caps.max_len;
479 return true;
480}
481
482uint8_t convertAidlGscanReportEventFlagToLegacy(
483 StaBackgroundScanBucketEventReportSchemeMask aidl_flag) {
484 using AidlFlag = StaBackgroundScanBucketEventReportSchemeMask;
485 switch (aidl_flag) {
486 case AidlFlag::EACH_SCAN:
487 return REPORT_EVENTS_EACH_SCAN;
488 case AidlFlag::FULL_RESULTS:
489 return REPORT_EVENTS_FULL_RESULTS;
490 case AidlFlag::NO_BATCH:
491 return REPORT_EVENTS_NO_BATCH;
492 };
493 CHECK(false);
494}
495
496StaScanDataFlagMask convertLegacyGscanDataFlagToAidl(uint8_t legacy_flag) {
497 switch (legacy_flag) {
498 case legacy_hal::WIFI_SCAN_FLAG_INTERRUPTED:
499 return StaScanDataFlagMask::INTERRUPTED;
500 };
501 CHECK(false) << "Unknown legacy flag: " << legacy_flag;
502 // To silence the compiler warning about reaching the end of non-void
503 // function.
504 return {};
505}
506
507bool convertLegacyGscanCapabilitiesToAidl(const legacy_hal::wifi_gscan_capabilities& legacy_caps,
508 StaBackgroundScanCapabilities* aidl_caps) {
509 if (!aidl_caps) {
510 return false;
511 }
512 *aidl_caps = {};
513 aidl_caps->maxCacheSize = legacy_caps.max_scan_cache_size;
514 aidl_caps->maxBuckets = legacy_caps.max_scan_buckets;
515 aidl_caps->maxApCachePerScan = legacy_caps.max_ap_cache_per_scan;
516 aidl_caps->maxReportingThreshold = legacy_caps.max_scan_reporting_threshold;
517 return true;
518}
519
520legacy_hal::wifi_band convertAidlWifiBandToLegacy(WifiBand band) {
521 switch (band) {
522 case WifiBand::BAND_UNSPECIFIED:
523 return legacy_hal::WIFI_BAND_UNSPECIFIED;
524 case WifiBand::BAND_24GHZ:
525 return legacy_hal::WIFI_BAND_BG;
526 case WifiBand::BAND_5GHZ:
527 return legacy_hal::WIFI_BAND_A;
528 case WifiBand::BAND_5GHZ_DFS:
529 return legacy_hal::WIFI_BAND_A_DFS;
530 case WifiBand::BAND_5GHZ_WITH_DFS:
531 return legacy_hal::WIFI_BAND_A_WITH_DFS;
532 case WifiBand::BAND_24GHZ_5GHZ:
533 return legacy_hal::WIFI_BAND_ABG;
534 case WifiBand::BAND_24GHZ_5GHZ_WITH_DFS:
535 return legacy_hal::WIFI_BAND_ABG_WITH_DFS;
536 default:
537 CHECK(false);
538 return {};
539 };
540}
541
542bool convertAidlGscanParamsToLegacy(const StaBackgroundScanParameters& aidl_scan_params,
543 legacy_hal::wifi_scan_cmd_params* legacy_scan_params) {
544 if (!legacy_scan_params) {
545 return false;
546 }
547 *legacy_scan_params = {};
548 legacy_scan_params->base_period = aidl_scan_params.basePeriodInMs;
549 legacy_scan_params->max_ap_per_scan = aidl_scan_params.maxApPerScan;
550 legacy_scan_params->report_threshold_percent = aidl_scan_params.reportThresholdPercent;
551 legacy_scan_params->report_threshold_num_scans = aidl_scan_params.reportThresholdNumScans;
552 if (aidl_scan_params.buckets.size() > MAX_BUCKETS) {
553 return false;
554 }
555 legacy_scan_params->num_buckets = aidl_scan_params.buckets.size();
556 for (uint32_t bucket_idx = 0; bucket_idx < aidl_scan_params.buckets.size(); bucket_idx++) {
557 const StaBackgroundScanBucketParameters& aidl_bucket_spec =
558 aidl_scan_params.buckets[bucket_idx];
559 legacy_hal::wifi_scan_bucket_spec& legacy_bucket_spec =
560 legacy_scan_params->buckets[bucket_idx];
561 if (aidl_bucket_spec.bucketIdx >= MAX_BUCKETS) {
562 return false;
563 }
564 legacy_bucket_spec.bucket = aidl_bucket_spec.bucketIdx;
565 legacy_bucket_spec.band = convertAidlWifiBandToLegacy(aidl_bucket_spec.band);
566 legacy_bucket_spec.period = aidl_bucket_spec.periodInMs;
567 legacy_bucket_spec.max_period = aidl_bucket_spec.exponentialMaxPeriodInMs;
568 legacy_bucket_spec.base = aidl_bucket_spec.exponentialBase;
569 legacy_bucket_spec.step_count = aidl_bucket_spec.exponentialStepCount;
570 legacy_bucket_spec.report_events = 0;
571 using AidlFlag = StaBackgroundScanBucketEventReportSchemeMask;
572 for (const auto flag : {AidlFlag::EACH_SCAN, AidlFlag::FULL_RESULTS, AidlFlag::NO_BATCH}) {
Gabriel Biren3b86a782023-02-04 00:42:53 +0000573 if (aidl_bucket_spec.eventReportScheme &
Gabriel Birenf3262f92022-07-15 23:25:39 +0000574 static_cast<std::underlying_type<AidlFlag>::type>(flag)) {
575 legacy_bucket_spec.report_events |= convertAidlGscanReportEventFlagToLegacy(flag);
576 }
577 }
578 if (aidl_bucket_spec.frequencies.size() > MAX_CHANNELS) {
579 return false;
580 }
581 legacy_bucket_spec.num_channels = aidl_bucket_spec.frequencies.size();
582 for (uint32_t freq_idx = 0; freq_idx < aidl_bucket_spec.frequencies.size(); freq_idx++) {
583 legacy_bucket_spec.channels[freq_idx].channel = aidl_bucket_spec.frequencies[freq_idx];
584 }
585 }
586 return true;
587}
588
589bool convertLegacyIeToAidl(const legacy_hal::wifi_information_element& legacy_ie,
590 WifiInformationElement* aidl_ie) {
591 if (!aidl_ie) {
592 return false;
593 }
594 *aidl_ie = {};
595 aidl_ie->id = legacy_ie.id;
596 aidl_ie->data = std::vector<uint8_t>(legacy_ie.data, legacy_ie.data + legacy_ie.len);
597 return true;
598}
599
600bool convertLegacyIeBlobToAidl(const uint8_t* ie_blob, uint32_t ie_blob_len,
601 std::vector<WifiInformationElement>* aidl_ies) {
602 if (!ie_blob || !aidl_ies) {
603 return false;
604 }
605 *aidl_ies = {};
606 const uint8_t* ies_begin = ie_blob;
607 const uint8_t* ies_end = ie_blob + ie_blob_len;
608 const uint8_t* next_ie = ies_begin;
609 using wifi_ie = legacy_hal::wifi_information_element;
610 constexpr size_t kIeHeaderLen = sizeof(wifi_ie);
611 // Each IE should at least have the header (i.e |id| & |len| fields).
612 while (next_ie + kIeHeaderLen <= ies_end) {
613 const wifi_ie& legacy_ie = (*reinterpret_cast<const wifi_ie*>(next_ie));
614 uint32_t curr_ie_len = kIeHeaderLen + legacy_ie.len;
615 if (next_ie + curr_ie_len > ies_end) {
616 LOG(ERROR) << "Error parsing IE blob. Next IE: " << (void*)next_ie
617 << ", Curr IE len: " << curr_ie_len << ", IEs End: " << (void*)ies_end;
618 break;
619 }
620 WifiInformationElement aidl_ie;
621 if (!convertLegacyIeToAidl(legacy_ie, &aidl_ie)) {
622 LOG(ERROR) << "Error converting IE. Id: " << legacy_ie.id << ", len: " << legacy_ie.len;
623 break;
624 }
625 aidl_ies->push_back(std::move(aidl_ie));
626 next_ie += curr_ie_len;
627 }
628 // Check if the blob has been fully consumed.
629 if (next_ie != ies_end) {
630 LOG(ERROR) << "Failed to fully parse IE blob. Next IE: " << (void*)next_ie
631 << ", IEs End: " << (void*)ies_end;
632 }
633 return true;
634}
635
636bool convertLegacyGscanResultToAidl(const legacy_hal::wifi_scan_result& legacy_scan_result,
637 bool has_ie_data, StaScanResult* aidl_scan_result) {
638 if (!aidl_scan_result) {
639 return false;
640 }
641 *aidl_scan_result = {};
642 aidl_scan_result->timeStampInUs = legacy_scan_result.ts;
643 aidl_scan_result->ssid = std::vector<uint8_t>(
644 legacy_scan_result.ssid,
645 legacy_scan_result.ssid +
646 strnlen(legacy_scan_result.ssid, sizeof(legacy_scan_result.ssid) - 1));
647 aidl_scan_result->bssid = std::array<uint8_t, 6>();
648 std::copy(legacy_scan_result.bssid, legacy_scan_result.bssid + 6,
649 std::begin(aidl_scan_result->bssid));
650 aidl_scan_result->frequency = legacy_scan_result.channel;
651 aidl_scan_result->rssi = legacy_scan_result.rssi;
652 aidl_scan_result->beaconPeriodInMs = legacy_scan_result.beacon_period;
653 aidl_scan_result->capability = legacy_scan_result.capability;
654 if (has_ie_data) {
655 std::vector<WifiInformationElement> ies;
656 if (!convertLegacyIeBlobToAidl(reinterpret_cast<const uint8_t*>(legacy_scan_result.ie_data),
657 legacy_scan_result.ie_length, &ies)) {
658 return false;
659 }
660 aidl_scan_result->informationElements = std::move(ies);
661 }
662 return true;
663}
664
665bool convertLegacyCachedGscanResultsToAidl(
666 const legacy_hal::wifi_cached_scan_results& legacy_cached_scan_result,
667 StaScanData* aidl_scan_data) {
668 if (!aidl_scan_data) {
669 return false;
670 }
671 *aidl_scan_data = {};
672 int32_t flags = 0;
673 for (const auto flag : {legacy_hal::WIFI_SCAN_FLAG_INTERRUPTED}) {
674 if (legacy_cached_scan_result.flags & flag) {
675 flags |= static_cast<std::underlying_type<StaScanDataFlagMask>::type>(
676 convertLegacyGscanDataFlagToAidl(flag));
677 }
678 }
Gabriel Biren3b86a782023-02-04 00:42:53 +0000679 aidl_scan_data->flags = flags;
Gabriel Birenf3262f92022-07-15 23:25:39 +0000680 aidl_scan_data->bucketsScanned = legacy_cached_scan_result.buckets_scanned;
681
682 CHECK(legacy_cached_scan_result.num_results >= 0 &&
683 legacy_cached_scan_result.num_results <= MAX_AP_CACHE_PER_SCAN);
684 std::vector<StaScanResult> aidl_scan_results;
685 for (int32_t result_idx = 0; result_idx < legacy_cached_scan_result.num_results; result_idx++) {
686 StaScanResult aidl_scan_result;
687 if (!convertLegacyGscanResultToAidl(legacy_cached_scan_result.results[result_idx], false,
688 &aidl_scan_result)) {
689 return false;
690 }
691 aidl_scan_results.push_back(aidl_scan_result);
692 }
693 aidl_scan_data->results = std::move(aidl_scan_results);
694 return true;
695}
696
697bool convertLegacyVectorOfCachedGscanResultsToAidl(
698 const std::vector<legacy_hal::wifi_cached_scan_results>& legacy_cached_scan_results,
699 std::vector<StaScanData>* aidl_scan_datas) {
700 if (!aidl_scan_datas) {
701 return false;
702 }
703 *aidl_scan_datas = {};
704 for (const auto& legacy_cached_scan_result : legacy_cached_scan_results) {
705 StaScanData aidl_scan_data;
706 if (!convertLegacyCachedGscanResultsToAidl(legacy_cached_scan_result, &aidl_scan_data)) {
707 return false;
708 }
709 aidl_scan_datas->push_back(aidl_scan_data);
710 }
711 return true;
712}
713
714WifiDebugTxPacketFate convertLegacyDebugTxPacketFateToAidl(legacy_hal::wifi_tx_packet_fate fate) {
715 switch (fate) {
716 case legacy_hal::TX_PKT_FATE_ACKED:
717 return WifiDebugTxPacketFate::ACKED;
718 case legacy_hal::TX_PKT_FATE_SENT:
719 return WifiDebugTxPacketFate::SENT;
720 case legacy_hal::TX_PKT_FATE_FW_QUEUED:
721 return WifiDebugTxPacketFate::FW_QUEUED;
722 case legacy_hal::TX_PKT_FATE_FW_DROP_INVALID:
723 return WifiDebugTxPacketFate::FW_DROP_INVALID;
724 case legacy_hal::TX_PKT_FATE_FW_DROP_NOBUFS:
725 return WifiDebugTxPacketFate::FW_DROP_NOBUFS;
726 case legacy_hal::TX_PKT_FATE_FW_DROP_OTHER:
727 return WifiDebugTxPacketFate::FW_DROP_OTHER;
728 case legacy_hal::TX_PKT_FATE_DRV_QUEUED:
729 return WifiDebugTxPacketFate::DRV_QUEUED;
730 case legacy_hal::TX_PKT_FATE_DRV_DROP_INVALID:
731 return WifiDebugTxPacketFate::DRV_DROP_INVALID;
732 case legacy_hal::TX_PKT_FATE_DRV_DROP_NOBUFS:
733 return WifiDebugTxPacketFate::DRV_DROP_NOBUFS;
734 case legacy_hal::TX_PKT_FATE_DRV_DROP_OTHER:
735 return WifiDebugTxPacketFate::DRV_DROP_OTHER;
736 };
737 CHECK(false) << "Unknown legacy fate type: " << fate;
738}
739
740WifiDebugRxPacketFate convertLegacyDebugRxPacketFateToAidl(legacy_hal::wifi_rx_packet_fate fate) {
741 switch (fate) {
742 case legacy_hal::RX_PKT_FATE_SUCCESS:
743 return WifiDebugRxPacketFate::SUCCESS;
744 case legacy_hal::RX_PKT_FATE_FW_QUEUED:
745 return WifiDebugRxPacketFate::FW_QUEUED;
746 case legacy_hal::RX_PKT_FATE_FW_DROP_FILTER:
747 return WifiDebugRxPacketFate::FW_DROP_FILTER;
748 case legacy_hal::RX_PKT_FATE_FW_DROP_INVALID:
749 return WifiDebugRxPacketFate::FW_DROP_INVALID;
750 case legacy_hal::RX_PKT_FATE_FW_DROP_NOBUFS:
751 return WifiDebugRxPacketFate::FW_DROP_NOBUFS;
752 case legacy_hal::RX_PKT_FATE_FW_DROP_OTHER:
753 return WifiDebugRxPacketFate::FW_DROP_OTHER;
754 case legacy_hal::RX_PKT_FATE_DRV_QUEUED:
755 return WifiDebugRxPacketFate::DRV_QUEUED;
756 case legacy_hal::RX_PKT_FATE_DRV_DROP_FILTER:
757 return WifiDebugRxPacketFate::DRV_DROP_FILTER;
758 case legacy_hal::RX_PKT_FATE_DRV_DROP_INVALID:
759 return WifiDebugRxPacketFate::DRV_DROP_INVALID;
760 case legacy_hal::RX_PKT_FATE_DRV_DROP_NOBUFS:
761 return WifiDebugRxPacketFate::DRV_DROP_NOBUFS;
762 case legacy_hal::RX_PKT_FATE_DRV_DROP_OTHER:
763 return WifiDebugRxPacketFate::DRV_DROP_OTHER;
764 };
765 CHECK(false) << "Unknown legacy fate type: " << fate;
766}
767
768WifiDebugPacketFateFrameType convertLegacyDebugPacketFateFrameTypeToAidl(
769 legacy_hal::frame_type type) {
770 switch (type) {
771 case legacy_hal::FRAME_TYPE_UNKNOWN:
772 return WifiDebugPacketFateFrameType::UNKNOWN;
773 case legacy_hal::FRAME_TYPE_ETHERNET_II:
774 return WifiDebugPacketFateFrameType::ETHERNET_II;
775 case legacy_hal::FRAME_TYPE_80211_MGMT:
776 return WifiDebugPacketFateFrameType::MGMT_80211;
777 };
778 CHECK(false) << "Unknown legacy frame type: " << type;
779}
780
781bool convertLegacyDebugPacketFateFrameToAidl(const legacy_hal::frame_info& legacy_frame,
782 WifiDebugPacketFateFrameInfo* aidl_frame) {
783 if (!aidl_frame) {
784 return false;
785 }
786 *aidl_frame = {};
787 aidl_frame->frameType = convertLegacyDebugPacketFateFrameTypeToAidl(legacy_frame.payload_type);
788 aidl_frame->frameLen = legacy_frame.frame_len;
789 aidl_frame->driverTimestampUsec = legacy_frame.driver_timestamp_usec;
790 aidl_frame->firmwareTimestampUsec = legacy_frame.firmware_timestamp_usec;
791 const uint8_t* frame_begin =
792 reinterpret_cast<const uint8_t*>(legacy_frame.frame_content.ethernet_ii_bytes);
793 aidl_frame->frameContent =
794 std::vector<uint8_t>(frame_begin, frame_begin + legacy_frame.frame_len);
795 return true;
796}
797
798bool convertLegacyDebugTxPacketFateToAidl(const legacy_hal::wifi_tx_report& legacy_fate,
799 WifiDebugTxPacketFateReport* aidl_fate) {
800 if (!aidl_fate) {
801 return false;
802 }
803 *aidl_fate = {};
804 aidl_fate->fate = convertLegacyDebugTxPacketFateToAidl(legacy_fate.fate);
805 return convertLegacyDebugPacketFateFrameToAidl(legacy_fate.frame_inf, &aidl_fate->frameInfo);
806}
807
808bool convertLegacyVectorOfDebugTxPacketFateToAidl(
809 const std::vector<legacy_hal::wifi_tx_report>& legacy_fates,
810 std::vector<WifiDebugTxPacketFateReport>* aidl_fates) {
811 if (!aidl_fates) {
812 return false;
813 }
814 *aidl_fates = {};
815 for (const auto& legacy_fate : legacy_fates) {
816 WifiDebugTxPacketFateReport aidl_fate;
817 if (!convertLegacyDebugTxPacketFateToAidl(legacy_fate, &aidl_fate)) {
818 return false;
819 }
820 aidl_fates->push_back(aidl_fate);
821 }
822 return true;
823}
824
825bool convertLegacyDebugRxPacketFateToAidl(const legacy_hal::wifi_rx_report& legacy_fate,
826 WifiDebugRxPacketFateReport* aidl_fate) {
827 if (!aidl_fate) {
828 return false;
829 }
830 *aidl_fate = {};
831 aidl_fate->fate = convertLegacyDebugRxPacketFateToAidl(legacy_fate.fate);
832 return convertLegacyDebugPacketFateFrameToAidl(legacy_fate.frame_inf, &aidl_fate->frameInfo);
833}
834
835bool convertLegacyVectorOfDebugRxPacketFateToAidl(
836 const std::vector<legacy_hal::wifi_rx_report>& legacy_fates,
837 std::vector<WifiDebugRxPacketFateReport>* aidl_fates) {
838 if (!aidl_fates) {
839 return false;
840 }
841 *aidl_fates = {};
842 for (const auto& legacy_fate : legacy_fates) {
843 WifiDebugRxPacketFateReport aidl_fate;
844 if (!convertLegacyDebugRxPacketFateToAidl(legacy_fate, &aidl_fate)) {
845 return false;
846 }
847 aidl_fates->push_back(aidl_fate);
848 }
849 return true;
850}
851
852bool convertLegacyLinkLayerRadioStatsToAidl(
853 const legacy_hal::LinkLayerRadioStats& legacy_radio_stat,
854 StaLinkLayerRadioStats* aidl_radio_stat) {
855 if (!aidl_radio_stat) {
856 return false;
857 }
858 *aidl_radio_stat = {};
859
860 aidl_radio_stat->radioId = legacy_radio_stat.stats.radio;
861 aidl_radio_stat->onTimeInMs = legacy_radio_stat.stats.on_time;
862 aidl_radio_stat->txTimeInMs = legacy_radio_stat.stats.tx_time;
863 aidl_radio_stat->rxTimeInMs = legacy_radio_stat.stats.rx_time;
864 aidl_radio_stat->onTimeInMsForScan = legacy_radio_stat.stats.on_time_scan;
865 aidl_radio_stat->txTimeInMsPerLevel = uintToIntVec(legacy_radio_stat.tx_time_per_levels);
866 aidl_radio_stat->onTimeInMsForNanScan = legacy_radio_stat.stats.on_time_nbd;
867 aidl_radio_stat->onTimeInMsForBgScan = legacy_radio_stat.stats.on_time_gscan;
868 aidl_radio_stat->onTimeInMsForRoamScan = legacy_radio_stat.stats.on_time_roam_scan;
869 aidl_radio_stat->onTimeInMsForPnoScan = legacy_radio_stat.stats.on_time_pno_scan;
870 aidl_radio_stat->onTimeInMsForHs20Scan = legacy_radio_stat.stats.on_time_hs20;
871
872 std::vector<WifiChannelStats> aidl_channel_stats;
873
874 for (const auto& channel_stat : legacy_radio_stat.channel_stats) {
875 WifiChannelStats aidl_channel_stat;
876 aidl_channel_stat.onTimeInMs = channel_stat.on_time;
877 aidl_channel_stat.ccaBusyTimeInMs = channel_stat.cca_busy_time;
878 aidl_channel_stat.channel.width = WifiChannelWidthInMhz::WIDTH_20;
879 aidl_channel_stat.channel.centerFreq = channel_stat.channel.center_freq;
880 aidl_channel_stat.channel.centerFreq0 = channel_stat.channel.center_freq0;
881 aidl_channel_stat.channel.centerFreq1 = channel_stat.channel.center_freq1;
882 aidl_channel_stats.push_back(aidl_channel_stat);
883 }
884
885 aidl_radio_stat->channelStats = aidl_channel_stats;
886
887 return true;
888}
889
Mahesh KKV5f30d332022-10-26 14:07:44 -0700890bool convertLegacyLinkLayerMlStatsToAidl(const legacy_hal::LinkLayerMlStats& legacy_ml_stats,
891 StaLinkLayerStats* aidl_stats) {
892 if (!aidl_stats) {
893 return false;
894 }
895 *aidl_stats = {};
896 std::vector<StaLinkLayerLinkStats> links;
897 // Iterate over each links
898 for (const auto& link : legacy_ml_stats.links) {
899 StaLinkLayerLinkStats linkStats = {};
900 linkStats.linkId = link.stat.link_id;
Mahesh KKV0da29972022-12-06 21:11:50 -0800901 linkStats.radioId = link.stat.radio;
902 linkStats.frequencyMhz = link.stat.frequency;
Mahesh KKV5f30d332022-10-26 14:07:44 -0700903 linkStats.beaconRx = link.stat.beacon_rx;
904 linkStats.avgRssiMgmt = link.stat.rssi_mgmt;
905 linkStats.wmeBePktStats.rxMpdu = link.stat.ac[legacy_hal::WIFI_AC_BE].rx_mpdu;
906 linkStats.wmeBePktStats.txMpdu = link.stat.ac[legacy_hal::WIFI_AC_BE].tx_mpdu;
907 linkStats.wmeBePktStats.lostMpdu = link.stat.ac[legacy_hal::WIFI_AC_BE].mpdu_lost;
908 linkStats.wmeBePktStats.retries = link.stat.ac[legacy_hal::WIFI_AC_BE].retries;
909 linkStats.wmeBeContentionTimeStats.contentionTimeMinInUsec =
910 link.stat.ac[legacy_hal::WIFI_AC_BE].contention_time_min;
911 linkStats.wmeBeContentionTimeStats.contentionTimeMaxInUsec =
912 link.stat.ac[legacy_hal::WIFI_AC_BE].contention_time_max;
913 linkStats.wmeBeContentionTimeStats.contentionTimeAvgInUsec =
914 link.stat.ac[legacy_hal::WIFI_AC_BE].contention_time_avg;
915 linkStats.wmeBeContentionTimeStats.contentionNumSamples =
916 link.stat.ac[legacy_hal::WIFI_AC_BE].contention_num_samples;
917 linkStats.wmeBkPktStats.rxMpdu = link.stat.ac[legacy_hal::WIFI_AC_BK].rx_mpdu;
918 linkStats.wmeBkPktStats.txMpdu = link.stat.ac[legacy_hal::WIFI_AC_BK].tx_mpdu;
919 linkStats.wmeBkPktStats.lostMpdu = link.stat.ac[legacy_hal::WIFI_AC_BK].mpdu_lost;
920 linkStats.wmeBkPktStats.retries = link.stat.ac[legacy_hal::WIFI_AC_BK].retries;
921 linkStats.wmeBkContentionTimeStats.contentionTimeMinInUsec =
922 link.stat.ac[legacy_hal::WIFI_AC_BK].contention_time_min;
923 linkStats.wmeBkContentionTimeStats.contentionTimeMaxInUsec =
924 link.stat.ac[legacy_hal::WIFI_AC_BK].contention_time_max;
925 linkStats.wmeBkContentionTimeStats.contentionTimeAvgInUsec =
926 link.stat.ac[legacy_hal::WIFI_AC_BK].contention_time_avg;
927 linkStats.wmeBkContentionTimeStats.contentionNumSamples =
928 link.stat.ac[legacy_hal::WIFI_AC_BK].contention_num_samples;
929 linkStats.wmeViPktStats.rxMpdu = link.stat.ac[legacy_hal::WIFI_AC_VI].rx_mpdu;
930 linkStats.wmeViPktStats.txMpdu = link.stat.ac[legacy_hal::WIFI_AC_VI].tx_mpdu;
931 linkStats.wmeViPktStats.lostMpdu = link.stat.ac[legacy_hal::WIFI_AC_VI].mpdu_lost;
932 linkStats.wmeViPktStats.retries = link.stat.ac[legacy_hal::WIFI_AC_VI].retries;
933 linkStats.wmeViContentionTimeStats.contentionTimeMinInUsec =
934 link.stat.ac[legacy_hal::WIFI_AC_VI].contention_time_min;
935 linkStats.wmeViContentionTimeStats.contentionTimeMaxInUsec =
936 link.stat.ac[legacy_hal::WIFI_AC_VI].contention_time_max;
937 linkStats.wmeViContentionTimeStats.contentionTimeAvgInUsec =
938 link.stat.ac[legacy_hal::WIFI_AC_VI].contention_time_avg;
939 linkStats.wmeViContentionTimeStats.contentionNumSamples =
940 link.stat.ac[legacy_hal::WIFI_AC_VI].contention_num_samples;
941 linkStats.wmeVoPktStats.rxMpdu = link.stat.ac[legacy_hal::WIFI_AC_VO].rx_mpdu;
942 linkStats.wmeVoPktStats.txMpdu = link.stat.ac[legacy_hal::WIFI_AC_VO].tx_mpdu;
943 linkStats.wmeVoPktStats.lostMpdu = link.stat.ac[legacy_hal::WIFI_AC_VO].mpdu_lost;
944 linkStats.wmeVoPktStats.retries = link.stat.ac[legacy_hal::WIFI_AC_VO].retries;
945 linkStats.wmeVoContentionTimeStats.contentionTimeMinInUsec =
946 link.stat.ac[legacy_hal::WIFI_AC_VO].contention_time_min;
947 linkStats.wmeVoContentionTimeStats.contentionTimeMaxInUsec =
948 link.stat.ac[legacy_hal::WIFI_AC_VO].contention_time_max;
949 linkStats.wmeVoContentionTimeStats.contentionTimeAvgInUsec =
950 link.stat.ac[legacy_hal::WIFI_AC_VO].contention_time_avg;
951 linkStats.wmeVoContentionTimeStats.contentionNumSamples =
952 link.stat.ac[legacy_hal::WIFI_AC_VO].contention_num_samples;
953 linkStats.timeSliceDutyCycleInPercent = link.stat.time_slicing_duty_cycle_percent;
954 // peer info legacy_stats conversion.
955 std::vector<StaPeerInfo> aidl_peers_info_stats;
956 for (const auto& legacy_peer_info_stats : link.peers) {
957 StaPeerInfo aidl_peer_info_stats;
958 if (!convertLegacyPeerInfoStatsToAidl(legacy_peer_info_stats, &aidl_peer_info_stats)) {
959 return false;
960 }
961 aidl_peers_info_stats.push_back(aidl_peer_info_stats);
962 }
963 linkStats.peers = aidl_peers_info_stats;
964 // Push link stats to aidl stats.
965 links.push_back(linkStats);
966 }
967 aidl_stats->iface.links = links;
968 // radio legacy_stats conversion.
969 std::vector<StaLinkLayerRadioStats> aidl_radios_stats;
970 for (const auto& legacy_radio_stats : legacy_ml_stats.radios) {
971 StaLinkLayerRadioStats aidl_radio_stats;
972 if (!convertLegacyLinkLayerRadioStatsToAidl(legacy_radio_stats, &aidl_radio_stats)) {
973 return false;
974 }
975 aidl_radios_stats.push_back(aidl_radio_stats);
976 }
977 aidl_stats->radios = aidl_radios_stats;
978 aidl_stats->timeStampInMs = ::android::uptimeMillis();
979
980 return true;
981}
982
Gabriel Birenf3262f92022-07-15 23:25:39 +0000983bool convertLegacyLinkLayerStatsToAidl(const legacy_hal::LinkLayerStats& legacy_stats,
984 StaLinkLayerStats* aidl_stats) {
985 if (!aidl_stats) {
986 return false;
987 }
988 *aidl_stats = {};
Mahesh KKV5f30d332022-10-26 14:07:44 -0700989 std::vector<StaLinkLayerLinkStats> links;
990 StaLinkLayerLinkStats linkStats = {};
Gabriel Birenf3262f92022-07-15 23:25:39 +0000991 // iface legacy_stats conversion.
Mahesh KKV5f30d332022-10-26 14:07:44 -0700992 linkStats.linkId = 0;
993 linkStats.beaconRx = legacy_stats.iface.beacon_rx;
994 linkStats.avgRssiMgmt = legacy_stats.iface.rssi_mgmt;
995 linkStats.wmeBePktStats.rxMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].rx_mpdu;
996 linkStats.wmeBePktStats.txMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].tx_mpdu;
997 linkStats.wmeBePktStats.lostMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].mpdu_lost;
998 linkStats.wmeBePktStats.retries = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].retries;
999 linkStats.wmeBeContentionTimeStats.contentionTimeMinInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001000 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].contention_time_min;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001001 linkStats.wmeBeContentionTimeStats.contentionTimeMaxInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001002 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].contention_time_max;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001003 linkStats.wmeBeContentionTimeStats.contentionTimeAvgInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001004 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].contention_time_avg;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001005 linkStats.wmeBeContentionTimeStats.contentionNumSamples =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001006 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BE].contention_num_samples;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001007 linkStats.wmeBkPktStats.rxMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].rx_mpdu;
1008 linkStats.wmeBkPktStats.txMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].tx_mpdu;
1009 linkStats.wmeBkPktStats.lostMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].mpdu_lost;
1010 linkStats.wmeBkPktStats.retries = legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].retries;
1011 linkStats.wmeBkContentionTimeStats.contentionTimeMinInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001012 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].contention_time_min;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001013 linkStats.wmeBkContentionTimeStats.contentionTimeMaxInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001014 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].contention_time_max;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001015 linkStats.wmeBkContentionTimeStats.contentionTimeAvgInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001016 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].contention_time_avg;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001017 linkStats.wmeBkContentionTimeStats.contentionNumSamples =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001018 legacy_stats.iface.ac[legacy_hal::WIFI_AC_BK].contention_num_samples;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001019 linkStats.wmeViPktStats.rxMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].rx_mpdu;
1020 linkStats.wmeViPktStats.txMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].tx_mpdu;
1021 linkStats.wmeViPktStats.lostMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].mpdu_lost;
1022 linkStats.wmeViPktStats.retries = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].retries;
1023 linkStats.wmeViContentionTimeStats.contentionTimeMinInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001024 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].contention_time_min;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001025 linkStats.wmeViContentionTimeStats.contentionTimeMaxInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001026 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].contention_time_max;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001027 linkStats.wmeViContentionTimeStats.contentionTimeAvgInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001028 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].contention_time_avg;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001029 linkStats.wmeViContentionTimeStats.contentionNumSamples =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001030 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VI].contention_num_samples;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001031 linkStats.wmeVoPktStats.rxMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].rx_mpdu;
1032 linkStats.wmeVoPktStats.txMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].tx_mpdu;
1033 linkStats.wmeVoPktStats.lostMpdu = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].mpdu_lost;
1034 linkStats.wmeVoPktStats.retries = legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].retries;
1035 linkStats.wmeVoContentionTimeStats.contentionTimeMinInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001036 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].contention_time_min;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001037 linkStats.wmeVoContentionTimeStats.contentionTimeMaxInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001038 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].contention_time_max;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001039 linkStats.wmeVoContentionTimeStats.contentionTimeAvgInUsec =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001040 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].contention_time_avg;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001041 linkStats.wmeVoContentionTimeStats.contentionNumSamples =
Gabriel Birenf3262f92022-07-15 23:25:39 +00001042 legacy_stats.iface.ac[legacy_hal::WIFI_AC_VO].contention_num_samples;
Mahesh KKV5f30d332022-10-26 14:07:44 -07001043 linkStats.timeSliceDutyCycleInPercent = legacy_stats.iface.info.time_slicing_duty_cycle_percent;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001044 // peer info legacy_stats conversion.
1045 std::vector<StaPeerInfo> aidl_peers_info_stats;
1046 for (const auto& legacy_peer_info_stats : legacy_stats.peers) {
1047 StaPeerInfo aidl_peer_info_stats;
1048 if (!convertLegacyPeerInfoStatsToAidl(legacy_peer_info_stats, &aidl_peer_info_stats)) {
1049 return false;
1050 }
1051 aidl_peers_info_stats.push_back(aidl_peer_info_stats);
1052 }
Mahesh KKV5f30d332022-10-26 14:07:44 -07001053 linkStats.peers = aidl_peers_info_stats;
1054 links.push_back(linkStats);
1055 aidl_stats->iface.links = links;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001056 // radio legacy_stats conversion.
1057 std::vector<StaLinkLayerRadioStats> aidl_radios_stats;
1058 for (const auto& legacy_radio_stats : legacy_stats.radios) {
1059 StaLinkLayerRadioStats aidl_radio_stats;
1060 if (!convertLegacyLinkLayerRadioStatsToAidl(legacy_radio_stats, &aidl_radio_stats)) {
1061 return false;
1062 }
1063 aidl_radios_stats.push_back(aidl_radio_stats);
1064 }
1065 aidl_stats->radios = aidl_radios_stats;
1066 aidl_stats->timeStampInMs = ::android::uptimeMillis();
1067 return true;
1068}
1069
1070bool convertLegacyPeerInfoStatsToAidl(const legacy_hal::WifiPeerInfo& legacy_peer_info_stats,
1071 StaPeerInfo* aidl_peer_info_stats) {
1072 if (!aidl_peer_info_stats) {
1073 return false;
1074 }
1075 *aidl_peer_info_stats = {};
1076 aidl_peer_info_stats->staCount = legacy_peer_info_stats.peer_info.bssload.sta_count;
1077 aidl_peer_info_stats->chanUtil = legacy_peer_info_stats.peer_info.bssload.chan_util;
1078
1079 std::vector<StaRateStat> aidlRateStats;
1080 for (const auto& legacy_rate_stats : legacy_peer_info_stats.rate_stats) {
1081 StaRateStat rateStat;
1082 if (!convertLegacyWifiRateInfoToAidl(legacy_rate_stats.rate, &rateStat.rateInfo)) {
1083 return false;
1084 }
1085 rateStat.txMpdu = legacy_rate_stats.tx_mpdu;
1086 rateStat.rxMpdu = legacy_rate_stats.rx_mpdu;
1087 rateStat.mpduLost = legacy_rate_stats.mpdu_lost;
1088 rateStat.retries = legacy_rate_stats.retries;
1089 aidlRateStats.push_back(rateStat);
1090 }
1091 aidl_peer_info_stats->rateStats = aidlRateStats;
1092 return true;
1093}
1094
1095bool convertLegacyRoamingCapabilitiesToAidl(
1096 const legacy_hal::wifi_roaming_capabilities& legacy_caps,
1097 StaRoamingCapabilities* aidl_caps) {
1098 if (!aidl_caps) {
1099 return false;
1100 }
1101 *aidl_caps = {};
1102 aidl_caps->maxBlocklistSize = legacy_caps.max_blacklist_size;
1103 aidl_caps->maxAllowlistSize = legacy_caps.max_whitelist_size;
1104 return true;
1105}
1106
1107bool convertAidlRoamingConfigToLegacy(const StaRoamingConfig& aidl_config,
1108 legacy_hal::wifi_roaming_config* legacy_config) {
1109 if (!legacy_config) {
1110 return false;
1111 }
1112 *legacy_config = {};
1113 if (aidl_config.bssidBlocklist.size() > MAX_BLACKLIST_BSSID ||
1114 aidl_config.ssidAllowlist.size() > MAX_WHITELIST_SSID) {
1115 return false;
1116 }
1117 legacy_config->num_blacklist_bssid = aidl_config.bssidBlocklist.size();
1118 uint32_t i = 0;
1119 for (const auto& bssid : aidl_config.bssidBlocklist) {
1120 CHECK(bssid.data.size() == sizeof(legacy_hal::mac_addr));
1121 memcpy(legacy_config->blacklist_bssid[i++], bssid.data.data(), bssid.data.size());
1122 }
1123 legacy_config->num_whitelist_ssid = aidl_config.ssidAllowlist.size();
1124 i = 0;
1125 for (const auto& ssid : aidl_config.ssidAllowlist) {
1126 CHECK(ssid.data.size() <= sizeof(legacy_hal::ssid_t::ssid_str));
1127 legacy_config->whitelist_ssid[i].length = ssid.data.size();
1128 memcpy(legacy_config->whitelist_ssid[i].ssid_str, ssid.data.data(), ssid.data.size());
1129 i++;
1130 }
1131 return true;
1132}
1133
1134legacy_hal::fw_roaming_state_t convertAidlRoamingStateToLegacy(StaRoamingState state) {
1135 switch (state) {
1136 case StaRoamingState::ENABLED:
1137 return legacy_hal::ROAMING_ENABLE;
1138 case StaRoamingState::DISABLED:
1139 return legacy_hal::ROAMING_DISABLE;
1140 };
1141 CHECK(false);
1142}
1143
1144legacy_hal::NanMatchAlg convertAidlNanMatchAlgToLegacy(NanMatchAlg type) {
1145 switch (type) {
1146 case NanMatchAlg::MATCH_ONCE:
1147 return legacy_hal::NAN_MATCH_ALG_MATCH_ONCE;
1148 case NanMatchAlg::MATCH_CONTINUOUS:
1149 return legacy_hal::NAN_MATCH_ALG_MATCH_CONTINUOUS;
1150 case NanMatchAlg::MATCH_NEVER:
1151 return legacy_hal::NAN_MATCH_ALG_MATCH_NEVER;
1152 }
1153 CHECK(false);
1154}
1155
1156legacy_hal::NanPublishType convertAidlNanPublishTypeToLegacy(NanPublishType type) {
1157 switch (type) {
1158 case NanPublishType::UNSOLICITED:
1159 return legacy_hal::NAN_PUBLISH_TYPE_UNSOLICITED;
1160 case NanPublishType::SOLICITED:
1161 return legacy_hal::NAN_PUBLISH_TYPE_SOLICITED;
1162 case NanPublishType::UNSOLICITED_SOLICITED:
1163 return legacy_hal::NAN_PUBLISH_TYPE_UNSOLICITED_SOLICITED;
1164 }
1165 CHECK(false);
1166}
1167
1168legacy_hal::NanTxType convertAidlNanTxTypeToLegacy(NanTxType type) {
1169 switch (type) {
1170 case NanTxType::BROADCAST:
1171 return legacy_hal::NAN_TX_TYPE_BROADCAST;
1172 case NanTxType::UNICAST:
1173 return legacy_hal::NAN_TX_TYPE_UNICAST;
1174 }
1175 CHECK(false);
1176}
1177
1178legacy_hal::NanSubscribeType convertAidlNanSubscribeTypeToLegacy(NanSubscribeType type) {
1179 switch (type) {
1180 case NanSubscribeType::PASSIVE:
1181 return legacy_hal::NAN_SUBSCRIBE_TYPE_PASSIVE;
1182 case NanSubscribeType::ACTIVE:
1183 return legacy_hal::NAN_SUBSCRIBE_TYPE_ACTIVE;
1184 }
1185 CHECK(false);
1186}
1187
1188legacy_hal::NanSRFType convertAidlNanSrfTypeToLegacy(NanSrfType type) {
1189 switch (type) {
1190 case NanSrfType::BLOOM_FILTER:
1191 return legacy_hal::NAN_SRF_ATTR_BLOOM_FILTER;
1192 case NanSrfType::PARTIAL_MAC_ADDR:
1193 return legacy_hal::NAN_SRF_ATTR_PARTIAL_MAC_ADDR;
1194 }
1195 CHECK(false);
1196}
1197
1198legacy_hal::NanDataPathChannelCfg convertAidlNanDataPathChannelCfgToLegacy(
1199 NanDataPathChannelCfg type) {
1200 switch (type) {
1201 case NanDataPathChannelCfg::CHANNEL_NOT_REQUESTED:
1202 return legacy_hal::NAN_DP_CHANNEL_NOT_REQUESTED;
1203 case NanDataPathChannelCfg::REQUEST_CHANNEL_SETUP:
1204 return legacy_hal::NAN_DP_REQUEST_CHANNEL_SETUP;
1205 case NanDataPathChannelCfg::FORCE_CHANNEL_SETUP:
1206 return legacy_hal::NAN_DP_FORCE_CHANNEL_SETUP;
1207 }
1208 CHECK(false);
1209}
1210
Nate Jiang38e8db52022-12-02 17:30:27 -08001211legacy_hal::NanPairingRequestType convertAidlNanPairingRequestTypeToLegacy(
1212 NanPairingRequestType type) {
1213 switch (type) {
1214 case NanPairingRequestType::NAN_PAIRING_SETUP:
1215 return legacy_hal::NAN_PAIRING_SETUP;
1216 case NanPairingRequestType::NAN_PAIRING_VERIFICATION:
1217 return legacy_hal::NAN_PAIRING_VERIFICATION;
1218 }
1219 LOG(FATAL);
1220}
1221
1222NanPairingRequestType convertLegacyNanPairingRequestTypeToAidl(
1223 legacy_hal::NanPairingRequestType type) {
1224 switch (type) {
1225 case legacy_hal::NAN_PAIRING_SETUP:
1226 return NanPairingRequestType::NAN_PAIRING_SETUP;
1227 case legacy_hal::NAN_PAIRING_VERIFICATION:
1228 return NanPairingRequestType::NAN_PAIRING_VERIFICATION;
1229 }
1230 LOG(FATAL);
1231}
1232
Nate Jiangbae6fdd2023-02-10 17:16:40 -08001233legacy_hal::NanAkm convertAidlAkmTypeToLegacy(NanPairingAkm type) {
Nate Jiang38e8db52022-12-02 17:30:27 -08001234 switch (type) {
1235 case NanPairingAkm::SAE:
1236 return legacy_hal::SAE;
1237 case NanPairingAkm::PASN:
1238 return legacy_hal::PASN;
1239 }
1240 LOG(FATAL);
1241}
1242
Nate Jiangbae6fdd2023-02-10 17:16:40 -08001243NanPairingAkm convertLegacyAkmTypeToAidl(legacy_hal::NanAkm type) {
Nate Jiang38e8db52022-12-02 17:30:27 -08001244 switch (type) {
1245 case legacy_hal::SAE:
1246 return NanPairingAkm::SAE;
1247 case legacy_hal::PASN:
1248 return NanPairingAkm::PASN;
1249 }
1250 LOG(FATAL);
1251}
1252
1253uint16_t convertAidlBootstrappingMethodToLegacy(NanBootstrappingMethod type) {
1254 switch (type) {
1255 case NanBootstrappingMethod::BOOTSTRAPPING_OPPORTUNISTIC_MASK:
1256 return NAN_PAIRING_BOOTSTRAPPING_OPPORTUNISTIC_MASK;
1257 case NanBootstrappingMethod::BOOTSTRAPPING_PIN_CODE_DISPLAY_MASK:
1258 return NAN_PAIRING_BOOTSTRAPPING_PIN_CODE_DISPLAY_MASK;
1259 case NanBootstrappingMethod::BOOTSTRAPPING_PASSPHRASE_DISPLAY_MASK:
1260 return NAN_PAIRING_BOOTSTRAPPING_PASSPHRASE_DISPLAY_MASK;
1261 case NanBootstrappingMethod::BOOTSTRAPPING_QR_DISPLAY_MASK:
1262 return NAN_PAIRING_BOOTSTRAPPING_QR_DISPLAY_MASK;
1263 case NanBootstrappingMethod::BOOTSTRAPPING_NFC_TAG_MASK:
1264 return NAN_PAIRING_BOOTSTRAPPING_NFC_TAG_MASK;
1265 case NanBootstrappingMethod::BOOTSTRAPPING_PIN_CODE_KEYPAD_MASK:
1266 return NAN_PAIRING_BOOTSTRAPPING_PIN_CODE_KEYPAD_MASK;
1267 case NanBootstrappingMethod::BOOTSTRAPPING_PASSPHRASE_KEYPAD_MASK:
1268 return NAN_PAIRING_BOOTSTRAPPING_PASSPHRASE_KEYPAD_MASK;
1269 case NanBootstrappingMethod::BOOTSTRAPPING_QR_SCAN_MASK:
1270 return NAN_PAIRING_BOOTSTRAPPING_QR_SCAN_MASK;
1271 case NanBootstrappingMethod::BOOTSTRAPPING_NFC_READER_MASK:
1272 return NAN_PAIRING_BOOTSTRAPPING_NFC_READER_MASK;
1273 case NanBootstrappingMethod::BOOTSTRAPPING_SERVICE_MANAGED_MASK:
1274 return NAN_PAIRING_BOOTSTRAPPING_SERVICE_MANAGED_MASK;
1275 case NanBootstrappingMethod::BOOTSTRAPPING_HANDSHAKE_SHIP_MASK:
1276 return NAN_PAIRING_BOOTSTRAPPING_HANDSHAKE_SHIP_MASK;
1277 }
1278 LOG(FATAL);
1279}
1280
1281NanBootstrappingMethod convertLegacyBootstrappingMethodToAidl(uint16_t type) {
1282 switch (type) {
1283 case NAN_PAIRING_BOOTSTRAPPING_OPPORTUNISTIC_MASK:
1284 return NanBootstrappingMethod::BOOTSTRAPPING_OPPORTUNISTIC_MASK;
1285 case NAN_PAIRING_BOOTSTRAPPING_PIN_CODE_DISPLAY_MASK:
1286 return NanBootstrappingMethod::BOOTSTRAPPING_PIN_CODE_DISPLAY_MASK;
1287 case NAN_PAIRING_BOOTSTRAPPING_PASSPHRASE_DISPLAY_MASK:
1288 return NanBootstrappingMethod::BOOTSTRAPPING_PASSPHRASE_DISPLAY_MASK;
1289 case NAN_PAIRING_BOOTSTRAPPING_QR_DISPLAY_MASK:
1290 return NanBootstrappingMethod::BOOTSTRAPPING_QR_DISPLAY_MASK;
1291 case NAN_PAIRING_BOOTSTRAPPING_NFC_TAG_MASK:
1292 return NanBootstrappingMethod::BOOTSTRAPPING_NFC_TAG_MASK;
1293 case NAN_PAIRING_BOOTSTRAPPING_PIN_CODE_KEYPAD_MASK:
1294 return NanBootstrappingMethod::BOOTSTRAPPING_PIN_CODE_KEYPAD_MASK;
1295 case NAN_PAIRING_BOOTSTRAPPING_PASSPHRASE_KEYPAD_MASK:
1296 return NanBootstrappingMethod::BOOTSTRAPPING_PASSPHRASE_KEYPAD_MASK;
1297 case NAN_PAIRING_BOOTSTRAPPING_QR_SCAN_MASK:
1298 return NanBootstrappingMethod::BOOTSTRAPPING_QR_SCAN_MASK;
1299 case NAN_PAIRING_BOOTSTRAPPING_NFC_READER_MASK:
1300 return NanBootstrappingMethod::BOOTSTRAPPING_NFC_READER_MASK;
1301 case NAN_PAIRING_BOOTSTRAPPING_SERVICE_MANAGED_MASK:
1302 return NanBootstrappingMethod::BOOTSTRAPPING_SERVICE_MANAGED_MASK;
1303 case NAN_PAIRING_BOOTSTRAPPING_HANDSHAKE_SHIP_MASK:
1304 return NanBootstrappingMethod::BOOTSTRAPPING_HANDSHAKE_SHIP_MASK;
1305 }
1306 LOG(FATAL);
1307 return {};
1308}
1309
1310bool covertAidlPairingConfigToLegacy(const NanPairingConfig& aidl_config,
1311 legacy_hal::NanPairingConfig* legacy_config) {
1312 if (!legacy_config) {
1313 LOG(ERROR) << "covertAidlPairingConfigToLegacy: legacy_config is null";
1314 return false;
1315 }
1316 legacy_config->enable_pairing_setup = aidl_config.enablePairingSetup ? 0x1 : 0x0;
1317 legacy_config->enable_pairing_cache = aidl_config.enablePairingCache ? 0x1 : 0x0;
1318 legacy_config->enable_pairing_verification = aidl_config.enablePairingVerification ? 0x1 : 0x0;
1319 legacy_config->supported_bootstrapping_methods = aidl_config.supportedBootstrappingMethods;
1320 return true;
1321}
1322
1323bool convertLegacyPairingConfigToAidl(const legacy_hal::NanPairingConfig& legacy_config,
1324 NanPairingConfig* aidl_config) {
1325 if (!aidl_config) {
1326 LOG(ERROR) << "convertLegacyPairingConfigToAidl: aidl_nira is null";
1327 return false;
1328 }
1329 *aidl_config = {};
1330 aidl_config->enablePairingSetup = legacy_config.enable_pairing_setup == 0x1;
1331 aidl_config->enablePairingCache = legacy_config.enable_pairing_cache == 0x1;
1332 aidl_config->enablePairingVerification = legacy_config.enable_pairing_verification == 0x1;
1333 aidl_config->supportedBootstrappingMethods = legacy_config.supported_bootstrapping_methods;
1334 return true;
1335}
1336
1337bool convertLegacyNiraToAidl(const legacy_hal::NanIdentityResolutionAttribute& legacy_nira,
1338 NanIdentityResolutionAttribute* aidl_nira) {
1339 if (!aidl_nira) {
1340 LOG(ERROR) << "convertLegacyNiraToAidl: aidl_nira is null";
1341 return false;
1342 }
1343 *aidl_nira = {};
1344 aidl_nira->nonce = std::array<uint8_t, 8>();
1345 std::copy(legacy_nira.nonce, legacy_nira.nonce + 8, std::begin(aidl_nira->nonce));
1346 aidl_nira->tag = std::array<uint8_t, 8>();
1347 std::copy(legacy_nira.tag, legacy_nira.tag + 8, std::begin(aidl_nira->tag));
1348 return true;
1349}
1350
1351bool convertLegacyNpsaToAidl(const legacy_hal::NpkSecurityAssociation& legacy_npsa,
1352 NpkSecurityAssociation* aidl_npsa) {
1353 if (!aidl_npsa) {
1354 LOG(ERROR) << "convertLegacyNiraToAidl: aidl_nira is null";
1355 return false;
1356 }
1357 *aidl_npsa = {};
1358 aidl_npsa->peerNanIdentityKey = std::array<uint8_t, 16>();
1359 std::copy(legacy_npsa.peer_nan_identity_key, legacy_npsa.peer_nan_identity_key + 16,
1360 std::begin(aidl_npsa->peerNanIdentityKey));
1361 aidl_npsa->localNanIdentityKey = std::array<uint8_t, 16>();
1362 std::copy(legacy_npsa.local_nan_identity_key, legacy_npsa.local_nan_identity_key + 16,
1363 std::begin(aidl_npsa->localNanIdentityKey));
1364 aidl_npsa->npk = std::array<uint8_t, 32>();
1365 std::copy(legacy_npsa.npk.pmk, legacy_npsa.npk.pmk + 32, std::begin(aidl_npsa->npk));
1366 aidl_npsa->akm = convertLegacyAkmTypeToAidl(legacy_npsa.akm);
Nate Jiangbae6fdd2023-02-10 17:16:40 -08001367 aidl_npsa->cipherType = (NanCipherSuiteType)legacy_npsa.cipher_type;
Nate Jiang38e8db52022-12-02 17:30:27 -08001368 return true;
1369}
1370
Gabriel Birenf3262f92022-07-15 23:25:39 +00001371NanStatusCode convertLegacyNanStatusTypeToAidl(legacy_hal::NanStatusType type) {
1372 switch (type) {
1373 case legacy_hal::NAN_STATUS_SUCCESS:
1374 return NanStatusCode::SUCCESS;
1375 case legacy_hal::NAN_STATUS_INTERNAL_FAILURE:
1376 return NanStatusCode::INTERNAL_FAILURE;
1377 case legacy_hal::NAN_STATUS_PROTOCOL_FAILURE:
1378 return NanStatusCode::PROTOCOL_FAILURE;
1379 case legacy_hal::NAN_STATUS_INVALID_PUBLISH_SUBSCRIBE_ID:
1380 return NanStatusCode::INVALID_SESSION_ID;
1381 case legacy_hal::NAN_STATUS_NO_RESOURCE_AVAILABLE:
1382 return NanStatusCode::NO_RESOURCES_AVAILABLE;
1383 case legacy_hal::NAN_STATUS_INVALID_PARAM:
1384 return NanStatusCode::INVALID_ARGS;
1385 case legacy_hal::NAN_STATUS_INVALID_REQUESTOR_INSTANCE_ID:
1386 return NanStatusCode::INVALID_PEER_ID;
1387 case legacy_hal::NAN_STATUS_INVALID_NDP_ID:
1388 return NanStatusCode::INVALID_NDP_ID;
1389 case legacy_hal::NAN_STATUS_NAN_NOT_ALLOWED:
1390 return NanStatusCode::NAN_NOT_ALLOWED;
1391 case legacy_hal::NAN_STATUS_NO_OTA_ACK:
1392 return NanStatusCode::NO_OTA_ACK;
1393 case legacy_hal::NAN_STATUS_ALREADY_ENABLED:
1394 return NanStatusCode::ALREADY_ENABLED;
1395 case legacy_hal::NAN_STATUS_FOLLOWUP_QUEUE_FULL:
1396 return NanStatusCode::FOLLOWUP_TX_QUEUE_FULL;
1397 case legacy_hal::NAN_STATUS_UNSUPPORTED_CONCURRENCY_NAN_DISABLED:
1398 return NanStatusCode::UNSUPPORTED_CONCURRENCY_NAN_DISABLED;
Nate Jiang38e8db52022-12-02 17:30:27 -08001399 case legacy_hal::NAN_STATUS_INVALID_PAIRING_ID:
1400 return NanStatusCode::INVALID_PAIRING_ID;
1401 case legacy_hal::NAN_STATUS_INVALID_BOOTSTRAPPING_ID:
1402 return NanStatusCode::INVALID_BOOTSTRAPPING_ID;
Nate Jiangd6cc3312023-02-14 16:37:54 -08001403 case legacy_hal::NAN_STATUS_REDUNDANT_REQUEST:
1404 return NanStatusCode::REDUNDANT_REQUEST;
1405 case legacy_hal::NAN_STATUS_NOT_SUPPORTED:
1406 return NanStatusCode::NOT_SUPPORTED;
1407 case legacy_hal::NAN_STATUS_NO_CONNECTION:
1408 return NanStatusCode::NO_CONNECTION;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001409 }
1410 CHECK(false);
1411}
1412
1413void convertToNanStatus(legacy_hal::NanStatusType type, const char* str, size_t max_len,
1414 NanStatus* nanStatus) {
1415 nanStatus->status = convertLegacyNanStatusTypeToAidl(type);
1416 nanStatus->description = safeConvertChar(str, max_len);
1417}
1418
1419bool convertAidlNanEnableRequestToLegacy(const NanEnableRequest& aidl_request1,
1420 const NanConfigRequestSupplemental& aidl_request2,
1421 legacy_hal::NanEnableRequest* legacy_request) {
1422 if (!legacy_request) {
1423 LOG(ERROR) << "convertAidlNanEnableRequestToLegacy: null legacy_request";
1424 return false;
1425 }
1426 *legacy_request = {};
1427
1428 legacy_request->config_2dot4g_support = 1;
1429 legacy_request->support_2dot4g_val =
1430 aidl_request1.operateInBand[(size_t)NanBandIndex::NAN_BAND_24GHZ];
1431 legacy_request->config_support_5g = 1;
1432 legacy_request->support_5g_val =
1433 aidl_request1.operateInBand[(size_t)NanBandIndex::NAN_BAND_5GHZ];
1434 legacy_request->config_hop_count_limit = 1;
1435 legacy_request->hop_count_limit_val = aidl_request1.hopCountMax;
1436 legacy_request->master_pref = aidl_request1.configParams.masterPref;
1437 legacy_request->discovery_indication_cfg = 0;
1438 legacy_request->discovery_indication_cfg |=
1439 aidl_request1.configParams.disableDiscoveryAddressChangeIndication ? 0x1 : 0x0;
1440 legacy_request->discovery_indication_cfg |=
1441 aidl_request1.configParams.disableStartedClusterIndication ? 0x2 : 0x0;
1442 legacy_request->discovery_indication_cfg |=
1443 aidl_request1.configParams.disableJoinedClusterIndication ? 0x4 : 0x0;
1444 legacy_request->config_sid_beacon = 1;
1445 if (aidl_request1.configParams.numberOfPublishServiceIdsInBeacon < 0) {
1446 LOG(ERROR) << "convertAidlNanEnableRequestToLegacy: "
1447 "numberOfPublishServiceIdsInBeacon < 0";
1448 return false;
1449 }
1450 legacy_request->sid_beacon_val =
1451 (aidl_request1.configParams.includePublishServiceIdsInBeacon ? 0x1 : 0x0) |
1452 (aidl_request1.configParams.numberOfPublishServiceIdsInBeacon << 1);
1453 legacy_request->config_subscribe_sid_beacon = 1;
1454 if (aidl_request1.configParams.numberOfSubscribeServiceIdsInBeacon < 0) {
1455 LOG(ERROR) << "convertAidlNanEnableRequestToLegacy: "
1456 "numberOfSubscribeServiceIdsInBeacon < 0";
1457 return false;
1458 }
1459 legacy_request->subscribe_sid_beacon_val =
1460 (aidl_request1.configParams.includeSubscribeServiceIdsInBeacon ? 0x1 : 0x0) |
1461 (aidl_request1.configParams.numberOfSubscribeServiceIdsInBeacon << 1);
1462 legacy_request->config_rssi_window_size = 1;
1463 legacy_request->rssi_window_size_val = aidl_request1.configParams.rssiWindowSize;
1464 legacy_request->config_disc_mac_addr_randomization = 1;
1465 legacy_request->disc_mac_addr_rand_interval_sec =
1466 aidl_request1.configParams.macAddressRandomizationIntervalSec;
1467 legacy_request->config_2dot4g_rssi_close = 1;
1468 if (aidl_request1.configParams.bandSpecificConfig.size() != 3) {
1469 LOG(ERROR) << "convertAidlNanEnableRequestToLegacy: "
1470 "bandSpecificConfig.size() != 3";
1471 return false;
1472 }
1473 legacy_request->rssi_close_2dot4g_val =
1474 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1475 .rssiClose;
1476 legacy_request->config_2dot4g_rssi_middle = 1;
1477 legacy_request->rssi_middle_2dot4g_val =
1478 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1479 .rssiMiddle;
1480 legacy_request->config_2dot4g_rssi_proximity = 1;
1481 legacy_request->rssi_proximity_2dot4g_val =
1482 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1483 .rssiCloseProximity;
1484 legacy_request->config_scan_params = 1;
1485 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_24G_BAND] =
1486 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1487 .dwellTimeMs;
1488 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_24G_BAND] =
1489 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1490 .scanPeriodSec;
1491 legacy_request->config_dw.config_2dot4g_dw_band =
1492 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1493 .validDiscoveryWindowIntervalVal;
1494 legacy_request->config_dw.dw_2dot4g_interval_val =
1495 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1496 .discoveryWindowIntervalVal;
1497 legacy_request->config_5g_rssi_close = 1;
1498 legacy_request->rssi_close_5g_val =
1499 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1500 .rssiClose;
1501 legacy_request->config_5g_rssi_middle = 1;
1502 legacy_request->rssi_middle_5g_val =
1503 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1504 .rssiMiddle;
1505 legacy_request->config_5g_rssi_close_proximity = 1;
1506 legacy_request->rssi_close_proximity_5g_val =
1507 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1508 .rssiCloseProximity;
1509 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1510 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1511 .dwellTimeMs;
1512 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1513 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1514 .scanPeriodSec;
1515 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1516 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1517 .dwellTimeMs;
1518 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1519 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1520 .scanPeriodSec;
1521 legacy_request->config_dw.config_5g_dw_band =
1522 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1523 .validDiscoveryWindowIntervalVal;
1524 legacy_request->config_dw.dw_5g_interval_val =
1525 aidl_request1.configParams.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1526 .discoveryWindowIntervalVal;
1527 if (aidl_request1.debugConfigs.validClusterIdVals) {
1528 legacy_request->cluster_low = aidl_request1.debugConfigs.clusterIdBottomRangeVal;
1529 legacy_request->cluster_high = aidl_request1.debugConfigs.clusterIdTopRangeVal;
1530 } else { // need 'else' since not configurable in legacy HAL
1531 legacy_request->cluster_low = 0x0000;
1532 legacy_request->cluster_high = 0xFFFF;
1533 }
1534 legacy_request->config_intf_addr = aidl_request1.debugConfigs.validIntfAddrVal;
1535 memcpy(legacy_request->intf_addr_val, aidl_request1.debugConfigs.intfAddrVal.data(), 6);
1536 legacy_request->config_oui = aidl_request1.debugConfigs.validOuiVal;
1537 legacy_request->oui_val = aidl_request1.debugConfigs.ouiVal;
1538 legacy_request->config_random_factor_force =
1539 aidl_request1.debugConfigs.validRandomFactorForceVal;
1540 legacy_request->random_factor_force_val = aidl_request1.debugConfigs.randomFactorForceVal;
1541 legacy_request->config_hop_count_force = aidl_request1.debugConfigs.validHopCountForceVal;
1542 legacy_request->hop_count_force_val = aidl_request1.debugConfigs.hopCountForceVal;
1543 legacy_request->config_24g_channel = aidl_request1.debugConfigs.validDiscoveryChannelVal;
1544 legacy_request->channel_24g_val =
1545 aidl_request1.debugConfigs.discoveryChannelMhzVal[(size_t)NanBandIndex::NAN_BAND_24GHZ];
1546 legacy_request->config_5g_channel = aidl_request1.debugConfigs.validDiscoveryChannelVal;
1547 legacy_request->channel_5g_val =
1548 aidl_request1.debugConfigs.discoveryChannelMhzVal[(size_t)NanBandIndex::NAN_BAND_5GHZ];
1549 legacy_request->config_2dot4g_beacons = aidl_request1.debugConfigs.validUseBeaconsInBandVal;
1550 legacy_request->beacon_2dot4g_val =
1551 aidl_request1.debugConfigs.useBeaconsInBandVal[(size_t)NanBandIndex::NAN_BAND_24GHZ];
1552 legacy_request->config_5g_beacons = aidl_request1.debugConfigs.validUseBeaconsInBandVal;
1553 legacy_request->beacon_5g_val =
1554 aidl_request1.debugConfigs.useBeaconsInBandVal[(size_t)NanBandIndex::NAN_BAND_5GHZ];
1555 legacy_request->config_2dot4g_sdf = aidl_request1.debugConfigs.validUseSdfInBandVal;
1556 legacy_request->sdf_2dot4g_val =
1557 aidl_request1.debugConfigs.useSdfInBandVal[(size_t)NanBandIndex::NAN_BAND_24GHZ];
1558 legacy_request->config_5g_sdf = aidl_request1.debugConfigs.validUseSdfInBandVal;
1559 legacy_request->sdf_5g_val =
1560 aidl_request1.debugConfigs.useSdfInBandVal[(size_t)NanBandIndex::NAN_BAND_5GHZ];
1561
1562 legacy_request->config_discovery_beacon_int = 1;
1563 legacy_request->discovery_beacon_interval = aidl_request2.discoveryBeaconIntervalMs;
1564 legacy_request->config_nss = 1;
1565 legacy_request->nss = aidl_request2.numberOfSpatialStreamsInDiscovery;
1566 legacy_request->config_dw_early_termination = 1;
1567 legacy_request->enable_dw_termination = aidl_request2.enableDiscoveryWindowEarlyTermination;
1568 legacy_request->config_enable_ranging = 1;
1569 legacy_request->enable_ranging = aidl_request2.enableRanging;
1570
1571 legacy_request->config_enable_instant_mode = 1;
1572 legacy_request->enable_instant_mode = aidl_request2.enableInstantCommunicationMode;
1573 legacy_request->config_instant_mode_channel = 1;
1574 legacy_request->instant_mode_channel = aidl_request2.instantModeChannel;
1575
1576 return true;
1577}
1578
1579bool convertAidlNanConfigRequestToLegacy(const NanConfigRequest& aidl_request1,
1580 const NanConfigRequestSupplemental& aidl_request2,
1581 legacy_hal::NanConfigRequest* legacy_request) {
1582 if (!legacy_request) {
1583 LOG(ERROR) << "convertAidlNanConfigRequestToLegacy: null legacy_request";
1584 return false;
1585 }
1586 *legacy_request = {};
1587
1588 legacy_request->master_pref = aidl_request1.masterPref;
1589 legacy_request->discovery_indication_cfg = 0;
1590 legacy_request->discovery_indication_cfg |=
1591 aidl_request1.disableDiscoveryAddressChangeIndication ? 0x1 : 0x0;
1592 legacy_request->discovery_indication_cfg |=
1593 aidl_request1.disableStartedClusterIndication ? 0x2 : 0x0;
1594 legacy_request->discovery_indication_cfg |=
1595 aidl_request1.disableJoinedClusterIndication ? 0x4 : 0x0;
1596 legacy_request->config_sid_beacon = 1;
1597 if (aidl_request1.numberOfPublishServiceIdsInBeacon < 0) {
1598 LOG(ERROR) << "convertAidlNanConfigRequestToLegacy: "
1599 "numberOfPublishServiceIdsInBeacon < 0";
1600 return false;
1601 }
1602 legacy_request->sid_beacon = (aidl_request1.includePublishServiceIdsInBeacon ? 0x1 : 0x0) |
1603 (aidl_request1.numberOfPublishServiceIdsInBeacon << 1);
1604 legacy_request->config_subscribe_sid_beacon = 1;
1605 if (aidl_request1.numberOfSubscribeServiceIdsInBeacon < 0) {
1606 LOG(ERROR) << "convertAidlNanConfigRequestToLegacy: "
1607 "numberOfSubscribeServiceIdsInBeacon < 0";
1608 return false;
1609 }
1610 legacy_request->subscribe_sid_beacon_val =
1611 (aidl_request1.includeSubscribeServiceIdsInBeacon ? 0x1 : 0x0) |
1612 (aidl_request1.numberOfSubscribeServiceIdsInBeacon << 1);
1613 legacy_request->config_rssi_window_size = 1;
1614 legacy_request->rssi_window_size_val = aidl_request1.rssiWindowSize;
1615 legacy_request->config_disc_mac_addr_randomization = 1;
1616 legacy_request->disc_mac_addr_rand_interval_sec =
1617 aidl_request1.macAddressRandomizationIntervalSec;
1618
1619 legacy_request->config_scan_params = 1;
1620 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_24G_BAND] =
1621 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ].dwellTimeMs;
1622 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_24G_BAND] =
1623 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ].scanPeriodSec;
1624 legacy_request->config_dw.config_2dot4g_dw_band =
1625 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1626 .validDiscoveryWindowIntervalVal;
1627 legacy_request->config_dw.dw_2dot4g_interval_val =
1628 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_24GHZ]
1629 .discoveryWindowIntervalVal;
1630
1631 legacy_request->config_5g_rssi_close_proximity = 1;
1632 legacy_request->rssi_close_proximity_5g_val =
1633 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1634 .rssiCloseProximity;
1635 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1636 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
1637 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_LOW] =
1638 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
1639 legacy_request->scan_params_val.dwell_time[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1640 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ].dwellTimeMs;
1641 legacy_request->scan_params_val.scan_period[legacy_hal::NAN_CHANNEL_5G_BAND_HIGH] =
1642 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ].scanPeriodSec;
1643 legacy_request->config_dw.config_5g_dw_band =
1644 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1645 .validDiscoveryWindowIntervalVal;
1646 legacy_request->config_dw.dw_5g_interval_val =
1647 aidl_request1.bandSpecificConfig[(size_t)NanBandIndex::NAN_BAND_5GHZ]
1648 .discoveryWindowIntervalVal;
1649
1650 legacy_request->config_discovery_beacon_int = 1;
1651 legacy_request->discovery_beacon_interval = aidl_request2.discoveryBeaconIntervalMs;
1652 legacy_request->config_nss = 1;
1653 legacy_request->nss = aidl_request2.numberOfSpatialStreamsInDiscovery;
1654 legacy_request->config_dw_early_termination = 1;
1655 legacy_request->enable_dw_termination = aidl_request2.enableDiscoveryWindowEarlyTermination;
1656 legacy_request->config_enable_ranging = 1;
1657 legacy_request->enable_ranging = aidl_request2.enableRanging;
1658
1659 legacy_request->config_enable_instant_mode = 1;
1660 legacy_request->enable_instant_mode = aidl_request2.enableInstantCommunicationMode;
1661 legacy_request->config_instant_mode_channel = 1;
1662 legacy_request->instant_mode_channel = aidl_request2.instantModeChannel;
Biswarup Paldc7192f2023-01-09 21:21:07 +00001663 legacy_request->config_cluster_id = 1;
1664 legacy_request->cluster_id_val = aidl_request2.clusterId;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001665
1666 return true;
1667}
1668
1669bool convertAidlNanPublishRequestToLegacy(const NanPublishRequest& aidl_request,
1670 legacy_hal::NanPublishRequest* legacy_request) {
1671 if (!legacy_request) {
1672 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: null legacy_request";
1673 return false;
1674 }
1675 *legacy_request = {};
1676
Nate Jiang42091762022-12-27 17:08:25 -08001677 legacy_request->publish_id = static_cast<uint8_t>(aidl_request.baseConfigs.sessionId);
Gabriel Birenf3262f92022-07-15 23:25:39 +00001678 legacy_request->ttl = aidl_request.baseConfigs.ttlSec;
1679 legacy_request->period = aidl_request.baseConfigs.discoveryWindowPeriod;
1680 legacy_request->publish_count = aidl_request.baseConfigs.discoveryCount;
1681 legacy_request->service_name_len = aidl_request.baseConfigs.serviceName.size();
1682 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
1683 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: service_name_len "
1684 "too large";
1685 return false;
1686 }
1687 memcpy(legacy_request->service_name, aidl_request.baseConfigs.serviceName.data(),
1688 legacy_request->service_name_len);
1689 legacy_request->publish_match_indicator =
1690 convertAidlNanMatchAlgToLegacy(aidl_request.baseConfigs.discoveryMatchIndicator);
1691 legacy_request->service_specific_info_len = aidl_request.baseConfigs.serviceSpecificInfo.size();
1692 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
1693 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1694 "service_specific_info_len too large";
1695 return false;
1696 }
1697 memcpy(legacy_request->service_specific_info,
1698 aidl_request.baseConfigs.serviceSpecificInfo.data(),
1699 legacy_request->service_specific_info_len);
1700 legacy_request->sdea_service_specific_info_len =
1701 aidl_request.baseConfigs.extendedServiceSpecificInfo.size();
1702 if (legacy_request->sdea_service_specific_info_len > NAN_MAX_SDEA_SERVICE_SPECIFIC_INFO_LEN) {
1703 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1704 "sdea_service_specific_info_len too large";
1705 return false;
1706 }
1707 memcpy(legacy_request->sdea_service_specific_info,
1708 aidl_request.baseConfigs.extendedServiceSpecificInfo.data(),
1709 legacy_request->sdea_service_specific_info_len);
1710 legacy_request->rx_match_filter_len = aidl_request.baseConfigs.rxMatchFilter.size();
1711 if (legacy_request->rx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
1712 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1713 "rx_match_filter_len too large";
1714 return false;
1715 }
1716 memcpy(legacy_request->rx_match_filter, aidl_request.baseConfigs.rxMatchFilter.data(),
1717 legacy_request->rx_match_filter_len);
1718 legacy_request->tx_match_filter_len = aidl_request.baseConfigs.txMatchFilter.size();
1719 if (legacy_request->tx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
1720 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1721 "tx_match_filter_len too large";
1722 return false;
1723 }
1724 memcpy(legacy_request->tx_match_filter, aidl_request.baseConfigs.txMatchFilter.data(),
1725 legacy_request->tx_match_filter_len);
1726 legacy_request->rssi_threshold_flag = aidl_request.baseConfigs.useRssiThreshold;
1727 legacy_request->recv_indication_cfg = 0;
1728 legacy_request->recv_indication_cfg |=
1729 aidl_request.baseConfigs.disableDiscoveryTerminationIndication ? 0x1 : 0x0;
1730 legacy_request->recv_indication_cfg |=
1731 aidl_request.baseConfigs.disableMatchExpirationIndication ? 0x2 : 0x0;
1732 legacy_request->recv_indication_cfg |=
1733 aidl_request.baseConfigs.disableFollowupReceivedIndication ? 0x4 : 0x0;
1734 legacy_request->recv_indication_cfg |= 0x8;
1735 legacy_request->cipher_type = (unsigned int)aidl_request.baseConfigs.securityConfig.cipherType;
1736
1737 legacy_request->scid_len = aidl_request.baseConfigs.securityConfig.scid.size();
1738 if (legacy_request->scid_len > NAN_MAX_SCID_BUF_LEN) {
1739 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: scid_len too large";
1740 return false;
1741 }
1742 memcpy(legacy_request->scid, aidl_request.baseConfigs.securityConfig.scid.data(),
1743 legacy_request->scid_len);
1744
1745 if (aidl_request.baseConfigs.securityConfig.securityType == NanDataPathSecurityType::PMK) {
1746 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
1747 legacy_request->key_info.body.pmk_info.pmk_len =
1748 aidl_request.baseConfigs.securityConfig.pmk.size();
1749 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
1750 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: invalid pmk_len";
1751 return false;
1752 }
1753 memcpy(legacy_request->key_info.body.pmk_info.pmk,
1754 aidl_request.baseConfigs.securityConfig.pmk.data(),
1755 legacy_request->key_info.body.pmk_info.pmk_len);
1756 }
1757 if (aidl_request.baseConfigs.securityConfig.securityType ==
1758 NanDataPathSecurityType::PASSPHRASE) {
1759 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
1760 legacy_request->key_info.body.passphrase_info.passphrase_len =
1761 aidl_request.baseConfigs.securityConfig.passphrase.size();
1762 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
1763 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
1764 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1765 "passphrase_len too small";
1766 return false;
1767 }
1768 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
1769 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
1770 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: "
1771 "passphrase_len too large";
1772 return false;
1773 }
1774 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
1775 aidl_request.baseConfigs.securityConfig.passphrase.data(),
1776 legacy_request->key_info.body.passphrase_info.passphrase_len);
1777 }
1778 legacy_request->sdea_params.security_cfg =
1779 (aidl_request.baseConfigs.securityConfig.securityType != NanDataPathSecurityType::OPEN)
1780 ? legacy_hal::NAN_DP_CONFIG_SECURITY
1781 : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
1782
1783 legacy_request->sdea_params.ranging_state = aidl_request.baseConfigs.rangingRequired
1784 ? legacy_hal::NAN_RANGING_ENABLE
1785 : legacy_hal::NAN_RANGING_DISABLE;
1786 legacy_request->ranging_cfg.ranging_interval_msec = aidl_request.baseConfigs.rangingIntervalMs;
1787 legacy_request->ranging_cfg.config_ranging_indications =
Gabriel Biren86971aa2023-03-03 18:04:46 +00001788 aidl_request.baseConfigs.configRangingIndications;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001789 legacy_request->ranging_cfg.distance_ingress_mm =
1790 aidl_request.baseConfigs.distanceIngressCm * 10;
1791 legacy_request->ranging_cfg.distance_egress_mm = aidl_request.baseConfigs.distanceEgressCm * 10;
1792 legacy_request->ranging_auto_response = aidl_request.baseConfigs.rangingRequired
1793 ? legacy_hal::NAN_RANGING_AUTO_RESPONSE_ENABLE
1794 : legacy_hal::NAN_RANGING_AUTO_RESPONSE_DISABLE;
1795 legacy_request->sdea_params.range_report = legacy_hal::NAN_DISABLE_RANGE_REPORT;
1796 legacy_request->publish_type = convertAidlNanPublishTypeToLegacy(aidl_request.publishType);
1797 legacy_request->tx_type = convertAidlNanTxTypeToLegacy(aidl_request.txType);
1798 legacy_request->service_responder_policy = aidl_request.autoAcceptDataPathRequests
1799 ? legacy_hal::NAN_SERVICE_ACCEPT_POLICY_ALL
1800 : legacy_hal::NAN_SERVICE_ACCEPT_POLICY_NONE;
Nate Jiang38e8db52022-12-02 17:30:27 -08001801 memcpy(legacy_request->nan_identity_key, aidl_request.identityKey.data(), NAN_IDENTITY_KEY_LEN);
1802 if (!covertAidlPairingConfigToLegacy(aidl_request.pairingConfig,
1803 &legacy_request->nan_pairing_config)) {
1804 LOG(ERROR) << "convertAidlNanPublishRequestToLegacy: invalid pairing config";
1805 return false;
1806 }
Biswarup Pal11921782023-01-09 14:10:51 +00001807 legacy_request->enable_suspendability = aidl_request.baseConfigs.enableSessionSuspendability;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001808
1809 return true;
1810}
1811
1812bool convertAidlNanSubscribeRequestToLegacy(const NanSubscribeRequest& aidl_request,
1813 legacy_hal::NanSubscribeRequest* legacy_request) {
1814 if (!legacy_request) {
1815 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: legacy_request is null";
1816 return false;
1817 }
1818 *legacy_request = {};
1819
Nate Jiang42091762022-12-27 17:08:25 -08001820 legacy_request->subscribe_id = static_cast<uint8_t>(aidl_request.baseConfigs.sessionId);
Gabriel Birenf3262f92022-07-15 23:25:39 +00001821 legacy_request->ttl = aidl_request.baseConfigs.ttlSec;
1822 legacy_request->period = aidl_request.baseConfigs.discoveryWindowPeriod;
1823 legacy_request->subscribe_count = aidl_request.baseConfigs.discoveryCount;
1824 legacy_request->service_name_len = aidl_request.baseConfigs.serviceName.size();
1825 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
1826 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1827 "service_name_len too large";
1828 return false;
1829 }
1830 memcpy(legacy_request->service_name, aidl_request.baseConfigs.serviceName.data(),
1831 legacy_request->service_name_len);
1832 legacy_request->subscribe_match_indicator =
1833 convertAidlNanMatchAlgToLegacy(aidl_request.baseConfigs.discoveryMatchIndicator);
1834 legacy_request->service_specific_info_len = aidl_request.baseConfigs.serviceSpecificInfo.size();
1835 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
1836 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1837 "service_specific_info_len too large";
1838 return false;
1839 }
1840 memcpy(legacy_request->service_specific_info,
1841 aidl_request.baseConfigs.serviceSpecificInfo.data(),
1842 legacy_request->service_specific_info_len);
1843 legacy_request->sdea_service_specific_info_len =
1844 aidl_request.baseConfigs.extendedServiceSpecificInfo.size();
1845 if (legacy_request->sdea_service_specific_info_len > NAN_MAX_SDEA_SERVICE_SPECIFIC_INFO_LEN) {
1846 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1847 "sdea_service_specific_info_len too large";
1848 return false;
1849 }
1850 memcpy(legacy_request->sdea_service_specific_info,
1851 aidl_request.baseConfigs.extendedServiceSpecificInfo.data(),
1852 legacy_request->sdea_service_specific_info_len);
1853 legacy_request->rx_match_filter_len = aidl_request.baseConfigs.rxMatchFilter.size();
1854 if (legacy_request->rx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
1855 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1856 "rx_match_filter_len too large";
1857 return false;
1858 }
1859 memcpy(legacy_request->rx_match_filter, aidl_request.baseConfigs.rxMatchFilter.data(),
1860 legacy_request->rx_match_filter_len);
1861 legacy_request->tx_match_filter_len = aidl_request.baseConfigs.txMatchFilter.size();
1862 if (legacy_request->tx_match_filter_len > NAN_MAX_MATCH_FILTER_LEN) {
1863 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1864 "tx_match_filter_len too large";
1865 return false;
1866 }
1867 memcpy(legacy_request->tx_match_filter, aidl_request.baseConfigs.txMatchFilter.data(),
1868 legacy_request->tx_match_filter_len);
1869 legacy_request->rssi_threshold_flag = aidl_request.baseConfigs.useRssiThreshold;
1870 legacy_request->recv_indication_cfg = 0;
1871 legacy_request->recv_indication_cfg |=
1872 aidl_request.baseConfigs.disableDiscoveryTerminationIndication ? 0x1 : 0x0;
1873 legacy_request->recv_indication_cfg |=
1874 aidl_request.baseConfigs.disableMatchExpirationIndication ? 0x2 : 0x0;
1875 legacy_request->recv_indication_cfg |=
1876 aidl_request.baseConfigs.disableFollowupReceivedIndication ? 0x4 : 0x0;
1877 legacy_request->cipher_type = (unsigned int)aidl_request.baseConfigs.securityConfig.cipherType;
1878 if (aidl_request.baseConfigs.securityConfig.securityType == NanDataPathSecurityType::PMK) {
1879 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
1880 legacy_request->key_info.body.pmk_info.pmk_len =
1881 aidl_request.baseConfigs.securityConfig.pmk.size();
1882 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
1883 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: invalid pmk_len";
1884 return false;
1885 }
1886 memcpy(legacy_request->key_info.body.pmk_info.pmk,
1887 aidl_request.baseConfigs.securityConfig.pmk.data(),
1888 legacy_request->key_info.body.pmk_info.pmk_len);
1889 }
1890 if (aidl_request.baseConfigs.securityConfig.securityType ==
1891 NanDataPathSecurityType::PASSPHRASE) {
1892 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
1893 legacy_request->key_info.body.passphrase_info.passphrase_len =
1894 aidl_request.baseConfigs.securityConfig.passphrase.size();
1895 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
1896 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
1897 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1898 "passphrase_len too small";
1899 return false;
1900 }
1901 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
1902 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
1903 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1904 "passphrase_len too large";
1905 return false;
1906 }
1907 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
1908 aidl_request.baseConfigs.securityConfig.passphrase.data(),
1909 legacy_request->key_info.body.passphrase_info.passphrase_len);
1910 }
1911 legacy_request->sdea_params.security_cfg =
1912 (aidl_request.baseConfigs.securityConfig.securityType != NanDataPathSecurityType::OPEN)
1913 ? legacy_hal::NAN_DP_CONFIG_SECURITY
1914 : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
1915 legacy_request->sdea_params.ranging_state = aidl_request.baseConfigs.rangingRequired
1916 ? legacy_hal::NAN_RANGING_ENABLE
1917 : legacy_hal::NAN_RANGING_DISABLE;
1918 legacy_request->ranging_cfg.ranging_interval_msec = aidl_request.baseConfigs.rangingIntervalMs;
1919 legacy_request->ranging_cfg.config_ranging_indications =
Gabriel Biren86971aa2023-03-03 18:04:46 +00001920 aidl_request.baseConfigs.configRangingIndications;
Gabriel Birenf3262f92022-07-15 23:25:39 +00001921 legacy_request->ranging_cfg.distance_ingress_mm =
1922 aidl_request.baseConfigs.distanceIngressCm * 10;
1923 legacy_request->ranging_cfg.distance_egress_mm = aidl_request.baseConfigs.distanceEgressCm * 10;
1924 legacy_request->ranging_auto_response = aidl_request.baseConfigs.rangingRequired
1925 ? legacy_hal::NAN_RANGING_AUTO_RESPONSE_ENABLE
1926 : legacy_hal::NAN_RANGING_AUTO_RESPONSE_DISABLE;
1927 legacy_request->sdea_params.range_report = legacy_hal::NAN_DISABLE_RANGE_REPORT;
1928 legacy_request->subscribe_type =
1929 convertAidlNanSubscribeTypeToLegacy(aidl_request.subscribeType);
1930 legacy_request->serviceResponseFilter = convertAidlNanSrfTypeToLegacy(aidl_request.srfType);
1931 legacy_request->serviceResponseInclude = aidl_request.srfRespondIfInAddressSet
1932 ? legacy_hal::NAN_SRF_INCLUDE_RESPOND
1933 : legacy_hal::NAN_SRF_INCLUDE_DO_NOT_RESPOND;
1934 legacy_request->useServiceResponseFilter =
1935 aidl_request.shouldUseSrf ? legacy_hal::NAN_USE_SRF : legacy_hal::NAN_DO_NOT_USE_SRF;
1936 legacy_request->ssiRequiredForMatchIndication =
1937 aidl_request.isSsiRequiredForMatch ? legacy_hal::NAN_SSI_REQUIRED_IN_MATCH_IND
1938 : legacy_hal::NAN_SSI_NOT_REQUIRED_IN_MATCH_IND;
1939 legacy_request->num_intf_addr_present = aidl_request.intfAddr.size();
1940 if (legacy_request->num_intf_addr_present > NAN_MAX_SUBSCRIBE_MAX_ADDRESS) {
1941 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: "
1942 "num_intf_addr_present - too many";
1943 return false;
1944 }
1945 for (int i = 0; i < legacy_request->num_intf_addr_present; i++) {
1946 memcpy(legacy_request->intf_addr[i], aidl_request.intfAddr[i].data.data(), 6);
1947 }
Nate Jiang38e8db52022-12-02 17:30:27 -08001948 memcpy(legacy_request->nan_identity_key, aidl_request.identityKey.data(), NAN_IDENTITY_KEY_LEN);
1949 if (!covertAidlPairingConfigToLegacy(aidl_request.pairingConfig,
1950 &legacy_request->nan_pairing_config)) {
1951 LOG(ERROR) << "convertAidlNanSubscribeRequestToLegacy: invalid pairing config";
1952 return false;
1953 }
Biswarup Pal11921782023-01-09 14:10:51 +00001954 legacy_request->enable_suspendability = aidl_request.baseConfigs.enableSessionSuspendability;
1955
Gabriel Birenf3262f92022-07-15 23:25:39 +00001956 return true;
1957}
1958
1959bool convertAidlNanTransmitFollowupRequestToLegacy(
1960 const NanTransmitFollowupRequest& aidl_request,
1961 legacy_hal::NanTransmitFollowupRequest* legacy_request) {
1962 if (!legacy_request) {
1963 LOG(ERROR) << "convertAidlNanTransmitFollowupRequestToLegacy: "
1964 "legacy_request is null";
1965 return false;
1966 }
1967 *legacy_request = {};
1968
Nate Jiang42091762022-12-27 17:08:25 -08001969 legacy_request->publish_subscribe_id = static_cast<uint8_t>(aidl_request.discoverySessionId);
Gabriel Birenf3262f92022-07-15 23:25:39 +00001970 legacy_request->requestor_instance_id = aidl_request.peerId;
1971 memcpy(legacy_request->addr, aidl_request.addr.data(), 6);
1972 legacy_request->priority = aidl_request.isHighPriority ? legacy_hal::NAN_TX_PRIORITY_HIGH
1973 : legacy_hal::NAN_TX_PRIORITY_NORMAL;
1974 legacy_request->dw_or_faw = aidl_request.shouldUseDiscoveryWindow
1975 ? legacy_hal::NAN_TRANSMIT_IN_DW
1976 : legacy_hal::NAN_TRANSMIT_IN_FAW;
1977 legacy_request->service_specific_info_len = aidl_request.serviceSpecificInfo.size();
1978 if (legacy_request->service_specific_info_len > NAN_MAX_SERVICE_SPECIFIC_INFO_LEN) {
1979 LOG(ERROR) << "convertAidlNanTransmitFollowupRequestToLegacy: "
1980 "service_specific_info_len too large";
1981 return false;
1982 }
1983 memcpy(legacy_request->service_specific_info, aidl_request.serviceSpecificInfo.data(),
1984 legacy_request->service_specific_info_len);
1985 legacy_request->sdea_service_specific_info_len =
1986 aidl_request.extendedServiceSpecificInfo.size();
1987 if (legacy_request->sdea_service_specific_info_len > NAN_MAX_SDEA_SERVICE_SPECIFIC_INFO_LEN) {
1988 LOG(ERROR) << "convertAidlNanTransmitFollowupRequestToLegacy: "
1989 "sdea_service_specific_info_len too large";
1990 return false;
1991 }
1992 memcpy(legacy_request->sdea_service_specific_info,
1993 aidl_request.extendedServiceSpecificInfo.data(),
1994 legacy_request->sdea_service_specific_info_len);
1995 legacy_request->recv_indication_cfg = aidl_request.disableFollowupResultIndication ? 0x1 : 0x0;
1996
1997 return true;
1998}
1999
2000bool convertAidlNanDataPathInitiatorRequestToLegacy(
2001 const NanInitiateDataPathRequest& aidl_request,
2002 legacy_hal::NanDataPathInitiatorRequest* legacy_request) {
2003 if (!legacy_request) {
2004 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2005 "legacy_request is null";
2006 return false;
2007 }
2008 *legacy_request = {};
2009
2010 legacy_request->requestor_instance_id = aidl_request.peerId;
2011 memcpy(legacy_request->peer_disc_mac_addr, aidl_request.peerDiscMacAddr.data(), 6);
2012 legacy_request->channel_request_type =
2013 convertAidlNanDataPathChannelCfgToLegacy(aidl_request.channelRequestType);
2014 legacy_request->channel = aidl_request.channel;
2015 if (strnlen(aidl_request.ifaceName.c_str(), IFNAMSIZ + 1) == IFNAMSIZ + 1) {
2016 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2017 "ifaceName too long";
2018 return false;
2019 }
2020 strlcpy(legacy_request->ndp_iface, aidl_request.ifaceName.c_str(), IFNAMSIZ + 1);
2021 legacy_request->ndp_cfg.security_cfg =
2022 (aidl_request.securityConfig.securityType != NanDataPathSecurityType::OPEN)
2023 ? legacy_hal::NAN_DP_CONFIG_SECURITY
2024 : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
2025 legacy_request->app_info.ndp_app_info_len = aidl_request.appInfo.size();
2026 if (legacy_request->app_info.ndp_app_info_len > NAN_DP_MAX_APP_INFO_LEN) {
2027 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2028 "ndp_app_info_len too large";
2029 return false;
2030 }
2031 memcpy(legacy_request->app_info.ndp_app_info, aidl_request.appInfo.data(),
2032 legacy_request->app_info.ndp_app_info_len);
2033 legacy_request->cipher_type = (unsigned int)aidl_request.securityConfig.cipherType;
2034 if (aidl_request.securityConfig.securityType == NanDataPathSecurityType::PMK) {
2035 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
2036 legacy_request->key_info.body.pmk_info.pmk_len = aidl_request.securityConfig.pmk.size();
2037 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
2038 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2039 "invalid pmk_len";
2040 return false;
2041 }
2042 memcpy(legacy_request->key_info.body.pmk_info.pmk, aidl_request.securityConfig.pmk.data(),
2043 legacy_request->key_info.body.pmk_info.pmk_len);
2044 }
2045 if (aidl_request.securityConfig.securityType == NanDataPathSecurityType::PASSPHRASE) {
2046 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
2047 legacy_request->key_info.body.passphrase_info.passphrase_len =
2048 aidl_request.securityConfig.passphrase.size();
2049 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
2050 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
2051 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2052 "passphrase_len too small";
2053 return false;
2054 }
2055 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
2056 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
2057 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2058 "passphrase_len too large";
2059 return false;
2060 }
2061 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
2062 aidl_request.securityConfig.passphrase.data(),
2063 legacy_request->key_info.body.passphrase_info.passphrase_len);
2064 }
2065 legacy_request->service_name_len = aidl_request.serviceNameOutOfBand.size();
2066 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
2067 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: "
2068 "service_name_len too large";
2069 return false;
2070 }
2071 memcpy(legacy_request->service_name, aidl_request.serviceNameOutOfBand.data(),
2072 legacy_request->service_name_len);
2073 legacy_request->scid_len = aidl_request.securityConfig.scid.size();
2074 if (legacy_request->scid_len > NAN_MAX_SCID_BUF_LEN) {
2075 LOG(ERROR) << "convertAidlNanDataPathInitiatorRequestToLegacy: scid_len too large";
2076 return false;
2077 }
2078 memcpy(legacy_request->scid, aidl_request.securityConfig.scid.data(), legacy_request->scid_len);
Nate Jiangd6cc3312023-02-14 16:37:54 -08002079 legacy_request->publish_subscribe_id = static_cast<uint8_t>(aidl_request.discoverySessionId);
Gabriel Birenf3262f92022-07-15 23:25:39 +00002080
2081 return true;
2082}
2083
2084bool convertAidlNanDataPathIndicationResponseToLegacy(
2085 const NanRespondToDataPathIndicationRequest& aidl_request,
2086 legacy_hal::NanDataPathIndicationResponse* legacy_request) {
2087 if (!legacy_request) {
2088 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2089 "legacy_request is null";
2090 return false;
2091 }
2092 *legacy_request = {};
2093
2094 legacy_request->rsp_code = aidl_request.acceptRequest ? legacy_hal::NAN_DP_REQUEST_ACCEPT
2095 : legacy_hal::NAN_DP_REQUEST_REJECT;
2096 legacy_request->ndp_instance_id = aidl_request.ndpInstanceId;
2097 if (strnlen(aidl_request.ifaceName.c_str(), IFNAMSIZ + 1) == IFNAMSIZ + 1) {
2098 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2099 "ifaceName too long";
2100 return false;
2101 }
2102 strlcpy(legacy_request->ndp_iface, aidl_request.ifaceName.c_str(), IFNAMSIZ + 1);
2103 legacy_request->ndp_cfg.security_cfg =
2104 (aidl_request.securityConfig.securityType != NanDataPathSecurityType::OPEN)
2105 ? legacy_hal::NAN_DP_CONFIG_SECURITY
2106 : legacy_hal::NAN_DP_CONFIG_NO_SECURITY;
2107 legacy_request->app_info.ndp_app_info_len = aidl_request.appInfo.size();
2108 if (legacy_request->app_info.ndp_app_info_len > NAN_DP_MAX_APP_INFO_LEN) {
2109 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2110 "ndp_app_info_len too large";
2111 return false;
2112 }
2113 memcpy(legacy_request->app_info.ndp_app_info, aidl_request.appInfo.data(),
2114 legacy_request->app_info.ndp_app_info_len);
2115 legacy_request->cipher_type = (unsigned int)aidl_request.securityConfig.cipherType;
2116 if (aidl_request.securityConfig.securityType == NanDataPathSecurityType::PMK) {
2117 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
2118 legacy_request->key_info.body.pmk_info.pmk_len = aidl_request.securityConfig.pmk.size();
2119 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
2120 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2121 "invalid pmk_len";
2122 return false;
2123 }
2124 memcpy(legacy_request->key_info.body.pmk_info.pmk, aidl_request.securityConfig.pmk.data(),
2125 legacy_request->key_info.body.pmk_info.pmk_len);
2126 }
2127 if (aidl_request.securityConfig.securityType == NanDataPathSecurityType::PASSPHRASE) {
2128 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
2129 legacy_request->key_info.body.passphrase_info.passphrase_len =
2130 aidl_request.securityConfig.passphrase.size();
2131 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
2132 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
2133 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2134 "passphrase_len too small";
2135 return false;
2136 }
2137 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
2138 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
2139 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2140 "passphrase_len too large";
2141 return false;
2142 }
2143 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
2144 aidl_request.securityConfig.passphrase.data(),
2145 legacy_request->key_info.body.passphrase_info.passphrase_len);
2146 }
2147 legacy_request->service_name_len = aidl_request.serviceNameOutOfBand.size();
2148 if (legacy_request->service_name_len > NAN_MAX_SERVICE_NAME_LEN) {
2149 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: "
2150 "service_name_len too large";
2151 return false;
2152 }
2153 memcpy(legacy_request->service_name, aidl_request.serviceNameOutOfBand.data(),
2154 legacy_request->service_name_len);
2155 legacy_request->scid_len = aidl_request.securityConfig.scid.size();
2156 if (legacy_request->scid_len > NAN_MAX_SCID_BUF_LEN) {
2157 LOG(ERROR) << "convertAidlNanDataPathIndicationResponseToLegacy: scid_len too large";
2158 return false;
2159 }
2160 memcpy(legacy_request->scid, aidl_request.securityConfig.scid.data(), legacy_request->scid_len);
Nate Jiangd6cc3312023-02-14 16:37:54 -08002161 legacy_request->publish_subscribe_id = static_cast<uint8_t>(aidl_request.discoverySessionId);
Gabriel Birenf3262f92022-07-15 23:25:39 +00002162
2163 return true;
2164}
2165
2166bool convertLegacyNanResponseHeaderToAidl(const legacy_hal::NanResponseMsg& legacy_response,
2167 NanStatus* nanStatus) {
2168 if (!nanStatus) {
2169 LOG(ERROR) << "convertLegacyNanResponseHeaderToAidl: nanStatus is null";
2170 return false;
2171 }
2172 *nanStatus = {};
2173
2174 convertToNanStatus(legacy_response.status, legacy_response.nan_error,
2175 sizeof(legacy_response.nan_error), nanStatus);
2176 return true;
2177}
2178
2179bool convertLegacyNanCapabilitiesResponseToAidl(const legacy_hal::NanCapabilities& legacy_response,
2180 NanCapabilities* aidl_response) {
2181 if (!aidl_response) {
2182 LOG(ERROR) << "convertLegacyNanCapabilitiesResponseToAidl: "
2183 "aidl_response is null";
2184 return false;
2185 }
2186 *aidl_response = {};
2187
2188 aidl_response->maxConcurrentClusters = legacy_response.max_concurrent_nan_clusters;
2189 aidl_response->maxPublishes = legacy_response.max_publishes;
2190 aidl_response->maxSubscribes = legacy_response.max_subscribes;
2191 aidl_response->maxServiceNameLen = legacy_response.max_service_name_len;
2192 aidl_response->maxMatchFilterLen = legacy_response.max_match_filter_len;
2193 aidl_response->maxTotalMatchFilterLen = legacy_response.max_total_match_filter_len;
2194 aidl_response->maxServiceSpecificInfoLen = legacy_response.max_service_specific_info_len;
2195 aidl_response->maxExtendedServiceSpecificInfoLen =
2196 legacy_response.max_sdea_service_specific_info_len;
2197 aidl_response->maxNdiInterfaces = legacy_response.max_ndi_interfaces;
2198 aidl_response->maxNdpSessions = legacy_response.max_ndp_sessions;
2199 aidl_response->maxAppInfoLen = legacy_response.max_app_info_len;
2200 aidl_response->maxQueuedTransmitFollowupMsgs =
2201 legacy_response.max_queued_transmit_followup_msgs;
2202 aidl_response->maxSubscribeInterfaceAddresses = legacy_response.max_subscribe_address;
Gabriel Biren86971aa2023-03-03 18:04:46 +00002203 aidl_response->supportedCipherSuites = legacy_response.cipher_suites_supported;
Gabriel Birenf3262f92022-07-15 23:25:39 +00002204 aidl_response->instantCommunicationModeSupportFlag = legacy_response.is_instant_mode_supported;
Nate Jiang38e8db52022-12-02 17:30:27 -08002205 aidl_response->supports6g = legacy_response.is_6g_supported;
2206 aidl_response->supportsHe = legacy_response.is_he_supported;
2207 aidl_response->supportsPairing = legacy_response.is_pairing_supported;
Biswarup Paldc7192f2023-01-09 21:21:07 +00002208 aidl_response->supportsSetClusterId = legacy_response.is_set_cluster_id_supported;
Biswarup Pal319f99f2022-12-20 18:06:50 +00002209 aidl_response->supportsSuspension = legacy_response.is_suspension_supported;
2210
Gabriel Birenf3262f92022-07-15 23:25:39 +00002211 return true;
2212}
2213
2214bool convertLegacyNanMatchIndToAidl(const legacy_hal::NanMatchInd& legacy_ind,
2215 NanMatchInd* aidl_ind) {
2216 if (!aidl_ind) {
2217 LOG(ERROR) << "convertLegacyNanMatchIndToAidl: aidl_ind is null";
2218 return false;
2219 }
2220 *aidl_ind = {};
2221
2222 aidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
2223 aidl_ind->peerId = legacy_ind.requestor_instance_id;
2224 aidl_ind->addr = std::array<uint8_t, 6>();
2225 std::copy(legacy_ind.addr, legacy_ind.addr + 6, std::begin(aidl_ind->addr));
2226 aidl_ind->serviceSpecificInfo = std::vector<uint8_t>(
2227 legacy_ind.service_specific_info,
2228 legacy_ind.service_specific_info + legacy_ind.service_specific_info_len);
2229 aidl_ind->extendedServiceSpecificInfo = std::vector<uint8_t>(
2230 legacy_ind.sdea_service_specific_info,
2231 legacy_ind.sdea_service_specific_info + legacy_ind.sdea_service_specific_info_len);
2232 aidl_ind->matchFilter =
2233 std::vector<uint8_t>(legacy_ind.sdf_match_filter,
2234 legacy_ind.sdf_match_filter + legacy_ind.sdf_match_filter_len);
2235 aidl_ind->matchOccurredInBeaconFlag = legacy_ind.match_occured_flag == 1; // NOTYPO
2236 aidl_ind->outOfResourceFlag = legacy_ind.out_of_resource_flag == 1;
2237 aidl_ind->rssiValue = legacy_ind.rssi_value;
2238 aidl_ind->peerCipherType = (NanCipherSuiteType)legacy_ind.peer_cipher_type;
2239 aidl_ind->peerRequiresSecurityEnabledInNdp =
2240 legacy_ind.peer_sdea_params.security_cfg == legacy_hal::NAN_DP_CONFIG_SECURITY;
2241 aidl_ind->peerRequiresRanging =
2242 legacy_ind.peer_sdea_params.ranging_state == legacy_hal::NAN_RANGING_ENABLE;
2243 aidl_ind->rangingMeasurementInMm = legacy_ind.range_info.range_measurement_mm;
Gabriel Biren86971aa2023-03-03 18:04:46 +00002244 aidl_ind->rangingIndicationType = legacy_ind.range_info.ranging_event_type;
Gabriel Birenf3262f92022-07-15 23:25:39 +00002245 aidl_ind->scid = std::vector<uint8_t>(legacy_ind.scid, legacy_ind.scid + legacy_ind.scid_len);
Nate Jiang38e8db52022-12-02 17:30:27 -08002246
2247 if (!convertLegacyNiraToAidl(legacy_ind.nira, &aidl_ind->peerNira)) {
2248 LOG(ERROR) << "convertLegacyNanMatchIndToAidl: invalid NIRA";
2249 return false;
2250 }
2251 if (!convertLegacyPairingConfigToAidl(legacy_ind.peer_pairing_config,
2252 &aidl_ind->peerPairingConfig)) {
2253 LOG(ERROR) << "convertLegacyNanMatchIndToAidl: invalid pairing config";
2254 return false;
2255 }
Gabriel Birenf3262f92022-07-15 23:25:39 +00002256 return true;
2257}
2258
2259bool convertLegacyNanFollowupIndToAidl(const legacy_hal::NanFollowupInd& legacy_ind,
2260 NanFollowupReceivedInd* aidl_ind) {
2261 if (!aidl_ind) {
2262 LOG(ERROR) << "convertLegacyNanFollowupIndToAidl: aidl_ind is null";
2263 return false;
2264 }
2265 *aidl_ind = {};
2266
2267 aidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
2268 aidl_ind->peerId = legacy_ind.requestor_instance_id;
2269 aidl_ind->addr = std::array<uint8_t, 6>();
2270 std::copy(legacy_ind.addr, legacy_ind.addr + 6, std::begin(aidl_ind->addr));
2271 aidl_ind->receivedInFaw = legacy_ind.dw_or_faw == 1;
2272 aidl_ind->serviceSpecificInfo = std::vector<uint8_t>(
2273 legacy_ind.service_specific_info,
2274 legacy_ind.service_specific_info + legacy_ind.service_specific_info_len);
2275 aidl_ind->extendedServiceSpecificInfo = std::vector<uint8_t>(
2276 legacy_ind.sdea_service_specific_info,
2277 legacy_ind.sdea_service_specific_info + legacy_ind.sdea_service_specific_info_len);
2278
2279 return true;
2280}
2281
2282bool convertLegacyNanDataPathRequestIndToAidl(const legacy_hal::NanDataPathRequestInd& legacy_ind,
2283 NanDataPathRequestInd* aidl_ind) {
2284 if (!aidl_ind) {
2285 LOG(ERROR) << "convertLegacyNanDataPathRequestIndToAidl: aidl_ind is null";
2286 return false;
2287 }
2288 *aidl_ind = {};
2289
2290 aidl_ind->discoverySessionId = legacy_ind.service_instance_id;
2291 aidl_ind->peerDiscMacAddr = std::array<uint8_t, 6>();
2292 std::copy(legacy_ind.peer_disc_mac_addr, legacy_ind.peer_disc_mac_addr + 6,
2293 std::begin(aidl_ind->peerDiscMacAddr));
2294 aidl_ind->ndpInstanceId = legacy_ind.ndp_instance_id;
2295 aidl_ind->securityRequired =
2296 legacy_ind.ndp_cfg.security_cfg == legacy_hal::NAN_DP_CONFIG_SECURITY;
2297 aidl_ind->appInfo = std::vector<uint8_t>(
2298 legacy_ind.app_info.ndp_app_info,
2299 legacy_ind.app_info.ndp_app_info + legacy_ind.app_info.ndp_app_info_len);
2300
2301 return true;
2302}
2303
2304bool convertLegacyNdpChannelInfoToAidl(const legacy_hal::NanChannelInfo& legacy_struct,
2305 NanDataPathChannelInfo* aidl_struct) {
2306 if (!aidl_struct) {
2307 LOG(ERROR) << "convertLegacyNdpChannelInfoToAidl: aidl_struct is null";
2308 return false;
2309 }
2310 *aidl_struct = {};
2311
2312 aidl_struct->channelFreq = legacy_struct.channel;
2313 aidl_struct->channelBandwidth = convertLegacyWifiChannelWidthToAidl(
2314 (legacy_hal::wifi_channel_width)legacy_struct.bandwidth);
2315 aidl_struct->numSpatialStreams = legacy_struct.nss;
2316
2317 return true;
2318}
2319
2320bool convertLegacyNanDataPathConfirmIndToAidl(const legacy_hal::NanDataPathConfirmInd& legacy_ind,
2321 NanDataPathConfirmInd* aidl_ind) {
2322 if (!aidl_ind) {
2323 LOG(ERROR) << "convertLegacyNanDataPathConfirmIndToAidl: aidl_ind is null";
2324 return false;
2325 }
2326 *aidl_ind = {};
2327
2328 aidl_ind->ndpInstanceId = legacy_ind.ndp_instance_id;
2329 aidl_ind->dataPathSetupSuccess = legacy_ind.rsp_code == legacy_hal::NAN_DP_REQUEST_ACCEPT;
2330 aidl_ind->peerNdiMacAddr = std::array<uint8_t, 6>();
2331 std::copy(legacy_ind.peer_ndi_mac_addr, legacy_ind.peer_ndi_mac_addr + 6,
2332 std::begin(aidl_ind->peerNdiMacAddr));
2333 aidl_ind->appInfo = std::vector<uint8_t>(
2334 legacy_ind.app_info.ndp_app_info,
2335 legacy_ind.app_info.ndp_app_info + legacy_ind.app_info.ndp_app_info_len);
2336 aidl_ind->status.status = convertLegacyNanStatusTypeToAidl(legacy_ind.reason_code);
2337 aidl_ind->status.description = "";
2338
2339 std::vector<NanDataPathChannelInfo> channelInfo;
2340 for (unsigned int i = 0; i < legacy_ind.num_channels; ++i) {
2341 NanDataPathChannelInfo aidl_struct;
2342 if (!convertLegacyNdpChannelInfoToAidl(legacy_ind.channel_info[i], &aidl_struct)) {
2343 return false;
2344 }
2345 channelInfo.push_back(aidl_struct);
2346 }
2347 aidl_ind->channelInfo = channelInfo;
2348
2349 return true;
2350}
2351
2352bool convertLegacyNanDataPathScheduleUpdateIndToAidl(
2353 const legacy_hal::NanDataPathScheduleUpdateInd& legacy_ind,
2354 NanDataPathScheduleUpdateInd* aidl_ind) {
2355 if (!aidl_ind) {
2356 LOG(ERROR) << "convertLegacyNanDataPathScheduleUpdateIndToAidl: "
2357 "aidl_ind is null";
2358 return false;
2359 }
2360 *aidl_ind = {};
2361
2362 aidl_ind->peerDiscoveryAddress = std::array<uint8_t, 6>();
2363 std::copy(legacy_ind.peer_mac_addr, legacy_ind.peer_mac_addr + 6,
2364 std::begin(aidl_ind->peerDiscoveryAddress));
2365 std::vector<NanDataPathChannelInfo> channelInfo;
2366 for (unsigned int i = 0; i < legacy_ind.num_channels; ++i) {
2367 NanDataPathChannelInfo aidl_struct;
2368 if (!convertLegacyNdpChannelInfoToAidl(legacy_ind.channel_info[i], &aidl_struct)) {
2369 return false;
2370 }
2371 channelInfo.push_back(aidl_struct);
2372 }
2373 aidl_ind->channelInfo = channelInfo;
2374 std::vector<uint32_t> ndpInstanceIds;
2375 for (unsigned int i = 0; i < legacy_ind.num_ndp_instances; ++i) {
2376 ndpInstanceIds.push_back(legacy_ind.ndp_instance_id[i]);
2377 }
2378 aidl_ind->ndpInstanceIds = uintToIntVec(ndpInstanceIds);
2379
2380 return true;
2381}
2382
2383legacy_hal::wifi_rtt_type convertAidlRttTypeToLegacy(RttType type) {
2384 switch (type) {
2385 case RttType::ONE_SIDED:
2386 return legacy_hal::RTT_TYPE_1_SIDED;
2387 case RttType::TWO_SIDED:
2388 return legacy_hal::RTT_TYPE_2_SIDED;
2389 };
2390 CHECK(false);
2391}
2392
2393RttType convertLegacyRttTypeToAidl(legacy_hal::wifi_rtt_type type) {
2394 switch (type) {
2395 case legacy_hal::RTT_TYPE_1_SIDED:
2396 return RttType::ONE_SIDED;
2397 case legacy_hal::RTT_TYPE_2_SIDED:
2398 return RttType::TWO_SIDED;
2399 };
2400 CHECK(false) << "Unknown legacy type: " << type;
2401}
2402
2403legacy_hal::rtt_peer_type convertAidlRttPeerTypeToLegacy(RttPeerType type) {
2404 switch (type) {
2405 case RttPeerType::AP:
2406 return legacy_hal::RTT_PEER_AP;
2407 case RttPeerType::STA:
2408 return legacy_hal::RTT_PEER_STA;
2409 case RttPeerType::P2P_GO:
2410 return legacy_hal::RTT_PEER_P2P_GO;
2411 case RttPeerType::P2P_CLIENT:
2412 return legacy_hal::RTT_PEER_P2P_CLIENT;
2413 case RttPeerType::NAN_TYPE:
2414 return legacy_hal::RTT_PEER_NAN;
2415 };
2416 CHECK(false);
2417}
2418
2419legacy_hal::wifi_channel_width convertAidlWifiChannelWidthToLegacy(WifiChannelWidthInMhz type) {
2420 switch (type) {
2421 case WifiChannelWidthInMhz::WIDTH_20:
2422 return legacy_hal::WIFI_CHAN_WIDTH_20;
2423 case WifiChannelWidthInMhz::WIDTH_40:
2424 return legacy_hal::WIFI_CHAN_WIDTH_40;
2425 case WifiChannelWidthInMhz::WIDTH_80:
2426 return legacy_hal::WIFI_CHAN_WIDTH_80;
2427 case WifiChannelWidthInMhz::WIDTH_160:
2428 return legacy_hal::WIFI_CHAN_WIDTH_160;
2429 case WifiChannelWidthInMhz::WIDTH_80P80:
2430 return legacy_hal::WIFI_CHAN_WIDTH_80P80;
2431 case WifiChannelWidthInMhz::WIDTH_5:
2432 return legacy_hal::WIFI_CHAN_WIDTH_5;
2433 case WifiChannelWidthInMhz::WIDTH_10:
2434 return legacy_hal::WIFI_CHAN_WIDTH_10;
2435 case WifiChannelWidthInMhz::WIDTH_320:
2436 return legacy_hal::WIFI_CHAN_WIDTH_320;
2437 case WifiChannelWidthInMhz::WIDTH_INVALID:
2438 return legacy_hal::WIFI_CHAN_WIDTH_INVALID;
2439 };
2440 CHECK(false);
2441}
2442
2443WifiChannelWidthInMhz convertLegacyWifiChannelWidthToAidl(legacy_hal::wifi_channel_width type) {
2444 switch (type) {
2445 case legacy_hal::WIFI_CHAN_WIDTH_20:
2446 return WifiChannelWidthInMhz::WIDTH_20;
2447 case legacy_hal::WIFI_CHAN_WIDTH_40:
2448 return WifiChannelWidthInMhz::WIDTH_40;
2449 case legacy_hal::WIFI_CHAN_WIDTH_80:
2450 return WifiChannelWidthInMhz::WIDTH_80;
2451 case legacy_hal::WIFI_CHAN_WIDTH_160:
2452 return WifiChannelWidthInMhz::WIDTH_160;
2453 case legacy_hal::WIFI_CHAN_WIDTH_80P80:
2454 return WifiChannelWidthInMhz::WIDTH_80P80;
2455 case legacy_hal::WIFI_CHAN_WIDTH_5:
2456 return WifiChannelWidthInMhz::WIDTH_5;
2457 case legacy_hal::WIFI_CHAN_WIDTH_10:
2458 return WifiChannelWidthInMhz::WIDTH_10;
2459 case legacy_hal::WIFI_CHAN_WIDTH_320:
2460 return WifiChannelWidthInMhz::WIDTH_320;
2461 default:
2462 return WifiChannelWidthInMhz::WIDTH_INVALID;
2463 };
2464}
2465
2466legacy_hal::wifi_rtt_preamble convertAidlRttPreambleToLegacy(RttPreamble type) {
2467 switch (type) {
2468 case RttPreamble::LEGACY:
2469 return legacy_hal::WIFI_RTT_PREAMBLE_LEGACY;
2470 case RttPreamble::HT:
2471 return legacy_hal::WIFI_RTT_PREAMBLE_HT;
2472 case RttPreamble::VHT:
2473 return legacy_hal::WIFI_RTT_PREAMBLE_VHT;
2474 case RttPreamble::HE:
2475 return legacy_hal::WIFI_RTT_PREAMBLE_HE;
2476 case RttPreamble::EHT:
2477 return legacy_hal::WIFI_RTT_PREAMBLE_EHT;
2478 };
2479 CHECK(false);
2480}
2481
2482RttPreamble convertLegacyRttPreambleToAidl(legacy_hal::wifi_rtt_preamble type) {
2483 switch (type) {
2484 case legacy_hal::WIFI_RTT_PREAMBLE_LEGACY:
2485 return RttPreamble::LEGACY;
2486 case legacy_hal::WIFI_RTT_PREAMBLE_HT:
2487 return RttPreamble::HT;
2488 case legacy_hal::WIFI_RTT_PREAMBLE_VHT:
2489 return RttPreamble::VHT;
2490 case legacy_hal::WIFI_RTT_PREAMBLE_HE:
2491 return RttPreamble::HE;
2492 case legacy_hal::WIFI_RTT_PREAMBLE_EHT:
2493 return RttPreamble::EHT;
2494 };
2495 CHECK(false) << "Unknown legacy type: " << type;
2496}
2497
2498legacy_hal::wifi_rtt_bw convertAidlRttBwToLegacy(RttBw type) {
2499 switch (type) {
2500 case RttBw::BW_5MHZ:
2501 return legacy_hal::WIFI_RTT_BW_5;
2502 case RttBw::BW_10MHZ:
2503 return legacy_hal::WIFI_RTT_BW_10;
2504 case RttBw::BW_20MHZ:
2505 return legacy_hal::WIFI_RTT_BW_20;
2506 case RttBw::BW_40MHZ:
2507 return legacy_hal::WIFI_RTT_BW_40;
2508 case RttBw::BW_80MHZ:
2509 return legacy_hal::WIFI_RTT_BW_80;
2510 case RttBw::BW_160MHZ:
2511 return legacy_hal::WIFI_RTT_BW_160;
2512 case RttBw::BW_320MHZ:
2513 return legacy_hal::WIFI_RTT_BW_320;
Sunil Ravif8fc2372022-11-10 18:37:41 +00002514 case RttBw::BW_UNSPECIFIED:
2515 return legacy_hal::WIFI_RTT_BW_UNSPECIFIED;
Gabriel Birenf3262f92022-07-15 23:25:39 +00002516 };
2517 CHECK(false);
2518}
2519
2520RttBw convertLegacyRttBwToAidl(legacy_hal::wifi_rtt_bw type) {
2521 switch (type) {
2522 case legacy_hal::WIFI_RTT_BW_5:
2523 return RttBw::BW_5MHZ;
2524 case legacy_hal::WIFI_RTT_BW_10:
2525 return RttBw::BW_10MHZ;
2526 case legacy_hal::WIFI_RTT_BW_20:
2527 return RttBw::BW_20MHZ;
2528 case legacy_hal::WIFI_RTT_BW_40:
2529 return RttBw::BW_40MHZ;
2530 case legacy_hal::WIFI_RTT_BW_80:
2531 return RttBw::BW_80MHZ;
2532 case legacy_hal::WIFI_RTT_BW_160:
2533 return RttBw::BW_160MHZ;
2534 case legacy_hal::WIFI_RTT_BW_320:
2535 return RttBw::BW_320MHZ;
Sunil Ravif8fc2372022-11-10 18:37:41 +00002536 case legacy_hal::WIFI_RTT_BW_UNSPECIFIED:
2537 return RttBw::BW_UNSPECIFIED;
Gabriel Birenf3262f92022-07-15 23:25:39 +00002538 };
2539 CHECK(false) << "Unknown legacy type: " << type;
2540}
2541
2542legacy_hal::wifi_motion_pattern convertAidlRttMotionPatternToLegacy(RttMotionPattern type) {
2543 switch (type) {
2544 case RttMotionPattern::NOT_EXPECTED:
2545 return legacy_hal::WIFI_MOTION_NOT_EXPECTED;
2546 case RttMotionPattern::EXPECTED:
2547 return legacy_hal::WIFI_MOTION_EXPECTED;
2548 case RttMotionPattern::UNKNOWN:
2549 return legacy_hal::WIFI_MOTION_UNKNOWN;
2550 };
2551 CHECK(false);
2552}
2553
2554WifiRatePreamble convertLegacyWifiRatePreambleToAidl(uint8_t preamble) {
2555 switch (preamble) {
2556 case 0:
2557 return WifiRatePreamble::OFDM;
2558 case 1:
2559 return WifiRatePreamble::CCK;
2560 case 2:
2561 return WifiRatePreamble::HT;
2562 case 3:
2563 return WifiRatePreamble::VHT;
2564 case 4:
2565 return WifiRatePreamble::HE;
2566 case 5:
2567 return WifiRatePreamble::EHT;
2568 default:
2569 return WifiRatePreamble::RESERVED;
2570 };
2571 CHECK(false) << "Unknown legacy preamble: " << preamble;
2572}
2573
2574WifiRateNss convertLegacyWifiRateNssToAidl(uint8_t nss) {
2575 switch (nss) {
2576 case 0:
2577 return WifiRateNss::NSS_1x1;
2578 case 1:
2579 return WifiRateNss::NSS_2x2;
2580 case 2:
2581 return WifiRateNss::NSS_3x3;
2582 case 3:
2583 return WifiRateNss::NSS_4x4;
2584 };
2585 CHECK(false) << "Unknown legacy nss: " << nss;
2586 return {};
2587}
2588
2589RttStatus convertLegacyRttStatusToAidl(legacy_hal::wifi_rtt_status status) {
2590 switch (status) {
2591 case legacy_hal::RTT_STATUS_SUCCESS:
2592 return RttStatus::SUCCESS;
2593 case legacy_hal::RTT_STATUS_FAILURE:
2594 return RttStatus::FAILURE;
2595 case legacy_hal::RTT_STATUS_FAIL_NO_RSP:
2596 return RttStatus::FAIL_NO_RSP;
2597 case legacy_hal::RTT_STATUS_FAIL_REJECTED:
2598 return RttStatus::FAIL_REJECTED;
2599 case legacy_hal::RTT_STATUS_FAIL_NOT_SCHEDULED_YET:
2600 return RttStatus::FAIL_NOT_SCHEDULED_YET;
2601 case legacy_hal::RTT_STATUS_FAIL_TM_TIMEOUT:
2602 return RttStatus::FAIL_TM_TIMEOUT;
2603 case legacy_hal::RTT_STATUS_FAIL_AP_ON_DIFF_CHANNEL:
2604 return RttStatus::FAIL_AP_ON_DIFF_CHANNEL;
2605 case legacy_hal::RTT_STATUS_FAIL_NO_CAPABILITY:
2606 return RttStatus::FAIL_NO_CAPABILITY;
2607 case legacy_hal::RTT_STATUS_ABORTED:
2608 return RttStatus::ABORTED;
2609 case legacy_hal::RTT_STATUS_FAIL_INVALID_TS:
2610 return RttStatus::FAIL_INVALID_TS;
2611 case legacy_hal::RTT_STATUS_FAIL_PROTOCOL:
2612 return RttStatus::FAIL_PROTOCOL;
2613 case legacy_hal::RTT_STATUS_FAIL_SCHEDULE:
2614 return RttStatus::FAIL_SCHEDULE;
2615 case legacy_hal::RTT_STATUS_FAIL_BUSY_TRY_LATER:
2616 return RttStatus::FAIL_BUSY_TRY_LATER;
2617 case legacy_hal::RTT_STATUS_INVALID_REQ:
2618 return RttStatus::INVALID_REQ;
2619 case legacy_hal::RTT_STATUS_NO_WIFI:
2620 return RttStatus::NO_WIFI;
2621 case legacy_hal::RTT_STATUS_FAIL_FTM_PARAM_OVERRIDE:
2622 return RttStatus::FAIL_FTM_PARAM_OVERRIDE;
2623 case legacy_hal::RTT_STATUS_NAN_RANGING_PROTOCOL_FAILURE:
2624 return RttStatus::NAN_RANGING_PROTOCOL_FAILURE;
2625 case legacy_hal::RTT_STATUS_NAN_RANGING_CONCURRENCY_NOT_SUPPORTED:
2626 return RttStatus::NAN_RANGING_CONCURRENCY_NOT_SUPPORTED;
2627 };
2628 CHECK(false) << "Unknown legacy status: " << status;
2629}
2630
2631bool convertAidlWifiChannelInfoToLegacy(const WifiChannelInfo& aidl_info,
2632 legacy_hal::wifi_channel_info* legacy_info) {
2633 if (!legacy_info) {
2634 return false;
2635 }
2636 *legacy_info = {};
2637 legacy_info->width = convertAidlWifiChannelWidthToLegacy(aidl_info.width);
2638 legacy_info->center_freq = aidl_info.centerFreq;
2639 legacy_info->center_freq0 = aidl_info.centerFreq0;
2640 legacy_info->center_freq1 = aidl_info.centerFreq1;
2641 return true;
2642}
2643
2644bool convertLegacyWifiChannelInfoToAidl(const legacy_hal::wifi_channel_info& legacy_info,
2645 WifiChannelInfo* aidl_info) {
2646 if (!aidl_info) {
2647 return false;
2648 }
2649 *aidl_info = {};
2650 aidl_info->width = convertLegacyWifiChannelWidthToAidl(legacy_info.width);
2651 aidl_info->centerFreq = legacy_info.center_freq;
2652 aidl_info->centerFreq0 = legacy_info.center_freq0;
2653 aidl_info->centerFreq1 = legacy_info.center_freq1;
2654 return true;
2655}
2656
2657bool convertAidlRttConfigToLegacy(const RttConfig& aidl_config,
2658 legacy_hal::wifi_rtt_config* legacy_config) {
2659 if (!legacy_config) {
2660 return false;
2661 }
2662 *legacy_config = {};
2663 CHECK(aidl_config.addr.size() == sizeof(legacy_config->addr));
2664 memcpy(legacy_config->addr, aidl_config.addr.data(), aidl_config.addr.size());
2665 legacy_config->type = convertAidlRttTypeToLegacy(aidl_config.type);
2666 legacy_config->peer = convertAidlRttPeerTypeToLegacy(aidl_config.peer);
2667 if (!convertAidlWifiChannelInfoToLegacy(aidl_config.channel, &legacy_config->channel)) {
2668 return false;
2669 }
2670 legacy_config->burst_period = aidl_config.burstPeriod;
2671 legacy_config->num_burst = aidl_config.numBurst;
2672 legacy_config->num_frames_per_burst = aidl_config.numFramesPerBurst;
2673 legacy_config->num_retries_per_rtt_frame = aidl_config.numRetriesPerRttFrame;
2674 legacy_config->num_retries_per_ftmr = aidl_config.numRetriesPerFtmr;
2675 legacy_config->LCI_request = aidl_config.mustRequestLci;
2676 legacy_config->LCR_request = aidl_config.mustRequestLcr;
2677 legacy_config->burst_duration = aidl_config.burstDuration;
2678 legacy_config->preamble = convertAidlRttPreambleToLegacy(aidl_config.preamble);
2679 legacy_config->bw = convertAidlRttBwToLegacy(aidl_config.bw);
2680 return true;
2681}
2682
2683bool convertAidlVectorOfRttConfigToLegacy(
2684 const std::vector<RttConfig>& aidl_configs,
2685 std::vector<legacy_hal::wifi_rtt_config>* legacy_configs) {
2686 if (!legacy_configs) {
2687 return false;
2688 }
2689 *legacy_configs = {};
2690 for (const auto& aidl_config : aidl_configs) {
2691 legacy_hal::wifi_rtt_config legacy_config;
2692 if (!convertAidlRttConfigToLegacy(aidl_config, &legacy_config)) {
2693 return false;
2694 }
2695 legacy_configs->push_back(legacy_config);
2696 }
2697 return true;
2698}
2699
2700bool convertAidlRttLciInformationToLegacy(const RttLciInformation& aidl_info,
2701 legacy_hal::wifi_lci_information* legacy_info) {
2702 if (!legacy_info) {
2703 return false;
2704 }
2705 *legacy_info = {};
2706 legacy_info->latitude = aidl_info.latitude;
2707 legacy_info->longitude = aidl_info.longitude;
2708 legacy_info->altitude = aidl_info.altitude;
2709 legacy_info->latitude_unc = aidl_info.latitudeUnc;
2710 legacy_info->longitude_unc = aidl_info.longitudeUnc;
2711 legacy_info->altitude_unc = aidl_info.altitudeUnc;
2712 legacy_info->motion_pattern = convertAidlRttMotionPatternToLegacy(aidl_info.motionPattern);
2713 legacy_info->floor = aidl_info.floor;
2714 legacy_info->height_above_floor = aidl_info.heightAboveFloor;
2715 legacy_info->height_unc = aidl_info.heightUnc;
2716 return true;
2717}
2718
2719bool convertAidlRttLcrInformationToLegacy(const RttLcrInformation& aidl_info,
2720 legacy_hal::wifi_lcr_information* legacy_info) {
2721 if (!legacy_info) {
2722 return false;
2723 }
2724 *legacy_info = {};
2725 CHECK(aidl_info.countryCode.size() == sizeof(legacy_info->country_code));
2726 memcpy(legacy_info->country_code, aidl_info.countryCode.data(), aidl_info.countryCode.size());
2727 if (aidl_info.civicInfo.size() > sizeof(legacy_info->civic_info)) {
2728 return false;
2729 }
2730 legacy_info->length = aidl_info.civicInfo.size();
2731 memcpy(legacy_info->civic_info, aidl_info.civicInfo.c_str(), aidl_info.civicInfo.size());
2732 return true;
2733}
2734
2735bool convertAidlRttResponderToLegacy(const RttResponder& aidl_responder,
2736 legacy_hal::wifi_rtt_responder* legacy_responder) {
2737 if (!legacy_responder) {
2738 return false;
2739 }
2740 *legacy_responder = {};
2741 if (!convertAidlWifiChannelInfoToLegacy(aidl_responder.channel, &legacy_responder->channel)) {
2742 return false;
2743 }
2744 legacy_responder->preamble = convertAidlRttPreambleToLegacy(aidl_responder.preamble);
2745 return true;
2746}
2747
2748bool convertLegacyRttResponderToAidl(const legacy_hal::wifi_rtt_responder& legacy_responder,
2749 RttResponder* aidl_responder) {
2750 if (!aidl_responder) {
2751 return false;
2752 }
2753 *aidl_responder = {};
2754 if (!convertLegacyWifiChannelInfoToAidl(legacy_responder.channel, &aidl_responder->channel)) {
2755 return false;
2756 }
2757 aidl_responder->preamble = convertLegacyRttPreambleToAidl(legacy_responder.preamble);
2758 return true;
2759}
2760
2761bool convertLegacyRttCapabilitiesToAidl(
2762 const legacy_hal::wifi_rtt_capabilities& legacy_capabilities,
2763 RttCapabilities* aidl_capabilities) {
2764 if (!aidl_capabilities) {
2765 return false;
2766 }
2767 *aidl_capabilities = {};
2768 aidl_capabilities->rttOneSidedSupported = legacy_capabilities.rtt_one_sided_supported;
2769 aidl_capabilities->rttFtmSupported = legacy_capabilities.rtt_ftm_supported;
2770 aidl_capabilities->lciSupported = legacy_capabilities.lci_support;
2771 aidl_capabilities->lcrSupported = legacy_capabilities.lcr_support;
2772 aidl_capabilities->responderSupported = legacy_capabilities.responder_supported;
2773 int32_t preambleSupport = 0;
2774 for (const auto flag : {legacy_hal::WIFI_RTT_PREAMBLE_LEGACY, legacy_hal::WIFI_RTT_PREAMBLE_HT,
2775 legacy_hal::WIFI_RTT_PREAMBLE_VHT, legacy_hal::WIFI_RTT_PREAMBLE_HE,
2776 legacy_hal::WIFI_RTT_PREAMBLE_EHT}) {
2777 if (legacy_capabilities.preamble_support & flag) {
2778 preambleSupport |= static_cast<std::underlying_type<RttPreamble>::type>(
2779 convertLegacyRttPreambleToAidl(flag));
2780 }
2781 }
2782 aidl_capabilities->preambleSupport = static_cast<RttPreamble>(preambleSupport);
2783 int32_t bwSupport = 0;
2784 for (const auto flag :
2785 {legacy_hal::WIFI_RTT_BW_5, legacy_hal::WIFI_RTT_BW_10, legacy_hal::WIFI_RTT_BW_20,
2786 legacy_hal::WIFI_RTT_BW_40, legacy_hal::WIFI_RTT_BW_80, legacy_hal::WIFI_RTT_BW_160,
2787 legacy_hal::WIFI_RTT_BW_320}) {
2788 if (legacy_capabilities.bw_support & flag) {
2789 bwSupport |=
2790 static_cast<std::underlying_type<RttBw>::type>(convertLegacyRttBwToAidl(flag));
2791 }
2792 }
2793 aidl_capabilities->bwSupport = static_cast<RttBw>(bwSupport);
2794 aidl_capabilities->mcVersion = legacy_capabilities.mc_version;
2795 return true;
2796}
2797
2798bool convertLegacyWifiRateInfoToAidl(const legacy_hal::wifi_rate& legacy_rate,
2799 WifiRateInfo* aidl_rate) {
2800 if (!aidl_rate) {
2801 return false;
2802 }
2803 *aidl_rate = {};
2804 aidl_rate->preamble = convertLegacyWifiRatePreambleToAidl(legacy_rate.preamble);
2805 aidl_rate->nss = convertLegacyWifiRateNssToAidl(legacy_rate.nss);
2806 aidl_rate->bw = convertLegacyWifiChannelWidthToAidl(
2807 static_cast<legacy_hal::wifi_channel_width>(legacy_rate.bw));
2808 aidl_rate->rateMcsIdx = legacy_rate.rateMcsIdx;
2809 aidl_rate->bitRateInKbps = legacy_rate.bitrate;
2810 return true;
2811}
2812
2813bool convertLegacyRttResultToAidl(const legacy_hal::wifi_rtt_result& legacy_result,
2814 RttResult* aidl_result) {
2815 if (!aidl_result) {
2816 return false;
2817 }
2818 *aidl_result = {};
2819 aidl_result->addr = std::array<uint8_t, 6>();
2820 CHECK(sizeof(legacy_result.addr) == aidl_result->addr.size());
2821 std::copy(legacy_result.addr, legacy_result.addr + 6, std::begin(aidl_result->addr));
2822 aidl_result->burstNum = legacy_result.burst_num;
2823 aidl_result->measurementNumber = legacy_result.measurement_number;
2824 aidl_result->successNumber = legacy_result.success_number;
2825 aidl_result->numberPerBurstPeer = legacy_result.number_per_burst_peer;
2826 aidl_result->status = convertLegacyRttStatusToAidl(legacy_result.status);
2827 aidl_result->retryAfterDuration = legacy_result.retry_after_duration;
2828 aidl_result->type = convertLegacyRttTypeToAidl(legacy_result.type);
2829 aidl_result->rssi = legacy_result.rssi;
2830 aidl_result->rssiSpread = legacy_result.rssi_spread;
2831 if (!convertLegacyWifiRateInfoToAidl(legacy_result.tx_rate, &aidl_result->txRate)) {
2832 return false;
2833 }
2834 if (!convertLegacyWifiRateInfoToAidl(legacy_result.rx_rate, &aidl_result->rxRate)) {
2835 return false;
2836 }
2837 aidl_result->rtt = legacy_result.rtt;
2838 aidl_result->rttSd = legacy_result.rtt_sd;
2839 aidl_result->rttSpread = legacy_result.rtt_spread;
2840 aidl_result->distanceInMm = legacy_result.distance_mm;
2841 aidl_result->distanceSdInMm = legacy_result.distance_sd_mm;
2842 aidl_result->distanceSpreadInMm = legacy_result.distance_spread_mm;
2843 aidl_result->timeStampInUs = legacy_result.ts;
2844 aidl_result->burstDurationInMs = legacy_result.burst_duration;
2845 aidl_result->negotiatedBurstNum = legacy_result.negotiated_burst_num;
2846 if (legacy_result.LCI && !convertLegacyIeToAidl(*legacy_result.LCI, &aidl_result->lci)) {
2847 return false;
2848 }
2849 if (legacy_result.LCR && !convertLegacyIeToAidl(*legacy_result.LCR, &aidl_result->lcr)) {
2850 return false;
2851 }
2852 return true;
2853}
2854
2855bool convertLegacyVectorOfRttResultToAidl(
2856 const std::vector<const legacy_hal::wifi_rtt_result*>& legacy_results,
2857 std::vector<RttResult>* aidl_results) {
2858 if (!aidl_results) {
2859 return false;
2860 }
2861 *aidl_results = {};
2862 for (const auto legacy_result : legacy_results) {
2863 RttResult aidl_result;
2864 if (!convertLegacyRttResultToAidl(*legacy_result, &aidl_result)) {
2865 return false;
2866 }
Sunil Ravif8fc2372022-11-10 18:37:41 +00002867 aidl_result.channelFreqMHz = 0;
2868 aidl_result.packetBw = RttBw::BW_UNSPECIFIED;
2869 aidl_results->push_back(aidl_result);
2870 }
2871 return true;
2872}
2873
2874bool convertLegacyVectorOfRttResultV2ToAidl(
2875 const std::vector<const legacy_hal::wifi_rtt_result_v2*>& legacy_results,
2876 std::vector<RttResult>* aidl_results) {
2877 if (!aidl_results) {
2878 return false;
2879 }
2880 *aidl_results = {};
2881 for (const auto legacy_result : legacy_results) {
2882 RttResult aidl_result;
2883 if (!convertLegacyRttResultToAidl(legacy_result->rtt_result, &aidl_result)) {
2884 return false;
2885 }
2886 aidl_result.channelFreqMHz =
2887 legacy_result->frequency != UNSPECIFIED ? legacy_result->frequency : 0;
2888 aidl_result.packetBw = convertLegacyRttBwToAidl(legacy_result->packet_bw);
Gabriel Birenf3262f92022-07-15 23:25:39 +00002889 aidl_results->push_back(aidl_result);
2890 }
2891 return true;
2892}
2893
2894legacy_hal::wifi_interface_type convertAidlIfaceTypeToLegacy(IfaceType aidl_interface_type) {
2895 switch (aidl_interface_type) {
2896 case IfaceType::STA:
2897 return legacy_hal::WIFI_INTERFACE_TYPE_STA;
2898 case IfaceType::AP:
2899 return legacy_hal::WIFI_INTERFACE_TYPE_AP;
2900 case IfaceType::P2P:
2901 return legacy_hal::WIFI_INTERFACE_TYPE_P2P;
2902 case IfaceType::NAN_IFACE:
2903 return legacy_hal::WIFI_INTERFACE_TYPE_NAN;
2904 }
2905 CHECK(false);
2906}
2907
2908legacy_hal::wifi_multi_sta_use_case convertAidlMultiStaUseCaseToLegacy(
2909 IWifiChip::MultiStaUseCase use_case) {
2910 switch (use_case) {
2911 case IWifiChip::MultiStaUseCase::DUAL_STA_TRANSIENT_PREFER_PRIMARY:
2912 return legacy_hal::WIFI_DUAL_STA_TRANSIENT_PREFER_PRIMARY;
2913 case IWifiChip::MultiStaUseCase::DUAL_STA_NON_TRANSIENT_UNBIASED:
2914 return legacy_hal::WIFI_DUAL_STA_NON_TRANSIENT_UNBIASED;
2915 }
2916 CHECK(false);
2917}
2918
2919bool convertAidlCoexUnsafeChannelToLegacy(
2920 const IWifiChip::CoexUnsafeChannel& aidl_unsafe_channel,
2921 legacy_hal::wifi_coex_unsafe_channel* legacy_unsafe_channel) {
2922 if (!legacy_unsafe_channel) {
2923 return false;
2924 }
2925 *legacy_unsafe_channel = {};
2926 switch (aidl_unsafe_channel.band) {
2927 case WifiBand::BAND_24GHZ:
2928 legacy_unsafe_channel->band = legacy_hal::WLAN_MAC_2_4_BAND;
2929 break;
2930 case WifiBand::BAND_5GHZ:
2931 legacy_unsafe_channel->band = legacy_hal::WLAN_MAC_5_0_BAND;
2932 break;
2933 default:
2934 return false;
2935 };
2936 legacy_unsafe_channel->channel = aidl_unsafe_channel.channel;
2937 legacy_unsafe_channel->power_cap_dbm = aidl_unsafe_channel.powerCapDbm;
2938 return true;
2939}
2940
2941bool convertAidlVectorOfCoexUnsafeChannelToLegacy(
2942 const std::vector<IWifiChip::CoexUnsafeChannel>& aidl_unsafe_channels,
2943 std::vector<legacy_hal::wifi_coex_unsafe_channel>* legacy_unsafe_channels) {
2944 if (!legacy_unsafe_channels) {
2945 return false;
2946 }
2947 *legacy_unsafe_channels = {};
2948 for (const auto& aidl_unsafe_channel : aidl_unsafe_channels) {
2949 legacy_hal::wifi_coex_unsafe_channel legacy_unsafe_channel;
2950 if (!aidl_struct_util::convertAidlCoexUnsafeChannelToLegacy(aidl_unsafe_channel,
2951 &legacy_unsafe_channel)) {
2952 return false;
2953 }
2954 legacy_unsafe_channels->push_back(legacy_unsafe_channel);
2955 }
2956 return true;
2957}
2958
2959WifiAntennaMode convertLegacyAntennaConfigurationToAidl(uint32_t antenna_cfg) {
2960 switch (antenna_cfg) {
2961 case legacy_hal::WIFI_ANTENNA_1X1:
2962 return WifiAntennaMode::WIFI_ANTENNA_MODE_1X1;
2963 case legacy_hal::WIFI_ANTENNA_2X2:
2964 return WifiAntennaMode::WIFI_ANTENNA_MODE_2X2;
2965 case legacy_hal::WIFI_ANTENNA_3X3:
2966 return WifiAntennaMode::WIFI_ANTENNA_MODE_3X3;
2967 case legacy_hal::WIFI_ANTENNA_4X4:
2968 return WifiAntennaMode::WIFI_ANTENNA_MODE_4X4;
2969 default:
2970 return WifiAntennaMode::WIFI_ANTENNA_MODE_UNSPECIFIED;
2971 }
2972}
2973
2974bool convertLegacyWifiRadioConfigurationToAidl(
2975 legacy_hal::wifi_radio_configuration* radio_configuration,
2976 WifiRadioConfiguration* aidl_radio_configuration) {
2977 if (!aidl_radio_configuration) {
2978 return false;
2979 }
2980 *aidl_radio_configuration = {};
2981 aidl_radio_configuration->bandInfo =
2982 aidl_struct_util::convertLegacyMacBandToAidlWifiBand(radio_configuration->band);
2983 if (aidl_radio_configuration->bandInfo == WifiBand::BAND_UNSPECIFIED) {
2984 LOG(ERROR) << "Unspecified band";
2985 return false;
2986 }
2987 aidl_radio_configuration->antennaMode =
2988 aidl_struct_util::convertLegacyAntennaConfigurationToAidl(
2989 radio_configuration->antenna_cfg);
2990 return true;
2991}
2992
2993bool convertLegacyRadioCombinationsMatrixToAidl(
2994 legacy_hal::wifi_radio_combination_matrix* legacy_matrix,
Gabriel Biren263db452023-02-24 21:07:38 +00002995 std::vector<WifiRadioCombination>* aidl_combinations) {
2996 if (!aidl_combinations || !legacy_matrix) {
Gabriel Birenf3262f92022-07-15 23:25:39 +00002997 return false;
2998 }
Gabriel Biren263db452023-02-24 21:07:38 +00002999 *aidl_combinations = {};
Gabriel Birenf3262f92022-07-15 23:25:39 +00003000
3001 int num_combinations = legacy_matrix->num_radio_combinations;
Gabriel Birenf3262f92022-07-15 23:25:39 +00003002 if (!num_combinations) {
3003 LOG(ERROR) << "zero radio combinations";
3004 return false;
3005 }
3006 wifi_radio_combination* l_radio_combinations_ptr = legacy_matrix->radio_combinations;
3007 for (int i = 0; i < num_combinations; i++) {
3008 int num_configurations = l_radio_combinations_ptr->num_radio_configurations;
3009 WifiRadioCombination radioCombination;
3010 std::vector<WifiRadioConfiguration> radio_configurations_vec;
3011 if (!num_configurations) {
3012 LOG(ERROR) << "zero radio configurations";
3013 return false;
3014 }
3015 for (int j = 0; j < num_configurations; j++) {
3016 WifiRadioConfiguration radioConfiguration;
3017 wifi_radio_configuration* l_radio_configurations_ptr =
3018 &l_radio_combinations_ptr->radio_configurations[j];
3019 if (!aidl_struct_util::convertLegacyWifiRadioConfigurationToAidl(
3020 l_radio_configurations_ptr, &radioConfiguration)) {
3021 LOG(ERROR) << "Error converting wifi radio configuration";
3022 return false;
3023 }
3024 radio_configurations_vec.push_back(radioConfiguration);
3025 }
3026 radioCombination.radioConfigurations = radio_configurations_vec;
Gabriel Biren263db452023-02-24 21:07:38 +00003027 aidl_combinations->push_back(radioCombination);
Gabriel Birenf3262f92022-07-15 23:25:39 +00003028 l_radio_combinations_ptr =
3029 (wifi_radio_combination*)((u8*)l_radio_combinations_ptr +
3030 sizeof(wifi_radio_combination) +
3031 (sizeof(wifi_radio_configuration) * num_configurations));
3032 }
Gabriel Birenf3262f92022-07-15 23:25:39 +00003033 return true;
3034}
3035
Nate Jiang38e8db52022-12-02 17:30:27 -08003036bool convertAidlNanPairingInitiatorRequestToLegacy(const NanPairingRequest& aidl_request,
3037 legacy_hal::NanPairingRequest* legacy_request) {
3038 if (!legacy_request) {
3039 LOG(ERROR) << "convertAidlNanPairingInitiatorRequestToLegacy: "
3040 "legacy_request is null";
3041 return false;
3042 }
3043 *legacy_request = {};
3044
3045 legacy_request->requestor_instance_id = aidl_request.peerId;
3046 memcpy(legacy_request->peer_disc_mac_addr, aidl_request.peerDiscMacAddr.data(), 6);
3047 legacy_request->nan_pairing_request_type =
3048 convertAidlNanPairingRequestTypeToLegacy(aidl_request.requestType);
3049 legacy_request->enable_pairing_cache = aidl_request.enablePairingCache;
3050
3051 memcpy(legacy_request->nan_identity_key, aidl_request.pairingIdentityKey.data(),
3052 NAN_IDENTITY_KEY_LEN);
3053
3054 legacy_request->is_opportunistic =
3055 aidl_request.securityConfig.securityType == NanPairingSecurityType::OPPORTUNISTIC ? 1
3056 : 0;
3057 legacy_request->akm = convertAidlAkmTypeToLegacy(aidl_request.securityConfig.akm);
Nate Jiangbae6fdd2023-02-10 17:16:40 -08003058 legacy_request->cipher_type = (unsigned int)aidl_request.securityConfig.cipherType;
Nate Jiang38e8db52022-12-02 17:30:27 -08003059 if (aidl_request.securityConfig.securityType == NanPairingSecurityType::PMK) {
3060 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
3061 legacy_request->key_info.body.pmk_info.pmk_len = aidl_request.securityConfig.pmk.size();
3062 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
3063 LOG(ERROR) << "convertAidlNanPairingInitiatorRequestToLegacy: "
3064 "invalid pmk_len";
3065 return false;
3066 }
3067 memcpy(legacy_request->key_info.body.pmk_info.pmk, aidl_request.securityConfig.pmk.data(),
3068 legacy_request->key_info.body.pmk_info.pmk_len);
3069 }
3070 if (aidl_request.securityConfig.securityType == NanPairingSecurityType::PASSPHRASE) {
3071 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
3072 legacy_request->key_info.body.passphrase_info.passphrase_len =
3073 aidl_request.securityConfig.passphrase.size();
3074 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
3075 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
3076 LOG(ERROR) << "convertAidlNanPairingInitiatorRequestToLegacy: "
3077 "passphrase_len too small";
3078 return false;
3079 }
3080 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
3081 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
3082 LOG(ERROR) << "convertAidlNanPairingInitiatorRequestToLegacy: "
3083 "passphrase_len too large";
3084 return false;
3085 }
3086 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
3087 aidl_request.securityConfig.passphrase.data(),
3088 legacy_request->key_info.body.passphrase_info.passphrase_len);
3089 }
3090
3091 return true;
3092}
3093
3094bool convertAidlNanPairingIndicationResponseToLegacy(
3095 const NanRespondToPairingIndicationRequest& aidl_request,
3096 legacy_hal::NanPairingIndicationResponse* legacy_request) {
3097 if (!legacy_request) {
3098 LOG(ERROR) << "convertAidlNanPairingIndicationResponseToLegacy: "
3099 "legacy_request is null";
3100 return false;
3101 }
3102 *legacy_request = {};
3103
3104 legacy_request->pairing_instance_id = aidl_request.pairingInstanceId;
3105 legacy_request->nan_pairing_request_type =
3106 convertAidlNanPairingRequestTypeToLegacy(aidl_request.requestType);
3107 legacy_request->enable_pairing_cache = aidl_request.enablePairingCache;
3108
3109 memcpy(legacy_request->nan_identity_key, aidl_request.pairingIdentityKey.data(),
3110 NAN_IDENTITY_KEY_LEN);
3111
3112 legacy_request->is_opportunistic =
3113 aidl_request.securityConfig.securityType == NanPairingSecurityType::OPPORTUNISTIC ? 1
3114 : 0;
3115 legacy_request->akm = convertAidlAkmTypeToLegacy(aidl_request.securityConfig.akm);
Nate Jiangbae6fdd2023-02-10 17:16:40 -08003116 legacy_request->cipher_type = (unsigned int)aidl_request.securityConfig.cipherType;
Nate Jiang38e8db52022-12-02 17:30:27 -08003117 legacy_request->rsp_code =
3118 aidl_request.acceptRequest ? NAN_PAIRING_REQUEST_ACCEPT : NAN_PAIRING_REQUEST_REJECT;
3119 if (aidl_request.securityConfig.securityType == NanPairingSecurityType::PMK) {
3120 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PMK;
3121 legacy_request->key_info.body.pmk_info.pmk_len = aidl_request.securityConfig.pmk.size();
3122 if (legacy_request->key_info.body.pmk_info.pmk_len != NAN_PMK_INFO_LEN) {
3123 LOG(ERROR) << "convertAidlNanPairingIndicationResponseToLegacy: "
3124 "invalid pmk_len";
3125 return false;
3126 }
3127 memcpy(legacy_request->key_info.body.pmk_info.pmk, aidl_request.securityConfig.pmk.data(),
3128 legacy_request->key_info.body.pmk_info.pmk_len);
3129 }
3130 if (aidl_request.securityConfig.securityType == NanPairingSecurityType::PASSPHRASE) {
3131 legacy_request->key_info.key_type = legacy_hal::NAN_SECURITY_KEY_INPUT_PASSPHRASE;
3132 legacy_request->key_info.body.passphrase_info.passphrase_len =
3133 aidl_request.securityConfig.passphrase.size();
3134 if (legacy_request->key_info.body.passphrase_info.passphrase_len <
3135 NAN_SECURITY_MIN_PASSPHRASE_LEN) {
3136 LOG(ERROR) << "convertAidlNanPairingIndicationResponseToLegacy: "
3137 "passphrase_len too small";
3138 return false;
3139 }
3140 if (legacy_request->key_info.body.passphrase_info.passphrase_len >
3141 NAN_SECURITY_MAX_PASSPHRASE_LEN) {
3142 LOG(ERROR) << "convertAidlNanPairingIndicationResponseToLegacy: "
3143 "passphrase_len too large";
3144 return false;
3145 }
3146 memcpy(legacy_request->key_info.body.passphrase_info.passphrase,
3147 aidl_request.securityConfig.passphrase.data(),
3148 legacy_request->key_info.body.passphrase_info.passphrase_len);
3149 }
3150
3151 return true;
3152}
3153
3154bool convertAidlNanBootstrappingInitiatorRequestToLegacy(
3155 const NanBootstrappingRequest& aidl_request,
3156 legacy_hal::NanBootstrappingRequest* legacy_request) {
3157 if (!legacy_request) {
3158 LOG(ERROR) << "convertAidlNanBootstrappingInitiatorRequestToLegacy: "
3159 "legacy_request is null";
3160 return false;
3161 }
3162 *legacy_request = {};
3163
3164 legacy_request->requestor_instance_id = aidl_request.peerId;
3165 memcpy(legacy_request->peer_disc_mac_addr, aidl_request.peerDiscMacAddr.data(), 6);
3166 legacy_request->request_bootstrapping_method =
3167 convertAidlBootstrappingMethodToLegacy(aidl_request.requestBootstrappingMethod);
Nate Jiangbae6fdd2023-02-10 17:16:40 -08003168 legacy_request->cookie_length = aidl_request.cookie.size();
3169
3170 memcpy(legacy_request->cookie, aidl_request.cookie.data(), legacy_request->cookie_length);
Nate Jiang38e8db52022-12-02 17:30:27 -08003171
3172 return true;
3173}
3174
3175bool convertAidlNanBootstrappingIndicationResponseToLegacy(
3176 const NanBootstrappingResponse& aidl_request,
3177 legacy_hal::NanBootstrappingIndicationResponse* legacy_request) {
3178 if (!legacy_request) {
3179 LOG(ERROR) << "convertAidlNanBootstrappingIndicationResponseToLegacy: "
3180 "legacy_request is null";
3181 return false;
3182 }
3183 *legacy_request = {};
3184
3185 legacy_request->service_instance_id = aidl_request.bootstrappingInstanceId;
3186 legacy_request->rsp_code = aidl_request.acceptRequest ? NAN_BOOTSTRAPPING_REQUEST_ACCEPT
3187 : NAN_BOOTSTRAPPING_REQUEST_REJECT;
3188
3189 return true;
3190}
3191
3192bool convertLegacyNanPairingRequestIndToAidl(const legacy_hal::NanPairingRequestInd& legacy_ind,
3193 NanPairingRequestInd* aidl_ind) {
3194 if (!aidl_ind) {
3195 LOG(ERROR) << "convertLegacyNanPairingRequestIndToAidl: aidl_ind is null";
3196 return false;
3197 }
3198 *aidl_ind = {};
3199
3200 aidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
3201 aidl_ind->peerId = legacy_ind.requestor_instance_id;
3202 aidl_ind->peerDiscMacAddr = std::array<uint8_t, 6>();
3203 std::copy(legacy_ind.peer_disc_mac_addr, legacy_ind.peer_disc_mac_addr + 6,
3204 std::begin(aidl_ind->peerDiscMacAddr));
3205 aidl_ind->pairingInstanceId = legacy_ind.pairing_instance_id;
3206 aidl_ind->enablePairingCache = legacy_ind.enable_pairing_cache == 1;
3207 aidl_ind->requestType =
3208 convertLegacyNanPairingRequestTypeToAidl(legacy_ind.nan_pairing_request_type);
3209 if (!convertLegacyNiraToAidl(legacy_ind.nira, &aidl_ind->peerNira)) {
3210 return false;
3211 }
3212 return true;
3213}
3214
3215bool convertLegacyNanPairingConfirmIndToAidl(const legacy_hal::NanPairingConfirmInd& legacy_ind,
3216 NanPairingConfirmInd* aidl_ind) {
3217 if (!aidl_ind) {
3218 LOG(ERROR) << "convertLegacyNanPairingRequestIndToAidl: aidl_ind is null";
3219 return false;
3220 }
3221 *aidl_ind = {};
3222
3223 aidl_ind->pairingInstanceId = legacy_ind.pairing_instance_id;
3224 aidl_ind->enablePairingCache = legacy_ind.enable_pairing_cache == 1;
3225 aidl_ind->requestType =
3226 convertLegacyNanPairingRequestTypeToAidl(legacy_ind.nan_pairing_request_type);
3227 aidl_ind->pairingSuccess = legacy_ind.rsp_code == NAN_PAIRING_REQUEST_ACCEPT;
3228 aidl_ind->status.status = convertLegacyNanStatusTypeToAidl(legacy_ind.reason_code);
3229 if (!convertLegacyNpsaToAidl(legacy_ind.npk_security_association, &aidl_ind->npksa)) {
3230 return false;
3231 }
3232 return true;
3233}
3234
3235bool convertLegacyNanBootstrappingRequestIndToAidl(
3236 const legacy_hal::NanBootstrappingRequestInd& legacy_ind,
3237 NanBootstrappingRequestInd* aidl_ind) {
3238 if (!aidl_ind) {
3239 LOG(ERROR) << "convertLegacyNanBootstrappingRequestIndToAidl: aidl_ind is null";
3240 return false;
3241 }
3242 *aidl_ind = {};
3243
3244 aidl_ind->discoverySessionId = legacy_ind.publish_subscribe_id;
3245 aidl_ind->peerId = legacy_ind.requestor_instance_id;
3246 aidl_ind->peerDiscMacAddr = std::array<uint8_t, 6>();
3247 std::copy(legacy_ind.peer_disc_mac_addr, legacy_ind.peer_disc_mac_addr + 6,
3248 std::begin(aidl_ind->peerDiscMacAddr));
3249 aidl_ind->bootstrappingInstanceId = legacy_ind.bootstrapping_instance_id;
3250 aidl_ind->requestBootstrappingMethod =
3251 convertLegacyBootstrappingMethodToAidl(legacy_ind.request_bootstrapping_method);
3252 return true;
3253}
3254
3255bool convertLegacyNanBootstrappingConfirmIndToAidl(
3256 const legacy_hal::NanBootstrappingConfirmInd& legacy_ind,
3257 NanBootstrappingConfirmInd* aidl_ind) {
3258 if (!aidl_ind) {
3259 LOG(ERROR) << "convertLegacyNanBootstrappingConfirmIndToAidl: aidl_ind is null";
3260 return false;
3261 }
3262 *aidl_ind = {};
3263
3264 aidl_ind->bootstrappingInstanceId = legacy_ind.bootstrapping_instance_id;
Nate Jiangbae6fdd2023-02-10 17:16:40 -08003265 aidl_ind->responseCode = static_cast<NanBootstrappingResponseCode>(legacy_ind.rsp_code);
Nate Jiang38e8db52022-12-02 17:30:27 -08003266 aidl_ind->reasonCode.status = convertLegacyNanStatusTypeToAidl(legacy_ind.reason_code);
Nate Jiangbae6fdd2023-02-10 17:16:40 -08003267 aidl_ind->comeBackDelay = legacy_ind.come_back_delay;
3268 aidl_ind->cookie =
3269 std::vector<uint8_t>(legacy_ind.cookie, legacy_ind.cookie + legacy_ind.cookie_length);
Nate Jiang38e8db52022-12-02 17:30:27 -08003270 return true;
3271}
3272
Mahesh KKVc84d3772022-12-02 16:53:28 -08003273bool convertLegacyWifiChipCapabilitiesToAidl(
3274 const legacy_hal::wifi_chip_capabilities& legacy_chip_capabilities,
3275 WifiChipCapabilities& aidl_chip_capabilities) {
Mahesh KKV21a98b42023-02-05 20:21:17 -08003276 aidl_chip_capabilities.maxMloStrLinkCount = legacy_chip_capabilities.max_mlo_str_link_count;
maheshkkv2565b872023-02-14 13:54:32 -08003277 aidl_chip_capabilities.maxMloAssociationLinkCount =
3278 legacy_chip_capabilities.max_mlo_association_link_count;
Sunil Ravi48556212022-12-12 04:17:04 +00003279 aidl_chip_capabilities.maxConcurrentTdlsSessionCount =
3280 legacy_chip_capabilities.max_concurrent_tdls_session_count;
Mahesh KKVc84d3772022-12-02 16:53:28 -08003281 return true;
3282}
3283
Shuibing Daie5fbcab2022-12-19 15:37:19 -08003284uint32_t convertAidlChannelCategoryToLegacy(uint32_t aidl_channel_category_mask) {
3285 uint32_t channel_category_mask = 0;
3286 if (aidl_channel_category_mask &
3287 static_cast<int32_t>(IWifiChip::ChannelCategoryMask::INDOOR_CHANNEL)) {
3288 channel_category_mask |= legacy_hal::WIFI_INDOOR_CHANNEL;
3289 }
3290 if (aidl_channel_category_mask &
3291 static_cast<int32_t>(IWifiChip::ChannelCategoryMask::DFS_CHANNEL)) {
3292 channel_category_mask |= legacy_hal::WIFI_DFS_CHANNEL;
3293 }
3294 return channel_category_mask;
3295}
3296
Sunil Ravi2be1f262023-02-15 20:56:56 +00003297bool convertLegacyIfaceMaskToIfaceConcurrencyType(u32 mask,
3298 std::vector<IfaceConcurrencyType>* types) {
3299 if (!mask) return false;
3300
3301#ifndef BIT
3302#define BIT(x) (1 << (x))
3303#endif
3304 if (mask & BIT(WIFI_INTERFACE_TYPE_STA)) types->push_back(IfaceConcurrencyType::STA);
3305 if (mask & BIT(WIFI_INTERFACE_TYPE_AP)) types->push_back(IfaceConcurrencyType::AP);
3306 if (mask & BIT(WIFI_INTERFACE_TYPE_AP_BRIDGED))
3307 types->push_back(IfaceConcurrencyType::AP_BRIDGED);
3308 if (mask & BIT(WIFI_INTERFACE_TYPE_P2P)) types->push_back(IfaceConcurrencyType::P2P);
3309 if (mask & BIT(WIFI_INTERFACE_TYPE_NAN)) types->push_back(IfaceConcurrencyType::NAN_IFACE);
3310
3311 return true;
3312}
3313
3314bool convertLegacyIfaceCombinationsMatrixToChipMode(
3315 legacy_hal::wifi_iface_concurrency_matrix& legacy_matrix, IWifiChip::ChipMode* chip_mode) {
3316 if (!chip_mode) {
3317 LOG(ERROR) << "chip_mode is null";
3318 return false;
3319 }
3320 *chip_mode = {};
3321
3322 int num_combinations = legacy_matrix.num_iface_combinations;
3323 std::vector<IWifiChip::ChipConcurrencyCombination> driver_Combinations_vec;
3324 if (!num_combinations) {
3325 LOG(ERROR) << "zero iface combinations";
3326 return false;
3327 }
3328
3329 for (int i = 0; i < num_combinations; i++) {
3330 IWifiChip::ChipConcurrencyCombination chipComb;
3331 std::vector<IWifiChip::ChipConcurrencyCombinationLimit> limits;
3332 wifi_iface_combination* comb = &legacy_matrix.iface_combinations[i];
3333 if (!comb->num_iface_limits) continue;
3334 for (u32 j = 0; j < comb->num_iface_limits; j++) {
3335 IWifiChip::ChipConcurrencyCombinationLimit chipLimit;
3336 chipLimit.maxIfaces = comb->iface_limits[j].max_limit;
3337 std::vector<IfaceConcurrencyType> types;
3338 if (!convertLegacyIfaceMaskToIfaceConcurrencyType(comb->iface_limits[j].iface_mask,
3339 &types)) {
3340 LOG(ERROR) << "Failed to convert from iface_mask:"
3341 << comb->iface_limits[j].iface_mask;
3342 return false;
3343 }
3344 chipLimit.types = types;
3345 limits.push_back(chipLimit);
3346 }
3347 chipComb.limits = limits;
3348 driver_Combinations_vec.push_back(chipComb);
3349 }
3350
3351 chip_mode->availableCombinations = driver_Combinations_vec;
3352 return true;
3353}
3354
Gabriel Birenf3262f92022-07-15 23:25:39 +00003355} // namespace aidl_struct_util
3356} // namespace wifi
3357} // namespace hardware
3358} // namespace android
3359} // namespace aidl