blob: 92c9fe439276371bd8c1be000f7e7f643ccc5622 [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 {
Jimmy Chend460df32019-11-29 17:31:22 +020027namespace V1_5 {
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,
Roshan Pius99dab382019-02-14 07:57:10 -080033 const std::weak_ptr<legacy_hal::WifiLegacyHal> legacy_hal,
34 const std::weak_ptr<iface_util::WifiIfaceUtil> iface_util)
35 : ifname_(ifname),
36 legacy_hal_(legacy_hal),
37 iface_util_(iface_util),
38 is_valid_(true) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070039 // Turn on DFS channel usage for STA iface.
40 legacy_hal::wifi_error legacy_status =
41 legacy_hal_.lock()->setDfsFlag(ifname_, true);
42 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
43 LOG(ERROR)
44 << "Failed to set DFS flag; DFS channels may be unavailable.";
45 }
Roshan Pius08d1df42017-04-19 23:11:07 -070046}
Roshan Pius3e2d6712016-10-06 13:16:23 -070047
48void WifiStaIface::invalidate() {
Roshan Piusabcf78f2017-10-06 16:30:38 -070049 legacy_hal_.reset();
50 event_cb_handler_.invalidate();
51 is_valid_ = false;
Roshan Pius3e2d6712016-10-06 13:16:23 -070052}
53
Roshan Piusabcf78f2017-10-06 16:30:38 -070054bool WifiStaIface::isValid() { return is_valid_; }
Roshan Pius907d4a22016-10-27 12:48:12 -070055
Roshan Pius675609b2017-10-31 14:24:58 -070056std::string WifiStaIface::getName() { return ifname_; }
57
Roshan Piusd37341f2017-01-31 13:13:28 -080058std::set<sp<IWifiStaIfaceEventCallback>> WifiStaIface::getEventCallbacks() {
Roshan Piusabcf78f2017-10-06 16:30:38 -070059 return event_cb_handler_.getCallbacks();
Roshan Pius970f0312016-12-05 15:25:51 -080060}
61
Roshan Pius734fea02016-10-11 08:30:28 -070062Return<void> WifiStaIface::getName(getName_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070063 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
64 &WifiStaIface::getNameInternal, hidl_status_cb);
Roshan Pius3e2d6712016-10-06 13:16:23 -070065}
66
Roshan Pius734fea02016-10-11 08:30:28 -070067Return<void> WifiStaIface::getType(getType_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070068 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
69 &WifiStaIface::getTypeInternal, hidl_status_cb);
Roshan Pius907d4a22016-10-27 12:48:12 -070070}
71
Roshan Piusa04ba3f2016-10-27 14:36:26 -070072Return<void> WifiStaIface::registerEventCallback(
73 const sp<IWifiStaIfaceEventCallback>& callback,
74 registerEventCallback_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070075 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
76 &WifiStaIface::registerEventCallbackInternal,
77 hidl_status_cb, callback);
Roshan Piusa04ba3f2016-10-27 14:36:26 -070078}
79
80Return<void> WifiStaIface::getCapabilities(getCapabilities_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070081 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
82 &WifiStaIface::getCapabilitiesInternal,
83 hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -070084}
85
86Return<void> WifiStaIface::getApfPacketFilterCapabilities(
87 getApfPacketFilterCapabilities_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070088 return validateAndCall(
89 this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
90 &WifiStaIface::getApfPacketFilterCapabilitiesInternal, hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -070091}
92
93Return<void> WifiStaIface::installApfPacketFilter(
Roshan Piusabcf78f2017-10-06 16:30:38 -070094 uint32_t cmd_id, const hidl_vec<uint8_t>& program,
Roshan Piusa04ba3f2016-10-27 14:36:26 -070095 installApfPacketFilter_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -070096 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
97 &WifiStaIface::installApfPacketFilterInternal,
98 hidl_status_cb, cmd_id, program);
Roshan Piusa04ba3f2016-10-27 14:36:26 -070099}
100
Bernie Innocenti7e6f71a2018-03-07 00:17:50 +0900101Return<void> WifiStaIface::readApfPacketFilterData(
102 readApfPacketFilterData_cb hidl_status_cb) {
103 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
104 &WifiStaIface::readApfPacketFilterDataInternal,
105 hidl_status_cb);
106}
107
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700108Return<void> WifiStaIface::getBackgroundScanCapabilities(
109 getBackgroundScanCapabilities_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700110 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
111 &WifiStaIface::getBackgroundScanCapabilitiesInternal,
112 hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700113}
114
Roshan Pius7f4574d2017-02-22 09:48:03 -0800115Return<void> WifiStaIface::getValidFrequenciesForBand(
Ahmed ElArabawyfd809fc2019-11-15 18:19:15 -0800116 V1_0::WifiBand band, getValidFrequenciesForBand_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700117 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
118 &WifiStaIface::getValidFrequenciesForBandInternal,
119 hidl_status_cb, band);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700120}
121
122Return<void> WifiStaIface::startBackgroundScan(
Roshan Piusabcf78f2017-10-06 16:30:38 -0700123 uint32_t cmd_id, const StaBackgroundScanParameters& params,
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700124 startBackgroundScan_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700125 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
126 &WifiStaIface::startBackgroundScanInternal,
127 hidl_status_cb, cmd_id, params);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700128}
129
130Return<void> WifiStaIface::stopBackgroundScan(
131 uint32_t cmd_id, stopBackgroundScan_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700132 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
133 &WifiStaIface::stopBackgroundScanInternal,
134 hidl_status_cb, cmd_id);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700135}
136
137Return<void> WifiStaIface::enableLinkLayerStatsCollection(
138 bool debug, enableLinkLayerStatsCollection_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700139 return validateAndCall(
140 this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
141 &WifiStaIface::enableLinkLayerStatsCollectionInternal, hidl_status_cb,
142 debug);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700143}
144
145Return<void> WifiStaIface::disableLinkLayerStatsCollection(
146 disableLinkLayerStatsCollection_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700147 return validateAndCall(
148 this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
149 &WifiStaIface::disableLinkLayerStatsCollectionInternal, hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700150}
151
152Return<void> WifiStaIface::getLinkLayerStats(
153 getLinkLayerStats_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700154 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
155 &WifiStaIface::getLinkLayerStatsInternal,
156 hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700157}
158
xshue9873252018-08-07 11:04:34 -0700159Return<void> WifiStaIface::getLinkLayerStats_1_3(
160 getLinkLayerStats_1_3_cb hidl_status_cb) {
161 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
162 &WifiStaIface::getLinkLayerStatsInternal_1_3,
163 hidl_status_cb);
164}
165
Roshan Piuse9d1e7d2020-11-04 11:44:16 -0800166Return<void> WifiStaIface::getLinkLayerStats_1_5(
167 getLinkLayerStats_1_5_cb hidl_status_cb) {
168 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
169 &WifiStaIface::getLinkLayerStatsInternal_1_5,
170 hidl_status_cb);
171}
172
Roshan Piusd4767542016-12-06 10:04:05 -0800173Return<void> WifiStaIface::startRssiMonitoring(
Roshan Piusabcf78f2017-10-06 16:30:38 -0700174 uint32_t cmd_id, int32_t max_rssi, int32_t min_rssi,
Roshan Piusd4767542016-12-06 10:04:05 -0800175 startRssiMonitoring_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700176 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
177 &WifiStaIface::startRssiMonitoringInternal,
178 hidl_status_cb, cmd_id, max_rssi, min_rssi);
Roshan Piusd4767542016-12-06 10:04:05 -0800179}
180
181Return<void> WifiStaIface::stopRssiMonitoring(
182 uint32_t cmd_id, stopRssiMonitoring_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700183 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
184 &WifiStaIface::stopRssiMonitoringInternal,
185 hidl_status_cb, cmd_id);
Roshan Piusd4767542016-12-06 10:04:05 -0800186}
187
Roshan Pius26801cb2016-12-13 14:25:45 -0800188Return<void> WifiStaIface::getRoamingCapabilities(
189 getRoamingCapabilities_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700190 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
191 &WifiStaIface::getRoamingCapabilitiesInternal,
192 hidl_status_cb);
Roshan Pius26801cb2016-12-13 14:25:45 -0800193}
194
195Return<void> WifiStaIface::configureRoaming(
196 const StaRoamingConfig& config, configureRoaming_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700197 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
198 &WifiStaIface::configureRoamingInternal,
199 hidl_status_cb, config);
Roshan Pius26801cb2016-12-13 14:25:45 -0800200}
201
202Return<void> WifiStaIface::setRoamingState(StaRoamingState state,
203 setRoamingState_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700204 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
205 &WifiStaIface::setRoamingStateInternal,
206 hidl_status_cb, state);
Roshan Pius26801cb2016-12-13 14:25:45 -0800207}
208
Roshan Piusaf727c02017-01-11 15:37:25 -0800209Return<void> WifiStaIface::enableNdOffload(bool enable,
210 enableNdOffload_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700211 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
212 &WifiStaIface::enableNdOffloadInternal,
213 hidl_status_cb, enable);
Roshan Piusaf727c02017-01-11 15:37:25 -0800214}
215
Roshan Pius9a9869a2017-01-11 16:42:16 -0800216Return<void> WifiStaIface::startSendingKeepAlivePackets(
Roshan Piusabcf78f2017-10-06 16:30:38 -0700217 uint32_t cmd_id, const hidl_vec<uint8_t>& ip_packet_data,
218 uint16_t ether_type, const hidl_array<uint8_t, 6>& src_address,
219 const hidl_array<uint8_t, 6>& dst_address, uint32_t period_in_ms,
Roshan Pius9a9869a2017-01-11 16:42:16 -0800220 startSendingKeepAlivePackets_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700221 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
222 &WifiStaIface::startSendingKeepAlivePacketsInternal,
223 hidl_status_cb, cmd_id, ip_packet_data, ether_type,
224 src_address, dst_address, period_in_ms);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800225}
226
227Return<void> WifiStaIface::stopSendingKeepAlivePackets(
228 uint32_t cmd_id, stopSendingKeepAlivePackets_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700229 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
230 &WifiStaIface::stopSendingKeepAlivePacketsInternal,
231 hidl_status_cb, cmd_id);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800232}
233
Roshan Pius795bb812017-02-01 13:09:08 -0800234Return<void> WifiStaIface::setScanningMacOui(
235 const hidl_array<uint8_t, 3>& oui, setScanningMacOui_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700236 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
237 &WifiStaIface::setScanningMacOuiInternal,
238 hidl_status_cb, oui);
Roshan Pius795bb812017-02-01 13:09:08 -0800239}
240
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700241Return<void> WifiStaIface::startDebugPacketFateMonitoring(
242 startDebugPacketFateMonitoring_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700243 return validateAndCall(
244 this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
245 &WifiStaIface::startDebugPacketFateMonitoringInternal, hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700246}
247
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700248Return<void> WifiStaIface::getDebugTxPacketFates(
249 getDebugTxPacketFates_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700250 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
251 &WifiStaIface::getDebugTxPacketFatesInternal,
252 hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700253}
254
255Return<void> WifiStaIface::getDebugRxPacketFates(
256 getDebugRxPacketFates_cb hidl_status_cb) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700257 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
258 &WifiStaIface::getDebugRxPacketFatesInternal,
259 hidl_status_cb);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700260}
261
Jong Wook Kimb9f0ff92018-03-16 16:21:49 -0700262Return<void> WifiStaIface::setMacAddress(const hidl_array<uint8_t, 6>& mac,
263 setMacAddress_cb hidl_status_cb) {
264 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
265 &WifiStaIface::setMacAddressInternal, hidl_status_cb,
266 mac);
267}
268
Jong Wook Kim0ee77432018-08-08 18:57:26 -0700269Return<void> WifiStaIface::getFactoryMacAddress(
270 getFactoryMacAddress_cb hidl_status_cb) {
271 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
272 &WifiStaIface::getFactoryMacAddressInternal,
273 hidl_status_cb);
274}
275
Ye Jiaoc6b5f892021-01-15 15:42:09 +0800276Return<void> WifiStaIface::setScanMode(bool enable,
277 setScanMode_cb hidl_status_cb) {
278 return validateAndCall(this, WifiStatusCode::ERROR_WIFI_IFACE_INVALID,
279 &WifiStaIface::setScanModeInternal, hidl_status_cb,
280 enable);
281}
282
Roshan Pius907d4a22016-10-27 12:48:12 -0700283std::pair<WifiStatus, std::string> WifiStaIface::getNameInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700284 return {createWifiStatus(WifiStatusCode::SUCCESS), ifname_};
Roshan Pius907d4a22016-10-27 12:48:12 -0700285}
286
287std::pair<WifiStatus, IfaceType> WifiStaIface::getTypeInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700288 return {createWifiStatus(WifiStatusCode::SUCCESS), IfaceType::STA};
Roshan Pius3e2d6712016-10-06 13:16:23 -0700289}
290
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700291WifiStatus WifiStaIface::registerEventCallbackInternal(
292 const sp<IWifiStaIfaceEventCallback>& callback) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700293 if (!event_cb_handler_.addCallback(callback)) {
294 return createWifiStatus(WifiStatusCode::ERROR_UNKNOWN);
295 }
296 return createWifiStatus(WifiStatusCode::SUCCESS);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700297}
298
299std::pair<WifiStatus, uint32_t> WifiStaIface::getCapabilitiesInternal() {
Ahmed ElArabawyb23485d2019-12-09 15:24:16 -0800300 legacy_hal::wifi_error legacy_status;
301 uint64_t legacy_feature_set;
302 std::tie(legacy_status, legacy_feature_set) =
303 legacy_hal_.lock()->getSupportedFeatureSet(ifname_);
304 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
305 return {createWifiStatusFromLegacyError(legacy_status), 0};
306 }
307 uint32_t legacy_logger_feature_set;
308 std::tie(legacy_status, legacy_logger_feature_set) =
309 legacy_hal_.lock()->getLoggerSupportedFeatureSet(ifname_);
310 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
311 // some devices don't support querying logger feature set
312 legacy_logger_feature_set = 0;
313 }
314 uint32_t hidl_caps;
315 if (!hidl_struct_util::convertLegacyFeaturesToHidlStaCapabilities(
316 legacy_feature_set, legacy_logger_feature_set, &hidl_caps)) {
317 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), 0};
318 }
319 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700320}
321
322std::pair<WifiStatus, StaApfPacketFilterCapabilities>
323WifiStaIface::getApfPacketFilterCapabilitiesInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700324 legacy_hal::wifi_error legacy_status;
325 legacy_hal::PacketFilterCapabilities legacy_caps;
326 std::tie(legacy_status, legacy_caps) =
327 legacy_hal_.lock()->getPacketFilterCapabilities(ifname_);
328 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
329 return {createWifiStatusFromLegacyError(legacy_status), {}};
330 }
331 StaApfPacketFilterCapabilities hidl_caps;
332 if (!hidl_struct_util::convertLegacyApfCapabilitiesToHidl(legacy_caps,
333 &hidl_caps)) {
334 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
335 }
336 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700337}
338
339WifiStatus WifiStaIface::installApfPacketFilterInternal(
Roshan Pius970f0312016-12-05 15:25:51 -0800340 uint32_t /* cmd_id */, const std::vector<uint8_t>& program) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700341 legacy_hal::wifi_error legacy_status =
342 legacy_hal_.lock()->setPacketFilter(ifname_, program);
343 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700344}
345
Bernie Innocenti7e6f71a2018-03-07 00:17:50 +0900346std::pair<WifiStatus, std::vector<uint8_t>>
347WifiStaIface::readApfPacketFilterDataInternal() {
348 const std::pair<legacy_hal::wifi_error, std::vector<uint8_t>>
349 legacy_status_and_data =
350 legacy_hal_.lock()->readApfPacketFilterData(ifname_);
351 return {createWifiStatusFromLegacyError(legacy_status_and_data.first),
352 std::move(legacy_status_and_data.second)};
353}
354
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700355std::pair<WifiStatus, StaBackgroundScanCapabilities>
356WifiStaIface::getBackgroundScanCapabilitiesInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700357 legacy_hal::wifi_error legacy_status;
358 legacy_hal::wifi_gscan_capabilities legacy_caps;
359 std::tie(legacy_status, legacy_caps) =
360 legacy_hal_.lock()->getGscanCapabilities(ifname_);
361 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
362 return {createWifiStatusFromLegacyError(legacy_status), {}};
363 }
364 StaBackgroundScanCapabilities hidl_caps;
365 if (!hidl_struct_util::convertLegacyGscanCapabilitiesToHidl(legacy_caps,
366 &hidl_caps)) {
367 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
368 }
369 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700370}
371
372std::pair<WifiStatus, std::vector<WifiChannelInMhz>>
Ahmed ElArabawyfd809fc2019-11-15 18:19:15 -0800373WifiStaIface::getValidFrequenciesForBandInternal(V1_0::WifiBand band) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700374 static_assert(sizeof(WifiChannelInMhz) == sizeof(uint32_t),
375 "Size mismatch");
376 legacy_hal::wifi_error legacy_status;
377 std::vector<uint32_t> valid_frequencies;
378 std::tie(legacy_status, valid_frequencies) =
379 legacy_hal_.lock()->getValidFrequenciesForBand(
380 ifname_, hidl_struct_util::convertHidlWifiBandToLegacy(band));
381 return {createWifiStatusFromLegacyError(legacy_status), valid_frequencies};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700382}
383
384WifiStatus WifiStaIface::startBackgroundScanInternal(
Roshan Pius970f0312016-12-05 15:25:51 -0800385 uint32_t cmd_id, const StaBackgroundScanParameters& params) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700386 legacy_hal::wifi_scan_cmd_params legacy_params;
387 if (!hidl_struct_util::convertHidlGscanParamsToLegacy(params,
388 &legacy_params)) {
389 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
390 }
391 android::wp<WifiStaIface> weak_ptr_this(this);
392 const auto& on_failure_callback =
393 [weak_ptr_this](legacy_hal::wifi_request_id id) {
394 const auto shared_ptr_this = weak_ptr_this.promote();
395 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
396 LOG(ERROR) << "Callback invoked on an invalid object";
397 return;
398 }
399 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
400 if (!callback->onBackgroundScanFailure(id).isOk()) {
401 LOG(ERROR)
402 << "Failed to invoke onBackgroundScanFailure callback";
403 }
404 }
405 };
406 const auto& on_results_callback =
407 [weak_ptr_this](
408 legacy_hal::wifi_request_id id,
409 const std::vector<legacy_hal::wifi_cached_scan_results>& results) {
410 const auto shared_ptr_this = weak_ptr_this.promote();
411 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
412 LOG(ERROR) << "Callback invoked on an invalid object";
413 return;
414 }
415 std::vector<StaScanData> hidl_scan_datas;
416 if (!hidl_struct_util::
417 convertLegacyVectorOfCachedGscanResultsToHidl(
418 results, &hidl_scan_datas)) {
419 LOG(ERROR) << "Failed to convert scan results to HIDL structs";
420 return;
421 }
422 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
423 if (!callback->onBackgroundScanResults(id, hidl_scan_datas)
424 .isOk()) {
425 LOG(ERROR)
426 << "Failed to invoke onBackgroundScanResults callback";
427 }
428 }
429 };
430 const auto& on_full_result_callback = [weak_ptr_this](
431 legacy_hal::wifi_request_id id,
432 const legacy_hal::
433 wifi_scan_result* result,
434 uint32_t buckets_scanned) {
Roshan Pius970f0312016-12-05 15:25:51 -0800435 const auto shared_ptr_this = weak_ptr_this.promote();
436 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700437 LOG(ERROR) << "Callback invoked on an invalid object";
438 return;
439 }
440 StaScanResult hidl_scan_result;
441 if (!hidl_struct_util::convertLegacyGscanResultToHidl(
442 *result, true, &hidl_scan_result)) {
443 LOG(ERROR) << "Failed to convert full scan results to HIDL structs";
444 return;
Roshan Pius970f0312016-12-05 15:25:51 -0800445 }
446 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700447 if (!callback
448 ->onBackgroundFullScanResult(id, buckets_scanned,
449 hidl_scan_result)
450 .isOk()) {
451 LOG(ERROR)
452 << "Failed to invoke onBackgroundFullScanResult callback";
453 }
Roshan Pius970f0312016-12-05 15:25:51 -0800454 }
Roshan Piusabcf78f2017-10-06 16:30:38 -0700455 };
456 legacy_hal::wifi_error legacy_status = legacy_hal_.lock()->startGscan(
457 ifname_, cmd_id, legacy_params, on_failure_callback,
458 on_results_callback, on_full_result_callback);
459 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700460}
461
Roshan Pius970f0312016-12-05 15:25:51 -0800462WifiStatus WifiStaIface::stopBackgroundScanInternal(uint32_t cmd_id) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700463 legacy_hal::wifi_error legacy_status =
464 legacy_hal_.lock()->stopGscan(ifname_, cmd_id);
465 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700466}
467
Roshan Pius970f0312016-12-05 15:25:51 -0800468WifiStatus WifiStaIface::enableLinkLayerStatsCollectionInternal(bool debug) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700469 legacy_hal::wifi_error legacy_status =
470 legacy_hal_.lock()->enableLinkLayerStats(ifname_, debug);
471 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700472}
473
474WifiStatus WifiStaIface::disableLinkLayerStatsCollectionInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700475 legacy_hal::wifi_error legacy_status =
476 legacy_hal_.lock()->disableLinkLayerStats(ifname_);
477 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700478}
479
xshue9873252018-08-07 11:04:34 -0700480std::pair<WifiStatus, V1_0::StaLinkLayerStats>
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700481WifiStaIface::getLinkLayerStatsInternal() {
xshue9873252018-08-07 11:04:34 -0700482 return {createWifiStatus(WifiStatusCode::ERROR_NOT_SUPPORTED), {}};
483}
484
485std::pair<WifiStatus, V1_3::StaLinkLayerStats>
486WifiStaIface::getLinkLayerStatsInternal_1_3() {
Roshan Piuse9d1e7d2020-11-04 11:44:16 -0800487 return {createWifiStatus(WifiStatusCode::ERROR_NOT_SUPPORTED), {}};
488}
489
490std::pair<WifiStatus, V1_5::StaLinkLayerStats>
491WifiStaIface::getLinkLayerStatsInternal_1_5() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700492 legacy_hal::wifi_error legacy_status;
493 legacy_hal::LinkLayerStats legacy_stats;
494 std::tie(legacy_status, legacy_stats) =
495 legacy_hal_.lock()->getLinkLayerStats(ifname_);
496 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
497 return {createWifiStatusFromLegacyError(legacy_status), {}};
498 }
Roshan Piuse9d1e7d2020-11-04 11:44:16 -0800499 V1_5::StaLinkLayerStats hidl_stats;
Roshan Piusabcf78f2017-10-06 16:30:38 -0700500 if (!hidl_struct_util::convertLegacyLinkLayerStatsToHidl(legacy_stats,
501 &hidl_stats)) {
502 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
503 }
504 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_stats};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700505}
506
Roshan Piusd4767542016-12-06 10:04:05 -0800507WifiStatus WifiStaIface::startRssiMonitoringInternal(uint32_t cmd_id,
508 int32_t max_rssi,
509 int32_t min_rssi) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700510 android::wp<WifiStaIface> weak_ptr_this(this);
511 const auto& on_threshold_breached_callback =
512 [weak_ptr_this](legacy_hal::wifi_request_id id,
513 std::array<uint8_t, 6> bssid, int8_t rssi) {
514 const auto shared_ptr_this = weak_ptr_this.promote();
515 if (!shared_ptr_this.get() || !shared_ptr_this->isValid()) {
516 LOG(ERROR) << "Callback invoked on an invalid object";
517 return;
518 }
519 for (const auto& callback : shared_ptr_this->getEventCallbacks()) {
520 if (!callback->onRssiThresholdBreached(id, bssid, rssi)
521 .isOk()) {
522 LOG(ERROR)
523 << "Failed to invoke onRssiThresholdBreached callback";
524 }
525 }
526 };
527 legacy_hal::wifi_error legacy_status =
528 legacy_hal_.lock()->startRssiMonitoring(ifname_, cmd_id, max_rssi,
529 min_rssi,
530 on_threshold_breached_callback);
531 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusd4767542016-12-06 10:04:05 -0800532}
533
534WifiStatus WifiStaIface::stopRssiMonitoringInternal(uint32_t cmd_id) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700535 legacy_hal::wifi_error legacy_status =
536 legacy_hal_.lock()->stopRssiMonitoring(ifname_, cmd_id);
537 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusd4767542016-12-06 10:04:05 -0800538}
539
Roshan Pius26801cb2016-12-13 14:25:45 -0800540std::pair<WifiStatus, StaRoamingCapabilities>
541WifiStaIface::getRoamingCapabilitiesInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700542 legacy_hal::wifi_error legacy_status;
543 legacy_hal::wifi_roaming_capabilities legacy_caps;
544 std::tie(legacy_status, legacy_caps) =
545 legacy_hal_.lock()->getRoamingCapabilities(ifname_);
546 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
547 return {createWifiStatusFromLegacyError(legacy_status), {}};
548 }
549 StaRoamingCapabilities hidl_caps;
550 if (!hidl_struct_util::convertLegacyRoamingCapabilitiesToHidl(legacy_caps,
551 &hidl_caps)) {
552 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
553 }
554 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
Roshan Pius26801cb2016-12-13 14:25:45 -0800555}
556
557WifiStatus WifiStaIface::configureRoamingInternal(
558 const StaRoamingConfig& config) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700559 legacy_hal::wifi_roaming_config legacy_config;
560 if (!hidl_struct_util::convertHidlRoamingConfigToLegacy(config,
561 &legacy_config)) {
562 return createWifiStatus(WifiStatusCode::ERROR_INVALID_ARGS);
563 }
564 legacy_hal::wifi_error legacy_status =
565 legacy_hal_.lock()->configureRoaming(ifname_, legacy_config);
566 return createWifiStatusFromLegacyError(legacy_status);
Roshan Pius26801cb2016-12-13 14:25:45 -0800567}
568
569WifiStatus WifiStaIface::setRoamingStateInternal(StaRoamingState state) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700570 legacy_hal::wifi_error legacy_status =
571 legacy_hal_.lock()->enableFirmwareRoaming(
572 ifname_, hidl_struct_util::convertHidlRoamingStateToLegacy(state));
573 return createWifiStatusFromLegacyError(legacy_status);
Roshan Pius26801cb2016-12-13 14:25:45 -0800574}
575
Roshan Piusaf727c02017-01-11 15:37:25 -0800576WifiStatus WifiStaIface::enableNdOffloadInternal(bool enable) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700577 legacy_hal::wifi_error legacy_status =
578 legacy_hal_.lock()->configureNdOffload(ifname_, enable);
579 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusaf727c02017-01-11 15:37:25 -0800580}
581
Roshan Pius9a9869a2017-01-11 16:42:16 -0800582WifiStatus WifiStaIface::startSendingKeepAlivePacketsInternal(
Roshan Piusabcf78f2017-10-06 16:30:38 -0700583 uint32_t cmd_id, const std::vector<uint8_t>& ip_packet_data,
Ahmed ElArabawyffbad182019-03-05 17:38:06 -0800584 uint16_t ether_type, const std::array<uint8_t, 6>& src_address,
Roshan Piusabcf78f2017-10-06 16:30:38 -0700585 const std::array<uint8_t, 6>& dst_address, uint32_t period_in_ms) {
586 legacy_hal::wifi_error legacy_status =
587 legacy_hal_.lock()->startSendingOffloadedPacket(
Ahmed ElArabawyffbad182019-03-05 17:38:06 -0800588 ifname_, cmd_id, ether_type, ip_packet_data, src_address,
589 dst_address, period_in_ms);
Roshan Piusabcf78f2017-10-06 16:30:38 -0700590 return createWifiStatusFromLegacyError(legacy_status);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800591}
592
593WifiStatus WifiStaIface::stopSendingKeepAlivePacketsInternal(uint32_t cmd_id) {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700594 legacy_hal::wifi_error legacy_status =
595 legacy_hal_.lock()->stopSendingOffloadedPacket(ifname_, cmd_id);
596 return createWifiStatusFromLegacyError(legacy_status);
Roshan Pius9a9869a2017-01-11 16:42:16 -0800597}
598
Roshan Piusd37341f2017-01-31 13:13:28 -0800599WifiStatus WifiStaIface::setScanningMacOuiInternal(
Roshan Pius322677a2020-04-16 16:18:23 -0700600 const std::array<uint8_t, 3>& /* oui */) {
601 // deprecated.
602 return createWifiStatus(WifiStatusCode::ERROR_NOT_SUPPORTED);
Roshan Pius795bb812017-02-01 13:09:08 -0800603}
604
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700605WifiStatus WifiStaIface::startDebugPacketFateMonitoringInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700606 legacy_hal::wifi_error legacy_status =
607 legacy_hal_.lock()->startPktFateMonitoring(ifname_);
608 return createWifiStatusFromLegacyError(legacy_status);
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700609}
610
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700611std::pair<WifiStatus, std::vector<WifiDebugTxPacketFateReport>>
612WifiStaIface::getDebugTxPacketFatesInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700613 legacy_hal::wifi_error legacy_status;
614 std::vector<legacy_hal::wifi_tx_report> legacy_fates;
615 std::tie(legacy_status, legacy_fates) =
616 legacy_hal_.lock()->getTxPktFates(ifname_);
617 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
618 return {createWifiStatusFromLegacyError(legacy_status), {}};
619 }
620 std::vector<WifiDebugTxPacketFateReport> hidl_fates;
621 if (!hidl_struct_util::convertLegacyVectorOfDebugTxPacketFateToHidl(
622 legacy_fates, &hidl_fates)) {
623 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
624 }
625 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_fates};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700626}
627
628std::pair<WifiStatus, std::vector<WifiDebugRxPacketFateReport>>
629WifiStaIface::getDebugRxPacketFatesInternal() {
Roshan Piusabcf78f2017-10-06 16:30:38 -0700630 legacy_hal::wifi_error legacy_status;
631 std::vector<legacy_hal::wifi_rx_report> legacy_fates;
632 std::tie(legacy_status, legacy_fates) =
633 legacy_hal_.lock()->getRxPktFates(ifname_);
634 if (legacy_status != legacy_hal::WIFI_SUCCESS) {
635 return {createWifiStatusFromLegacyError(legacy_status), {}};
636 }
637 std::vector<WifiDebugRxPacketFateReport> hidl_fates;
638 if (!hidl_struct_util::convertLegacyVectorOfDebugRxPacketFateToHidl(
639 legacy_fates, &hidl_fates)) {
640 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
641 }
642 return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_fates};
Roshan Piusa04ba3f2016-10-27 14:36:26 -0700643}
644
Jong Wook Kimb9f0ff92018-03-16 16:21:49 -0700645WifiStatus WifiStaIface::setMacAddressInternal(
646 const std::array<uint8_t, 6>& mac) {
Roshan Pius99dab382019-02-14 07:57:10 -0800647 bool status = iface_util_.lock()->setMacAddress(ifname_, mac);
648 if (!status) {
Jong Wook Kimb9f0ff92018-03-16 16:21:49 -0700649 return createWifiStatus(WifiStatusCode::ERROR_UNKNOWN);
650 }
Jong Wook Kimb9f0ff92018-03-16 16:21:49 -0700651 return createWifiStatus(WifiStatusCode::SUCCESS);
652}
653
Jong Wook Kim0ee77432018-08-08 18:57:26 -0700654std::pair<WifiStatus, std::array<uint8_t, 6>>
655WifiStaIface::getFactoryMacAddressInternal() {
656 std::array<uint8_t, 6> mac =
Roshan Pius99dab382019-02-14 07:57:10 -0800657 iface_util_.lock()->getFactoryMacAddress(ifname_);
Alessandro Astone40e57ca2020-11-11 18:41:30 +0100658 if (mac[0] == 0 && mac[1] == 0 && mac[2] == 0 && mac[3] == 0 &&
659 mac[4] == 0 && mac[5] == 0) {
660 return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), mac};
661 }
Jong Wook Kim0ee77432018-08-08 18:57:26 -0700662 return {createWifiStatus(WifiStatusCode::SUCCESS), mac};
663}
664
Ye Jiaoc6b5f892021-01-15 15:42:09 +0800665WifiStatus WifiStaIface::setScanModeInternal(bool enable) {
666 // OEM's need to implement this on their devices if needed.
667 LOG(WARNING) << "setScanModeInternal(" << enable << ") not supported";
668 return createWifiStatus(WifiStatusCode::ERROR_NOT_SUPPORTED);
669}
670
Roshan Pius3e2d6712016-10-06 13:16:23 -0700671} // namespace implementation
Jimmy Chend460df32019-11-29 17:31:22 +0200672} // namespace V1_5
Roshan Pius3e2d6712016-10-06 13:16:23 -0700673} // namespace wifi
674} // namespace hardware
675} // namespace android