blob: f41b778461b6a2e19632d4c71a4c00acc98aff72 [file] [log] [blame]
Roshan Pius3e2d6712016-10-06 13:16:23 -07001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Roshan Pius3e2d6712016-10-06 13:16:23 -070017#include <android-base/logging.h>
18
Roshan Pius907d4a22016-10-27 12:48:12 -070019#include "hidl_return_util.h"
Roshan Pius970f0312016-12-05 15:25:51 -080020#include "hidl_struct_util.h"
Roshan Pius907d4a22016-10-27 12:48:12 -070021#include "wifi_sta_iface.h"
Roshan Pius734fea02016-10-11 08:30:28 -070022#include "wifi_status_util.h"
Roshan Pius3e2d6712016-10-06 13:16:23 -070023
24namespace android {
25namespace hardware {
26namespace wifi {
Etan Cohen6ce50902017-09-14 07:30:57 -070027namespace V1_2 {
Roshan Pius3e2d6712016-10-06 13:16:23 -070028namespace implementation {
Roshan Pius907d4a22016-10-27 12:48:12 -070029using hidl_return_util::validateAndCall;
Roshan Pius3e2d6712016-10-06 13:16:23 -070030
Roshan Pius6cedc972016-10-28 10:11:17 -070031WifiStaIface::WifiStaIface(
32 const std::string& ifname,
33 const std::weak_ptr<legacy_hal::WifiLegacyHal> legacy_hal)
Roshan Pius08d1df42017-04-19 23:11:07 -070034 : ifname_(ifname), legacy_hal_(legacy_hal), is_valid_(true) {
35 // Turn on DFS channel usage for STA iface.
36 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -070037 legacy_hal_.lock()->setDfsFlag(ifname_, true);
Roshan Pius08d1df42017-04-19 23:11:07 -070038 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
39 LOG(ERROR) << "Failed to set DFS flag; DFS channels may be unavailable.";
40 }
41}
Roshan Pius3e2d6712016-10-06 13:16:23 -070042
43void WifiStaIface::invalidate() {
44 legacy_hal_.reset();
Roshan Piusd37341f2017-01-31 13:13:28 -080045 event_cb_handler_.invalidate();
Roshan Pius3e2d6712016-10-06 13:16:23 -070046 is_valid_ = false;
47}
48
Roshan Pius907d4a22016-10-27 12:48:12 -070049bool WifiStaIface::isValid() {
50 return is_valid_;
51}
52
Roshan Piusd37341f2017-01-31 13:13:28 -080053std::set<sp<IWifiStaIfaceEventCallback>> WifiStaIface::getEventCallbacks() {
54 return event_cb_handler_.getCallbacks();
Roshan Pius970f0312016-12-05 15:25:51 -080055}
56
Roshan Pius734fea02016-10-11 08:30:28 -070057Return<void> WifiStaIface::getName(getName_cb hidl_status_cb) {
Roshan Pius907d4a22016-10-27 12:48:12 -070058 return validateAndCall(this,
59 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
60 &WifiStaIface::getNameInternal,
61 hidl_status_cb);
Roshan Pius3e2d6712016-10-06 13:16:23 -070062}
63
Roshan Pius734fea02016-10-11 08:30:28 -070064Return<void> WifiStaIface::getType(getType_cb hidl_status_cb) {
Roshan Pius907d4a22016-10-27 12:48:12 -070065 return validateAndCall(this,
66 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
67 &WifiStaIface::getTypeInternal,
68 hidl_status_cb);
69}
70
Roshan Piusa04ba3f2016-10-27 14:36:26 -070071Return<void> WifiStaIface::registerEventCallback(
72 const sp<IWifiStaIfaceEventCallback>& callback,
73 registerEventCallback_cb hidl_status_cb) {
74 return validateAndCall(this,
75 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
76 &WifiStaIface::registerEventCallbackInternal,
77 hidl_status_cb,
78 callback);
79}
80
81Return<void> WifiStaIface::getCapabilities(getCapabilities_cb hidl_status_cb) {
82 return validateAndCall(this,
83 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
84 &WifiStaIface::getCapabilitiesInternal,
85 hidl_status_cb);
86}
87
88Return<void> WifiStaIface::getApfPacketFilterCapabilities(
89 getApfPacketFilterCapabilities_cb hidl_status_cb) {
90 return validateAndCall(this,
91 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
92 &WifiStaIface::getApfPacketFilterCapabilitiesInternal,
93 hidl_status_cb);
94}
95
96Return<void> WifiStaIface::installApfPacketFilter(
97 uint32_t cmd_id,
98 const hidl_vec<uint8_t>& program,
99 installApfPacketFilter_cb hidl_status_cb) {
100 return validateAndCall(this,
101 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
102 &WifiStaIface::installApfPacketFilterInternal,
103 hidl_status_cb,
104 cmd_id,
105 program);
106}
107
108Return<void> WifiStaIface::getBackgroundScanCapabilities(
109 getBackgroundScanCapabilities_cb hidl_status_cb) {
110 return validateAndCall(this,
111 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
112 &WifiStaIface::getBackgroundScanCapabilitiesInternal,
113 hidl_status_cb);
114}
115
Roshan Pius7f4574d2017-02-22 09:48:03 -0800116Return<void> WifiStaIface::getValidFrequenciesForBand(
117 WifiBand band, getValidFrequenciesForBand_cb hidl_status_cb) {
118 return validateAndCall(this,
119 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
120 &WifiStaIface::getValidFrequenciesForBandInternal,
121 hidl_status_cb,
122 band);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700123}
124
125Return<void> WifiStaIface::startBackgroundScan(
126 uint32_t cmd_id,
127 const StaBackgroundScanParameters& params,
128 startBackgroundScan_cb hidl_status_cb) {
129 return validateAndCall(this,
130 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
131 &WifiStaIface::startBackgroundScanInternal,
132 hidl_status_cb,
133 cmd_id,
134 params);
135}
136
137Return<void> WifiStaIface::stopBackgroundScan(
138 uint32_t cmd_id, stopBackgroundScan_cb hidl_status_cb) {
139 return validateAndCall(this,
140 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
141 &WifiStaIface::stopBackgroundScanInternal,
142 hidl_status_cb,
143 cmd_id);
144}
145
146Return<void> WifiStaIface::enableLinkLayerStatsCollection(
147 bool debug, enableLinkLayerStatsCollection_cb hidl_status_cb) {
148 return validateAndCall(this,
149 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
150 &WifiStaIface::enableLinkLayerStatsCollectionInternal,
151 hidl_status_cb,
152 debug);
153}
154
155Return<void> WifiStaIface::disableLinkLayerStatsCollection(
156 disableLinkLayerStatsCollection_cb hidl_status_cb) {
157 return validateAndCall(this,
158 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
159 &WifiStaIface::disableLinkLayerStatsCollectionInternal,
160 hidl_status_cb);
161}
162
163Return<void> WifiStaIface::getLinkLayerStats(
164 getLinkLayerStats_cb hidl_status_cb) {
165 return validateAndCall(this,
166 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
167 &WifiStaIface::getLinkLayerStatsInternal,
168 hidl_status_cb);
169}
170
Roshan Piusd4767542016-12-06 10:04:05 -0800171Return<void> WifiStaIface::startRssiMonitoring(
172 uint32_t cmd_id,
173 int32_t max_rssi,
174 int32_t min_rssi,
175 startRssiMonitoring_cb hidl_status_cb) {
176 return validateAndCall(this,
177 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
178 &WifiStaIface::startRssiMonitoringInternal,
179 hidl_status_cb,
180 cmd_id,
181 max_rssi,
182 min_rssi);
183}
184
185Return<void> WifiStaIface::stopRssiMonitoring(
186 uint32_t cmd_id, stopRssiMonitoring_cb hidl_status_cb) {
187 return validateAndCall(this,
188 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
189 &WifiStaIface::stopRssiMonitoringInternal,
190 hidl_status_cb,
191 cmd_id);
192}
193
Roshan Pius26801cb2016-12-13 14:25:45 -0800194Return<void> WifiStaIface::getRoamingCapabilities(
195 getRoamingCapabilities_cb hidl_status_cb) {
196 return validateAndCall(this,
197 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
198 &WifiStaIface::getRoamingCapabilitiesInternal,
199 hidl_status_cb);
200}
201
202Return<void> WifiStaIface::configureRoaming(
203 const StaRoamingConfig& config, configureRoaming_cb hidl_status_cb) {
204 return validateAndCall(this,
205 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
206 &WifiStaIface::configureRoamingInternal,
207 hidl_status_cb,
208 config);
209}
210
211Return<void> WifiStaIface::setRoamingState(StaRoamingState state,
212 setRoamingState_cb hidl_status_cb) {
213 return validateAndCall(this,
214 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
215 &WifiStaIface::setRoamingStateInternal,
216 hidl_status_cb,
217 state);
218}
219
Roshan Piusaf727c02017-01-11 15:37:25 -0800220Return<void> WifiStaIface::enableNdOffload(bool enable,
221 enableNdOffload_cb hidl_status_cb) {
222 return validateAndCall(this,
223 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
224 &WifiStaIface::enableNdOffloadInternal,
225 hidl_status_cb,
226 enable);
227}
228
Roshan Pius9a9869a2017-01-11 16:42:16 -0800229Return<void> WifiStaIface::startSendingKeepAlivePackets(
230 uint32_t cmd_id,
231 const hidl_vec<uint8_t>& ip_packet_data,
232 uint16_t ether_type,
233 const hidl_array<uint8_t, 6>& src_address,
234 const hidl_array<uint8_t, 6>& dst_address,
235 uint32_t period_in_ms,
236 startSendingKeepAlivePackets_cb hidl_status_cb) {
237 return validateAndCall(this,
238 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
239 &WifiStaIface::startSendingKeepAlivePacketsInternal,
240 hidl_status_cb,
241 cmd_id,
242 ip_packet_data,
243 ether_type,
244 src_address,
245 dst_address,
246 period_in_ms);
247}
248
249Return<void> WifiStaIface::stopSendingKeepAlivePackets(
250 uint32_t cmd_id, stopSendingKeepAlivePackets_cb hidl_status_cb) {
251 return validateAndCall(this,
252 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
253 &WifiStaIface::stopSendingKeepAlivePacketsInternal,
254 hidl_status_cb,
255 cmd_id);
256}
257
Roshan Pius795bb812017-02-01 13:09:08 -0800258Return<void> WifiStaIface::setScanningMacOui(
259 const hidl_array<uint8_t, 3>& oui, setScanningMacOui_cb hidl_status_cb) {
260 return validateAndCall(this,
261 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
262 &WifiStaIface::setScanningMacOuiInternal,
263 hidl_status_cb,
264 oui);
265}
266
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700267Return<void> WifiStaIface::startDebugPacketFateMonitoring(
268 startDebugPacketFateMonitoring_cb hidl_status_cb) {
269 return validateAndCall(this,
270 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
271 &WifiStaIface::startDebugPacketFateMonitoringInternal,
272 hidl_status_cb);
273}
274
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700275Return<void> WifiStaIface::getDebugTxPacketFates(
276 getDebugTxPacketFates_cb hidl_status_cb) {
277 return validateAndCall(this,
278 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
279 &WifiStaIface::getDebugTxPacketFatesInternal,
280 hidl_status_cb);
281}
282
283Return<void> WifiStaIface::getDebugRxPacketFates(
284 getDebugRxPacketFates_cb hidl_status_cb) {
285 return validateAndCall(this,
286 WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
287 &WifiStaIface::getDebugRxPacketFatesInternal,
288 hidl_status_cb);
289}
290
Roshan Pius907d4a22016-10-27 12:48:12 -0700291std::pair<WifiStatus, std::string> WifiStaIface::getNameInternal() {
292 return {createWifiStatus(WifiStatusCode::SUCCESS), ifname_};
293}
294
295std::pair<WifiStatus, IfaceType> WifiStaIface::getTypeInternal() {
296 return {createWifiStatus(WifiStatusCode::SUCCESS), IfaceType::STA};
Roshan Pius3e2d6712016-10-06 13:16:23 -0700297}
298
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700299WifiStatus WifiStaIface::registerEventCallbackInternal(
300 const sp<IWifiStaIfaceEventCallback>& callback) {
Roshan Piusd37341f2017-01-31 13:13:28 -0800301 if (!event_cb_handler_.addCallback(callback)) {
302 return createWifiStatus(WifiStatusCode::ERROR_UNKNOWN);
303 }
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700304 return createWifiStatus(WifiStatusCode::SUCCESS);
305}
306
307std::pair<WifiStatus, uint32_t> WifiStaIface::getCapabilitiesInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800308 legacy_hal::wifi_error legacy_status;
309 uint32_t legacy_feature_set;
310 std::tie(legacy_status, legacy_feature_set) =
Roshan Piusacededb2017-10-06 14:59:26 -0700311 legacy_hal_.lock()->getSupportedFeatureSet(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800312 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
313 return {createWifiStatusFromLegacyError(legacy_status), 0};
314 }
315 uint32_t legacy_logger_feature_set;
316 std::tie(legacy_status, legacy_logger_feature_set) =
Roshan Piusacededb2017-10-06 14:59:26 -0700317 legacy_hal_.lock()->getLoggerSupportedFeatureSet(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800318 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
Randy Pandbb31022017-04-20 10:03:41 -0700319 // some devices don't support querying logger feature set
320 legacy_logger_feature_set = 0;
Roshan Pius970f0312016-12-05 15:25:51 -0800321 }
322 uint32_t hidl_caps;
323 if (!hidl_struct_util::convertLegacyFeaturesToHidlStaCapabilities(
324 legacy_feature_set, legacy_logger_feature_set, &hidl_caps)) {
325 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), 0};
326 }
327 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700328}
329
330std::pair<WifiStatus, StaApfPacketFilterCapabilities>
331WifiStaIface::getApfPacketFilterCapabilitiesInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800332 legacy_hal::wifi_error legacy_status;
333 legacy_hal::PacketFilterCapabilities legacy_caps;
334 std::tie(legacy_status, legacy_caps) =
Roshan Piusacededb2017-10-06 14:59:26 -0700335 legacy_hal_.lock()->getPacketFilterCapabilities(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800336 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
337 return {createWifiStatusFromLegacyError(legacy_status), {}};
338 }
339 StaApfPacketFilterCapabilities hidl_caps;
340 if (!hidl_struct_util::convertLegacyApfCapabilitiesToHidl(legacy_caps,
341 &hidl_caps)) {
342 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
343 }
344 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700345}
346
347WifiStatus WifiStaIface::installApfPacketFilterInternal(
Roshan Pius970f0312016-12-05 15:25:51 -0800348 uint32_t /* cmd_id */, const std::vector<uint8_t>& program) {
349 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700350 legacy_hal_.lock()->setPacketFilter(ifname_, program);
Roshan Pius970f0312016-12-05 15:25:51 -0800351 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700352}
353
354std::pair<WifiStatus, StaBackgroundScanCapabilities>
355WifiStaIface::getBackgroundScanCapabilitiesInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800356 legacy_hal::wifi_error legacy_status;
357 legacy_hal::wifi_gscan_capabilities legacy_caps;
358 std::tie(legacy_status, legacy_caps) =
Roshan Piusacededb2017-10-06 14:59:26 -0700359 legacy_hal_.lock()->getGscanCapabilities(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800360 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
361 return {createWifiStatusFromLegacyError(legacy_status), {}};
362 }
363 StaBackgroundScanCapabilities hidl_caps;
364 if (!hidl_struct_util::convertLegacyGscanCapabilitiesToHidl(legacy_caps,
365 &hidl_caps)) {
366 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
367 }
368 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700369}
370
371std::pair<WifiStatus, std::vector<WifiChannelInMhz>>
Roshan Pius7f4574d2017-02-22 09:48:03 -0800372WifiStaIface::getValidFrequenciesForBandInternal(WifiBand band) {
Roshan Pius970f0312016-12-05 15:25:51 -0800373 static_assert(sizeof(WifiChannelInMhz) == sizeof(uint32_t), "Size mismatch");
374 legacy_hal::wifi_error legacy_status;
375 std::vector<uint32_t> valid_frequencies;
376 std::tie(legacy_status, valid_frequencies) =
Roshan Pius7f4574d2017-02-22 09:48:03 -0800377 legacy_hal_.lock()->getValidFrequenciesForBand(
Roshan Piusacededb2017-10-06 14:59:26 -0700378 ifname_, hidl_struct_util::convertHidlWifiBandToLegacy(band));
Roshan Pius970f0312016-12-05 15:25:51 -0800379 return {createWifiStatusFromLegacyError(legacy_status), valid_frequencies};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700380}
381
382WifiStatus WifiStaIface::startBackgroundScanInternal(
Roshan Pius970f0312016-12-05 15:25:51 -0800383 uint32_t cmd_id, const StaBackgroundScanParameters& params) {
384 legacy_hal::wifi_scan_cmd_params legacy_params;
385 if (!hidl_struct_util::convertHidlGscanParamsToLegacy(params,
386 &legacy_params)) {
387 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
388 }
389 android::wp<WifiStaIface> weak_ptr_this(this);
390 const auto& on_failure_callback =
391 [weak_ptr_this](legacy_hal::wifi_request_id id) {
392 const auto shared_ptr_this = weak_ptr_this.promote();
393 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
394 LOG(ERROR) << "Callback invoked on an invalid object";
395 return;
396 }
397 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
Roshan Piusbc662202017-01-30 17:07:42 -0800398 if (!callback->onBackgroundScanFailure(id).isOk()) {
399 LOG(ERROR) << "Failed to invoke onBackgroundScanFailure callback";
400 }
Roshan Pius970f0312016-12-05 15:25:51 -0800401 }
402 };
403 const auto& on_results_callback = [weak_ptr_this](
404 legacy_hal::wifi_request_id id,
405 const std::vector<legacy_hal::wifi_cached_scan_results>& results) {
406 const auto shared_ptr_this = weak_ptr_this.promote();
407 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
408 LOG(ERROR) << "Callback invoked on an invalid object";
409 return;
410 }
411 std::vector<StaScanData> hidl_scan_datas;
412 if (!hidl_struct_util::convertLegacyVectorOfCachedGscanResultsToHidl(
413 results, &hidl_scan_datas)) {
414 LOG(ERROR) << "Failed to convert scan results to HIDL structs";
415 return;
416 }
417 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
Roshan Piusbc662202017-01-30 17:07:42 -0800418 if (!callback->onBackgroundScanResults(id, hidl_scan_datas).isOk()) {
419 LOG(ERROR) << "Failed to invoke onBackgroundScanResults callback";
420 }
Roshan Pius970f0312016-12-05 15:25:51 -0800421 }
422 };
423 const auto& on_full_result_callback = [weak_ptr_this](
424 legacy_hal::wifi_request_id id,
425 const legacy_hal::wifi_scan_result* result,
Roshan Pius8c0c8e92017-02-24 08:07:42 -0800426 uint32_t buckets_scanned) {
Roshan Pius970f0312016-12-05 15:25:51 -0800427 const auto shared_ptr_this = weak_ptr_this.promote();
428 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
429 LOG(ERROR) << "Callback invoked on an invalid object";
430 return;
431 }
432 StaScanResult hidl_scan_result;
433 if (!hidl_struct_util::convertLegacyGscanResultToHidl(
434 *result, true, &hidl_scan_result)) {
435 LOG(ERROR) << "Failed to convert full scan results to HIDL structs";
436 return;
437 }
438 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
Roshan Pius8c0c8e92017-02-24 08:07:42 -0800439 if (!callback->onBackgroundFullScanResult(
440 id, buckets_scanned, hidl_scan_result).isOk()) {
Roshan Piusbc662202017-01-30 17:07:42 -0800441 LOG(ERROR) << "Failed to invoke onBackgroundFullScanResult callback";
442 }
Roshan Pius970f0312016-12-05 15:25:51 -0800443 }
444 };
445 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700446 legacy_hal_.lock()->startGscan(ifname_,
447 cmd_id,
Roshan Pius970f0312016-12-05 15:25:51 -0800448 legacy_params,
449 on_failure_callback,
450 on_results_callback,
451 on_full_result_callback);
452 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700453}
454
Roshan Pius970f0312016-12-05 15:25:51 -0800455WifiStatus WifiStaIface::stopBackgroundScanInternal(uint32_t cmd_id) {
Roshan Piusacededb2017-10-06 14:59:26 -0700456 legacy_hal::wifi_error legacy_status =
457 legacy_hal_.lock()->stopGscan(ifname_, cmd_id);
Roshan Pius970f0312016-12-05 15:25:51 -0800458 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700459}
460
Roshan Pius970f0312016-12-05 15:25:51 -0800461WifiStatus WifiStaIface::enableLinkLayerStatsCollectionInternal(bool debug) {
462 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700463 legacy_hal_.lock()->enableLinkLayerStats(ifname_, debug);
Roshan Pius970f0312016-12-05 15:25:51 -0800464 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700465}
466
467WifiStatus WifiStaIface::disableLinkLayerStatsCollectionInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800468 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700469 legacy_hal_.lock()->disableLinkLayerStats(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800470 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700471}
472
473std::pair<WifiStatus, StaLinkLayerStats>
474WifiStaIface::getLinkLayerStatsInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800475 legacy_hal::wifi_error legacy_status;
476 legacy_hal::LinkLayerStats legacy_stats;
477 std::tie(legacy_status, legacy_stats) =
Roshan Piusacededb2017-10-06 14:59:26 -0700478 legacy_hal_.lock()->getLinkLayerStats(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800479 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
480 return {createWifiStatusFromLegacyError(legacy_status), {}};
481 }
482 StaLinkLayerStats hidl_stats;
483 if (!hidl_struct_util::convertLegacyLinkLayerStatsToHidl(legacy_stats,
484 &hidl_stats)) {
485 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
486 }
487 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_stats};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700488}
489
Roshan Piusd4767542016-12-06 10:04:05 -0800490WifiStatus WifiStaIface::startRssiMonitoringInternal(uint32_t cmd_id,
491 int32_t max_rssi,
492 int32_t min_rssi) {
493 android::wp<WifiStaIface> weak_ptr_this(this);
494 const auto& on_threshold_breached_callback = [weak_ptr_this](
495 legacy_hal::wifi_request_id id,
496 std::array<uint8_t, 6> bssid,
497 int8_t rssi) {
498 const auto shared_ptr_this = weak_ptr_this.promote();
499 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
500 LOG(ERROR) << "Callback invoked on an invalid object";
501 return;
502 }
503 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
Roshan Piusbc662202017-01-30 17:07:42 -0800504 if (!callback->onRssiThresholdBreached(id, bssid, rssi).isOk()) {
505 LOG(ERROR) << "Failed to invoke onRssiThresholdBreached callback";
506 }
Roshan Piusd4767542016-12-06 10:04:05 -0800507 }
508 };
509 legacy_hal::wifi_error legacy_status =
510 legacy_hal_.lock()->startRssiMonitoring(
Roshan Piusacededb2017-10-06 14:59:26 -0700511 ifname_, cmd_id, max_rssi, min_rssi, on_threshold_breached_callback);
Roshan Piusd4767542016-12-06 10:04:05 -0800512 return createWifiStatusFromLegacyError(legacy_status);
513}
514
515WifiStatus WifiStaIface::stopRssiMonitoringInternal(uint32_t cmd_id) {
516 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700517 legacy_hal_.lock()->stopRssiMonitoring(ifname_, cmd_id);
Roshan Piusd4767542016-12-06 10:04:05 -0800518 return createWifiStatusFromLegacyError(legacy_status);
519}
520
Roshan Pius26801cb2016-12-13 14:25:45 -0800521std::pair<WifiStatus, StaRoamingCapabilities>
522WifiStaIface::getRoamingCapabilitiesInternal() {
523 legacy_hal::wifi_error legacy_status;
524 legacy_hal::wifi_roaming_capabilities legacy_caps;
525 std::tie(legacy_status, legacy_caps) =
Roshan Piusacededb2017-10-06 14:59:26 -0700526 legacy_hal_.lock()->getRoamingCapabilities(ifname_);
Roshan Pius26801cb2016-12-13 14:25:45 -0800527 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
528 return {createWifiStatusFromLegacyError(legacy_status), {}};
529 }
530 StaRoamingCapabilities hidl_caps;
531 if (!hidl_struct_util::convertLegacyRoamingCapabilitiesToHidl(legacy_caps,
532 &hidl_caps)) {
533 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
534 }
535 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
536}
537
538WifiStatus WifiStaIface::configureRoamingInternal(
539 const StaRoamingConfig& config) {
540 legacy_hal::wifi_roaming_config legacy_config;
541 if (!hidl_struct_util::convertHidlRoamingConfigToLegacy(config,
542 &legacy_config)) {
543 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
544 }
545 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700546 legacy_hal_.lock()->configureRoaming(ifname_, legacy_config);
Roshan Pius26801cb2016-12-13 14:25:45 -0800547 return createWifiStatusFromLegacyError(legacy_status);
548}
549
550WifiStatus WifiStaIface::setRoamingStateInternal(StaRoamingState state) {
551 legacy_hal::wifi_error legacy_status =
552 legacy_hal_.lock()->enableFirmwareRoaming(
Roshan Piusacededb2017-10-06 14:59:26 -0700553 ifname_, hidl_struct_util::convertHidlRoamingStateToLegacy(state));
Roshan Pius26801cb2016-12-13 14:25:45 -0800554 return createWifiStatusFromLegacyError(legacy_status);
555}
556
Roshan Piusaf727c02017-01-11 15:37:25 -0800557WifiStatus WifiStaIface::enableNdOffloadInternal(bool enable) {
558 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700559 legacy_hal_.lock()->configureNdOffload(ifname_, enable);
Roshan Piusaf727c02017-01-11 15:37:25 -0800560 return createWifiStatusFromLegacyError(legacy_status);
561}
562
Roshan Pius9a9869a2017-01-11 16:42:16 -0800563WifiStatus WifiStaIface::startSendingKeepAlivePacketsInternal(
564 uint32_t cmd_id,
565 const std::vector<uint8_t>& ip_packet_data,
566 uint16_t /* ether_type */,
567 const std::array<uint8_t, 6>& src_address,
568 const std::array<uint8_t, 6>& dst_address,
569 uint32_t period_in_ms) {
570 legacy_hal::wifi_error legacy_status =
571 legacy_hal_.lock()->startSendingOffloadedPacket(
Roshan Piusacededb2017-10-06 14:59:26 -0700572 ifname_, cmd_id, ip_packet_data, src_address, dst_address,
573 period_in_ms);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800574 return createWifiStatusFromLegacyError(legacy_status);
575}
576
577WifiStatus WifiStaIface::stopSendingKeepAlivePacketsInternal(uint32_t cmd_id) {
578 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700579 legacy_hal_.lock()->stopSendingOffloadedPacket(ifname_, cmd_id);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800580 return createWifiStatusFromLegacyError(legacy_status);
581}
582
Roshan Piusd37341f2017-01-31 13:13:28 -0800583WifiStatus WifiStaIface::setScanningMacOuiInternal(
584 const std::array<uint8_t, 3>& oui) {
Roshan Pius795bb812017-02-01 13:09:08 -0800585 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700586 legacy_hal_.lock()->setScanningMacOui(ifname_, oui);
Roshan Pius795bb812017-02-01 13:09:08 -0800587 return createWifiStatusFromLegacyError(legacy_status);
588}
589
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700590WifiStatus WifiStaIface::startDebugPacketFateMonitoringInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800591 legacy_hal::wifi_error legacy_status =
Roshan Piusacededb2017-10-06 14:59:26 -0700592 legacy_hal_.lock()->startPktFateMonitoring(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800593 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700594}
595
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700596std::pair<WifiStatus, std::vector<WifiDebugTxPacketFateReport>>
597WifiStaIface::getDebugTxPacketFatesInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800598 legacy_hal::wifi_error legacy_status;
599 std::vector<legacy_hal::wifi_tx_report> legacy_fates;
Roshan Piusacededb2017-10-06 14:59:26 -0700600 std::tie(legacy_status, legacy_fates) =
601 legacy_hal_.lock()->getTxPktFates(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800602 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
603 return {createWifiStatusFromLegacyError(legacy_status), {}};
604 }
605 std::vector<WifiDebugTxPacketFateReport> hidl_fates;
606 if (!hidl_struct_util::convertLegacyVectorOfDebugTxPacketFateToHidl(
607 legacy_fates, &hidl_fates)) {
608 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
609 }
610 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_fates};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700611}
612
613std::pair<WifiStatus, std::vector<WifiDebugRxPacketFateReport>>
614WifiStaIface::getDebugRxPacketFatesInternal() {
Roshan Pius970f0312016-12-05 15:25:51 -0800615 legacy_hal::wifi_error legacy_status;
616 std::vector<legacy_hal::wifi_rx_report> legacy_fates;
Roshan Piusacededb2017-10-06 14:59:26 -0700617 std::tie(legacy_status, legacy_fates) =
618 legacy_hal_.lock()->getRxPktFates(ifname_);
Roshan Pius970f0312016-12-05 15:25:51 -0800619 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
620 return {createWifiStatusFromLegacyError(legacy_status), {}};
621 }
622 std::vector<WifiDebugRxPacketFateReport> hidl_fates;
623 if (!hidl_struct_util::convertLegacyVectorOfDebugRxPacketFateToHidl(
624 legacy_fates, &hidl_fates)) {
625 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
626 }
627 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_fates};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700628}
629
Roshan Pius3e2d6712016-10-06 13:16:23 -0700630} // namespace implementation
Etan Cohen6ce50902017-09-14 07:30:57 -0700631} // namespace V1_2
Roshan Pius3e2d6712016-10-06 13:16:23 -0700632} // namespace wifi
633} // namespace hardware
634} // namespace android