blob: 96dc809839a9009c37de8e6f46661d968173d3d2 [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 "wifi_sta_iface.h"
18
19#include <android-base/logging.h>
20
21#include "aidl_return_util.h"
22#include "aidl_struct_util.h"
23#include "wifi_status_util.h"
24
25namespace aidl {
26namespace android {
27namespace hardware {
28namespace wifi {
29using aidl_return_util::validateAndCall;
30
31WifiStaIface::WifiStaIface(const std::string& ifname,
32 const std::weak_ptr<legacy_hal::WifiLegacyHal> legacy_hal,
33 const std::weak_ptr<iface_util::WifiIfaceUtil> iface_util)
34 : ifname_(ifname), legacy_hal_(legacy_hal), iface_util_(iface_util), is_valid_(true) {
35 // Turn on DFS channel usage for STA iface.
36 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->setDfsFlag(ifname_, true);
37 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
38 LOG(ERROR) << "Failed to set DFS flag; DFS channels may be unavailable.";
39 }
40}
41
42std::shared_ptr<WifiStaIface> WifiStaIface::create(
43 const std::string& ifname, const std::weak_ptr<legacy_hal::WifiLegacyHal> legacy_hal,
44 const std::weak_ptr<iface_util::WifiIfaceUtil> iface_util) {
45 std::shared_ptr<WifiStaIface> ptr =
46 ndk::SharedRefBase::make<WifiStaIface>(ifname, legacy_hal, iface_util);
47 std::weak_ptr<WifiStaIface> weak_ptr_this(ptr);
48 ptr->setWeakPtr(weak_ptr_this);
49 return ptr;
50}
51
52void WifiStaIface::invalidate() {
53 legacy_hal_.reset();
54 event_cb_handler_.invalidate();
55 is_valid_ = false;
56}
57
58void WifiStaIface::setWeakPtr(std::weak_ptr<WifiStaIface> ptr) {
59 weak_ptr_this_ = ptr;
60}
61
62bool WifiStaIface::isValid() {
63 return is_valid_;
64}
65
66std::string WifiStaIface::getName() {
67 return ifname_;
68}
69
70std::set<std::shared_ptr<IWifiStaIfaceEventCallback>> WifiStaIface::getEventCallbacks() {
71 return event_cb_handler_.getCallbacks();
72}
73
74ndk::ScopedAStatus WifiStaIface::getName(std::string* _aidl_return) {
75 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
76 &WifiStaIface::getNameInternal, _aidl_return);
77}
78
79ndk::ScopedAStatus WifiStaIface::registerEventCallback(
80 const std::shared_ptr<IWifiStaIfaceEventCallback>& in_callback) {
81 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
82 &WifiStaIface::registerEventCallbackInternal, in_callback);
83}
84
85ndk::ScopedAStatus WifiStaIface::getCapabilities(
86 IWifiStaIface::StaIfaceCapabilityMask* _aidl_return) {
87 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
88 &WifiStaIface::getCapabilitiesInternal, _aidl_return);
89}
90
91ndk::ScopedAStatus WifiStaIface::getApfPacketFilterCapabilities(
92 StaApfPacketFilterCapabilities* _aidl_return) {
93 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
94 &WifiStaIface::getApfPacketFilterCapabilitiesInternal, _aidl_return);
95}
96
97ndk::ScopedAStatus WifiStaIface::installApfPacketFilter(const std::vector<uint8_t>& in_program) {
98 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
99 &WifiStaIface::installApfPacketFilterInternal, in_program);
100}
101
102ndk::ScopedAStatus WifiStaIface::readApfPacketFilterData(std::vector<uint8_t>* _aidl_return) {
103 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
104 &WifiStaIface::readApfPacketFilterDataInternal, _aidl_return);
105}
106
107ndk::ScopedAStatus WifiStaIface::getBackgroundScanCapabilities(
108 StaBackgroundScanCapabilities* _aidl_return) {
109 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
110 &WifiStaIface::getBackgroundScanCapabilitiesInternal, _aidl_return);
111}
112
113ndk::ScopedAStatus WifiStaIface::getValidFrequenciesForBand(WifiBand in_band,
114 std::vector<int32_t>* _aidl_return) {
115 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
116 &WifiStaIface::getValidFrequenciesForBandInternal, _aidl_return,
117 in_band);
118}
119
120ndk::ScopedAStatus WifiStaIface::startBackgroundScan(int32_t in_cmdId,
121 const StaBackgroundScanParameters& in_params) {
122 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
123 &WifiStaIface::startBackgroundScanInternal, in_cmdId, in_params);
124}
125
126ndk::ScopedAStatus WifiStaIface::stopBackgroundScan(int32_t in_cmdId) {
127 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
128 &WifiStaIface::stopBackgroundScanInternal, in_cmdId);
129}
130
131ndk::ScopedAStatus WifiStaIface::enableLinkLayerStatsCollection(bool in_debug) {
132 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
133 &WifiStaIface::enableLinkLayerStatsCollectionInternal, in_debug);
134}
135
136ndk::ScopedAStatus WifiStaIface::disableLinkLayerStatsCollection() {
137 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
138 &WifiStaIface::disableLinkLayerStatsCollectionInternal);
139}
140
141ndk::ScopedAStatus WifiStaIface::getLinkLayerStats(StaLinkLayerStats* _aidl_return) {
142 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
143 &WifiStaIface::getLinkLayerStatsInternal, _aidl_return);
144}
145
146ndk::ScopedAStatus WifiStaIface::startRssiMonitoring(int32_t in_cmdId, int32_t in_maxRssi,
147 int32_t in_minRssi) {
148 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
149 &WifiStaIface::startRssiMonitoringInternal, in_cmdId, in_maxRssi,
150 in_minRssi);
151}
152
153ndk::ScopedAStatus WifiStaIface::stopRssiMonitoring(int32_t in_cmdId) {
154 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
155 &WifiStaIface::stopRssiMonitoringInternal, in_cmdId);
156}
157
158ndk::ScopedAStatus WifiStaIface::getRoamingCapabilities(StaRoamingCapabilities* _aidl_return) {
159 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
160 &WifiStaIface::getRoamingCapabilitiesInternal, _aidl_return);
161}
162
163ndk::ScopedAStatus WifiStaIface::configureRoaming(const StaRoamingConfig& in_config) {
164 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
165 &WifiStaIface::configureRoamingInternal, in_config);
166}
167
168ndk::ScopedAStatus WifiStaIface::setRoamingState(StaRoamingState in_state) {
169 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
170 &WifiStaIface::setRoamingStateInternal, in_state);
171}
172
173ndk::ScopedAStatus WifiStaIface::enableNdOffload(bool in_enable) {
174 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
175 &WifiStaIface::enableNdOffloadInternal, in_enable);
176}
177
178ndk::ScopedAStatus WifiStaIface::startSendingKeepAlivePackets(
179 int32_t in_cmdId, const std::vector<uint8_t>& in_ipPacketData, char16_t in_etherType,
180 const std::array<uint8_t, 6>& in_srcAddress, const std::array<uint8_t, 6>& in_dstAddress,
181 int32_t in_periodInMs) {
182 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
183 &WifiStaIface::startSendingKeepAlivePacketsInternal, in_cmdId,
184 in_ipPacketData, in_etherType, in_srcAddress, in_dstAddress,
185 in_periodInMs);
186}
187
188ndk::ScopedAStatus WifiStaIface::stopSendingKeepAlivePackets(int32_t in_cmdId) {
189 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
190 &WifiStaIface::stopSendingKeepAlivePacketsInternal, in_cmdId);
191}
192
193ndk::ScopedAStatus WifiStaIface::startDebugPacketFateMonitoring() {
194 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
195 &WifiStaIface::startDebugPacketFateMonitoringInternal);
196}
197
198ndk::ScopedAStatus WifiStaIface::getDebugTxPacketFates(
199 std::vector<WifiDebugTxPacketFateReport>* _aidl_return) {
200 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
201 &WifiStaIface::getDebugTxPacketFatesInternal, _aidl_return);
202}
203
204ndk::ScopedAStatus WifiStaIface::getDebugRxPacketFates(
205 std::vector<WifiDebugRxPacketFateReport>* _aidl_return) {
206 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
207 &WifiStaIface::getDebugRxPacketFatesInternal, _aidl_return);
208}
209
210ndk::ScopedAStatus WifiStaIface::setMacAddress(const std::array<uint8_t, 6>& in_mac) {
211 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
212 &WifiStaIface::setMacAddressInternal, in_mac);
213}
214
215ndk::ScopedAStatus WifiStaIface::getFactoryMacAddress(std::array<uint8_t, 6>* _aidl_return) {
216 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
217 &WifiStaIface::getFactoryMacAddressInternal, _aidl_return);
218}
219
220ndk::ScopedAStatus WifiStaIface::setScanMode(bool in_enable) {
221 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
222 &WifiStaIface::setScanModeInternal, in_enable);
223}
224
Kai Shi6d02d402022-11-17 16:34:05 -0800225ndk::ScopedAStatus WifiStaIface::setDtimMultiplier(int32_t in_multiplier) {
226 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
227 &WifiStaIface::setDtimMultiplierInternal, in_multiplier);
228}
229
Gabriel Birenf3262f92022-07-15 23:25:39 +0000230std::pair<std::string, ndk::ScopedAStatus> WifiStaIface::getNameInternal() {
231 return {ifname_, ndk::ScopedAStatus::ok()};
232}
233
234ndk::ScopedAStatus WifiStaIface::registerEventCallbackInternal(
235 const std::shared_ptr<IWifiStaIfaceEventCallback>& callback) {
236 if (!event_cb_handler_.addCallback(callback)) {
237 return createWifiStatus(WifiStatusCode::ERROR_UNKNOWN);
238 }
239 return ndk::ScopedAStatus::ok();
240}
241
242std::pair<IWifiStaIface::StaIfaceCapabilityMask, ndk::ScopedAStatus>
243WifiStaIface::getCapabilitiesInternal() {
244 legacy_hal::wifi_error legacy_status;
245 uint64_t legacy_feature_set;
246 std::tie(legacy_status, legacy_feature_set) =
247 legacy_hal_.lock()->getSupportedFeatureSet(ifname_);
248 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
249 return {IWifiStaIface::StaIfaceCapabilityMask{},
250 createWifiStatusFromLegacyError(legacy_status)};
251 }
252 uint32_t legacy_logger_feature_set;
253 std::tie(legacy_status, legacy_logger_feature_set) =
254 legacy_hal_.lock()->getLoggerSupportedFeatureSet(ifname_);
255 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
256 // some devices don't support querying logger feature set
257 legacy_logger_feature_set = 0;
258 }
259 uint32_t aidl_caps;
260 if (!aidl_struct_util::convertLegacyFeaturesToAidlStaCapabilities(
261 legacy_feature_set, legacy_logger_feature_set, &aidl_caps)) {
262 return {IWifiStaIface::StaIfaceCapabilityMask{},
263 createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
264 }
265 return {static_cast<IWifiStaIface::StaIfaceCapabilityMask>(aidl_caps),
266 ndk::ScopedAStatus::ok()};
267}
268
269std::pair<StaApfPacketFilterCapabilities, ndk::ScopedAStatus>
270WifiStaIface::getApfPacketFilterCapabilitiesInternal() {
271 legacy_hal::wifi_error legacy_status;
272 legacy_hal::PacketFilterCapabilities legacy_caps;
273 std::tie(legacy_status, legacy_caps) = legacy_hal_.lock()->getPacketFilterCapabilities(ifname_);
274 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
275 return {StaApfPacketFilterCapabilities{}, createWifiStatusFromLegacyError(legacy_status)};
276 }
277 StaApfPacketFilterCapabilities aidl_caps;
278 if (!aidl_struct_util::convertLegacyApfCapabilitiesToAidl(legacy_caps, &aidl_caps)) {
279 return {StaApfPacketFilterCapabilities{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
280 }
281 return {aidl_caps, ndk::ScopedAStatus::ok()};
282}
283
284ndk::ScopedAStatus WifiStaIface::installApfPacketFilterInternal(
285 const std::vector<uint8_t>& program) {
286 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->setPacketFilter(ifname_, program);
287 return createWifiStatusFromLegacyError(legacy_status);
288}
289
290std::pair<std::vector<uint8_t>, ndk::ScopedAStatus>
291WifiStaIface::readApfPacketFilterDataInternal() {
292 const std::pair<legacy_hal::wifi_error, std::vector<uint8_t>> legacy_status_and_data =
293 legacy_hal_.lock()->readApfPacketFilterData(ifname_);
294 return {std::move(legacy_status_and_data.second),
295 createWifiStatusFromLegacyError(legacy_status_and_data.first)};
296}
297
298std::pair<StaBackgroundScanCapabilities, ndk::ScopedAStatus>
299WifiStaIface::getBackgroundScanCapabilitiesInternal() {
300 legacy_hal::wifi_error legacy_status;
301 legacy_hal::wifi_gscan_capabilities legacy_caps;
302 std::tie(legacy_status, legacy_caps) = legacy_hal_.lock()->getGscanCapabilities(ifname_);
303 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
304 return {StaBackgroundScanCapabilities{}, createWifiStatusFromLegacyError(legacy_status)};
305 }
306 StaBackgroundScanCapabilities aidl_caps;
307 if (!aidl_struct_util::convertLegacyGscanCapabilitiesToAidl(legacy_caps, &aidl_caps)) {
308 return {StaBackgroundScanCapabilities{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
309 }
310 return {aidl_caps, ndk::ScopedAStatus::ok()};
311}
312
313std::pair<std::vector<int32_t>, ndk::ScopedAStatus>
314WifiStaIface::getValidFrequenciesForBandInternal(WifiBand band) {
315 static_assert(sizeof(WifiChannelWidthInMhz) == sizeof(int32_t), "Size mismatch");
316 legacy_hal::wifi_error legacy_status;
317 std::vector<uint32_t> valid_frequencies;
318 std::tie(legacy_status, valid_frequencies) = legacy_hal_.lock()->getValidFrequenciesForBand(
319 ifname_, aidl_struct_util::convertAidlWifiBandToLegacy(band));
320 return {std::vector<int32_t>(valid_frequencies.begin(), valid_frequencies.end()),
321 createWifiStatusFromLegacyError(legacy_status)};
322}
323
324ndk::ScopedAStatus WifiStaIface::startBackgroundScanInternal(
325 int32_t cmd_id, const StaBackgroundScanParameters& params) {
326 legacy_hal::wifi_scan_cmd_params legacy_params;
327 if (!aidl_struct_util::convertAidlGscanParamsToLegacy(params, &legacy_params)) {
328 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
329 }
330 std::weak_ptr<WifiStaIface> weak_ptr_this = weak_ptr_this_;
331 const auto& on_failure_callback = [weak_ptr_this](legacy_hal::wifi_request_id id) {
332 const auto shared_ptr_this = weak_ptr_this.lock();
333 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
334 LOG(ERROR) << "Callback invoked on an invalid object";
335 return;
336 }
337 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
338 if (!callback->onBackgroundScanFailure(id).isOk()) {
339 LOG(ERROR) << "Failed to invoke onBackgroundScanFailure callback";
340 }
341 }
342 };
343 const auto& on_results_callback =
344 [weak_ptr_this](legacy_hal::wifi_request_id id,
345 const std::vector<legacy_hal::wifi_cached_scan_results>& results) {
346 const auto shared_ptr_this = weak_ptr_this.lock();
347 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
348 LOG(ERROR) << "Callback invoked on an invalid object";
349 return;
350 }
351 std::vector<StaScanData> aidl_scan_datas;
352 if (!aidl_struct_util::convertLegacyVectorOfCachedGscanResultsToAidl(
353 results, &aidl_scan_datas)) {
354 LOG(ERROR) << "Failed to convert scan results to AIDL structs";
355 return;
356 }
357 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
358 if (!callback->onBackgroundScanResults(id, aidl_scan_datas).isOk()) {
359 LOG(ERROR) << "Failed to invoke onBackgroundScanResults callback";
360 }
361 }
362 };
363 const auto& on_full_result_callback = [weak_ptr_this](
364 legacy_hal::wifi_request_id id,
365 const legacy_hal::wifi_scan_result* result,
366 uint32_t buckets_scanned) {
367 const auto shared_ptr_this = weak_ptr_this.lock();
368 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
369 LOG(ERROR) << "Callback invoked on an invalid object";
370 return;
371 }
372 StaScanResult aidl_scan_result;
373 if (!aidl_struct_util::convertLegacyGscanResultToAidl(*result, true, &aidl_scan_result)) {
374 LOG(ERROR) << "Failed to convert full scan results to AIDL structs";
375 return;
376 }
377 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
378 if (!callback->onBackgroundFullScanResult(id, buckets_scanned, aidl_scan_result)
379 .isOk()) {
380 LOG(ERROR) << "Failed to invoke onBackgroundFullScanResult callback";
381 }
382 }
383 };
384 legacy_hal::wifi_error legacy_status =
385 legacy_hal_.lock()->startGscan(ifname_, cmd_id, legacy_params, on_failure_callback,
386 on_results_callback, on_full_result_callback);
387 return createWifiStatusFromLegacyError(legacy_status);
388}
389
390ndk::ScopedAStatus WifiStaIface::stopBackgroundScanInternal(int32_t cmd_id) {
391 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->stopGscan(ifname_, cmd_id);
392 return createWifiStatusFromLegacyError(legacy_status);
393}
394
395ndk::ScopedAStatus WifiStaIface::enableLinkLayerStatsCollectionInternal(bool debug) {
396 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->enableLinkLayerStats(ifname_, debug);
397 return createWifiStatusFromLegacyError(legacy_status);
398}
399
400ndk::ScopedAStatus WifiStaIface::disableLinkLayerStatsCollectionInternal() {
401 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->disableLinkLayerStats(ifname_);
402 return createWifiStatusFromLegacyError(legacy_status);
403}
404
405std::pair<StaLinkLayerStats, ndk::ScopedAStatus> WifiStaIface::getLinkLayerStatsInternal() {
406 legacy_hal::wifi_error legacy_status;
Mahesh KKV5f30d332022-10-26 14:07:44 -0700407 legacy_hal::LinkLayerStats legacy_stats{};
408 legacy_hal::LinkLayerMlStats legacy_ml_stats{};
409 legacy_status = legacy_hal_.lock()->getLinkLayerStats(ifname_, legacy_stats, legacy_ml_stats);
Gabriel Birenf3262f92022-07-15 23:25:39 +0000410 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
411 return {StaLinkLayerStats{}, createWifiStatusFromLegacyError(legacy_status)};
412 }
413 StaLinkLayerStats aidl_stats;
Mahesh KKV5f30d332022-10-26 14:07:44 -0700414 if (legacy_stats.valid) {
415 if (!aidl_struct_util::convertLegacyLinkLayerStatsToAidl(legacy_stats, &aidl_stats)) {
416 return {StaLinkLayerStats{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
417 }
418 } else if (legacy_ml_stats.valid) {
419 if (!aidl_struct_util::convertLegacyLinkLayerMlStatsToAidl(legacy_ml_stats, &aidl_stats)) {
420 return {StaLinkLayerStats{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
421 }
422 } else {
Gabriel Birenf3262f92022-07-15 23:25:39 +0000423 return {StaLinkLayerStats{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
424 }
425 return {aidl_stats, ndk::ScopedAStatus::ok()};
426}
427
428ndk::ScopedAStatus WifiStaIface::startRssiMonitoringInternal(int32_t cmd_id, int32_t max_rssi,
429 int32_t min_rssi) {
430 std::weak_ptr<WifiStaIface> weak_ptr_this = weak_ptr_this_;
431 const auto& on_threshold_breached_callback =
432 [weak_ptr_this](legacy_hal::wifi_request_id id, std::array<uint8_t, ETH_ALEN> bssid,
433 int8_t rssi) {
434 const auto shared_ptr_this = weak_ptr_this.lock();
435 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
436 LOG(ERROR) << "Callback invoked on an invalid object";
437 return;
438 }
439 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
440 if (!callback->onRssiThresholdBreached(id, bssid, rssi).isOk()) {
441 LOG(ERROR) << "Failed to invoke onRssiThresholdBreached callback";
442 }
443 }
444 };
445 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->startRssiMonitoring(
446 ifname_, cmd_id, max_rssi, min_rssi, on_threshold_breached_callback);
447 return createWifiStatusFromLegacyError(legacy_status);
448}
449
450ndk::ScopedAStatus WifiStaIface::stopRssiMonitoringInternal(int32_t cmd_id) {
451 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->stopRssiMonitoring(ifname_, cmd_id);
452 return createWifiStatusFromLegacyError(legacy_status);
453}
454
455std::pair<StaRoamingCapabilities, ndk::ScopedAStatus>
456WifiStaIface::getRoamingCapabilitiesInternal() {
457 legacy_hal::wifi_error legacy_status;
458 legacy_hal::wifi_roaming_capabilities legacy_caps;
459 std::tie(legacy_status, legacy_caps) = legacy_hal_.lock()->getRoamingCapabilities(ifname_);
460 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
461 return {StaRoamingCapabilities{}, createWifiStatusFromLegacyError(legacy_status)};
462 }
463 StaRoamingCapabilities aidl_caps;
464 if (!aidl_struct_util::convertLegacyRoamingCapabilitiesToAidl(legacy_caps, &aidl_caps)) {
465 return {StaRoamingCapabilities{}, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
466 }
467 return {aidl_caps, ndk::ScopedAStatus::ok()};
468}
469
470ndk::ScopedAStatus WifiStaIface::configureRoamingInternal(const StaRoamingConfig& config) {
471 legacy_hal::wifi_roaming_config legacy_config;
472 if (!aidl_struct_util::convertAidlRoamingConfigToLegacy(config, &legacy_config)) {
473 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
474 }
475 legacy_hal::wifi_error legacy_status =
476 legacy_hal_.lock()->configureRoaming(ifname_, legacy_config);
477 return createWifiStatusFromLegacyError(legacy_status);
478}
479
480ndk::ScopedAStatus WifiStaIface::setRoamingStateInternal(StaRoamingState state) {
481 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->enableFirmwareRoaming(
482 ifname_, aidl_struct_util::convertAidlRoamingStateToLegacy(state));
483 return createWifiStatusFromLegacyError(legacy_status);
484}
485
486ndk::ScopedAStatus WifiStaIface::enableNdOffloadInternal(bool enable) {
487 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->configureNdOffload(ifname_, enable);
488 return createWifiStatusFromLegacyError(legacy_status);
489}
490
491ndk::ScopedAStatus WifiStaIface::startSendingKeepAlivePacketsInternal(
492 int32_t cmd_id, const std::vector<uint8_t>& ip_packet_data, char16_t ether_type,
493 const std::array<uint8_t, 6>& src_address, const std::array<uint8_t, 6>& dst_address,
494 int32_t period_in_ms) {
495 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->startSendingOffloadedPacket(
496 ifname_, cmd_id, ether_type, ip_packet_data, src_address, dst_address, period_in_ms);
497 return createWifiStatusFromLegacyError(legacy_status);
498}
499
500ndk::ScopedAStatus WifiStaIface::stopSendingKeepAlivePacketsInternal(int32_t cmd_id) {
501 legacy_hal::wifi_error legacy_status =
502 legacy_hal_.lock()->stopSendingOffloadedPacket(ifname_, cmd_id);
503 return createWifiStatusFromLegacyError(legacy_status);
504}
505
506ndk::ScopedAStatus WifiStaIface::startDebugPacketFateMonitoringInternal() {
507 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->startPktFateMonitoring(ifname_);
508 return createWifiStatusFromLegacyError(legacy_status);
509}
510
511std::pair<std::vector<WifiDebugTxPacketFateReport>, ndk::ScopedAStatus>
512WifiStaIface::getDebugTxPacketFatesInternal() {
513 legacy_hal::wifi_error legacy_status;
514 std::vector<legacy_hal::wifi_tx_report> legacy_fates;
515 std::tie(legacy_status, legacy_fates) = legacy_hal_.lock()->getTxPktFates(ifname_);
516 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
517 return {std::vector<WifiDebugTxPacketFateReport>(),
518 createWifiStatusFromLegacyError(legacy_status)};
519 }
520 std::vector<WifiDebugTxPacketFateReport> aidl_fates;
521 if (!aidl_struct_util::convertLegacyVectorOfDebugTxPacketFateToAidl(legacy_fates,
522 &aidl_fates)) {
523 return {std::vector<WifiDebugTxPacketFateReport>(),
524 createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
525 }
526 return {aidl_fates, ndk::ScopedAStatus::ok()};
527}
528
529std::pair<std::vector<WifiDebugRxPacketFateReport>, ndk::ScopedAStatus>
530WifiStaIface::getDebugRxPacketFatesInternal() {
531 legacy_hal::wifi_error legacy_status;
532 std::vector<legacy_hal::wifi_rx_report> legacy_fates;
533 std::tie(legacy_status, legacy_fates) = legacy_hal_.lock()->getRxPktFates(ifname_);
534 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
535 return {std::vector<WifiDebugRxPacketFateReport>(),
536 createWifiStatusFromLegacyError(legacy_status)};
537 }
538 std::vector<WifiDebugRxPacketFateReport> aidl_fates;
539 if (!aidl_struct_util::convertLegacyVectorOfDebugRxPacketFateToAidl(legacy_fates,
540 &aidl_fates)) {
541 return {std::vector<WifiDebugRxPacketFateReport>(),
542 createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
543 }
544 return {aidl_fates, ndk::ScopedAStatus::ok()};
545}
546
547ndk::ScopedAStatus WifiStaIface::setMacAddressInternal(const std::array<uint8_t, 6>& mac) {
548 bool status = iface_util_.lock()->setMacAddress(ifname_, mac);
549 if (!status) {
550 return createWifiStatus(WifiStatusCode::ERROR_UNKNOWN);
551 }
552 return ndk::ScopedAStatus::ok();
553}
554
555std::pair<std::array<uint8_t, 6>, ndk::ScopedAStatus> WifiStaIface::getFactoryMacAddressInternal() {
556 std::array<uint8_t, 6> mac = iface_util_.lock()->getFactoryMacAddress(ifname_);
557 if (mac[0] == 0 && mac[1] == 0 && mac[2] == 0 && mac[3] == 0 && mac[4] == 0 && mac[5] == 0) {
558 return {mac, createWifiStatus(WifiStatusCode::ERROR_UNKNOWN)};
559 }
560 return {mac, ndk::ScopedAStatus::ok()};
561}
562
563ndk::ScopedAStatus WifiStaIface::setScanModeInternal(bool enable) {
Ye Jiao50274f72023-01-17 14:53:22 +0800564 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->setScanMode(ifname_, enable);
565 return createWifiStatusFromLegacyError(legacy_status);
Gabriel Birenf3262f92022-07-15 23:25:39 +0000566}
567
Kai Shi6d02d402022-11-17 16:34:05 -0800568ndk::ScopedAStatus WifiStaIface::setDtimMultiplierInternal(const int multiplier) {
569 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->setDtimConfig(ifname_, multiplier);
570 return createWifiStatusFromLegacyError(legacy_status);
571}
572
Gabriel Birenf3262f92022-07-15 23:25:39 +0000573} // namespace wifi
574} // namespace hardware
575} // namespace android
576} // namespace aidl