/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "wificond/scanning/offload/offload_scan_utils.h"
#include <android-base/logging.h>
#include <utils/Timers.h>
#include "wificond/scanning/offload/scan_stats.h"
#include "wificond/scanning/scan_result.h"
using ::com::android::server::wifi::wificond::NativeScanResult;
using ::com::android::server::wifi::wificond::NativeScanStats;
using android::hardware::wifi::offload::V1_0::ScanResult;
using android::hardware::wifi::offload::V1_0::ScanParam;
using android::hardware::wifi::offload::V1_0::ScanFilter;
using android::hardware::wifi::offload::V1_0::ScanStats;
using android::hardware::wifi::offload::V1_0::NetworkInfo;
using android::hardware::hidl_vec;
using std::vector;
namespace android {
namespace wificond {
bool OffloadScanUtils::convertToNativeScanResults(
const vector<ScanResult>& scan_result,
vector<NativeScanResult>* native_scan_result) {
if (native_scan_result == nullptr) return false;
for (size_t i = 0; i < scan_result.size(); i++) {
NativeScanResult single_scan_result;
single_scan_result.ssid.assign(scan_result[i].networkInfo.ssid.begin(),
scan_result[i].networkInfo.ssid.end());
for (size_t j = 0; j < scan_result[i].bssid.elementCount(); j++) {
single_scan_result.bssid.at(j) = scan_result[i].bssid[j];
}
single_scan_result.frequency = scan_result[i].frequency;
single_scan_result.signal_mbm = scan_result[i].rssi;
single_scan_result.tsf = systemTime(SYSTEM_TIME_MONOTONIC) / 1000;
single_scan_result.capability = scan_result[i].capability;
single_scan_result.associated = false;
native_scan_result->push_back(std::move(single_scan_result));
}
return true;
}
ScanParam OffloadScanUtils::createScanParam(
const vector<vector<uint8_t>>& ssid_list,
const vector<uint32_t>& frequency_list, uint32_t scan_interval_ms) {
ScanParam scan_param;
scan_param.disconnectedModeScanIntervalMs = scan_interval_ms;
scan_param.frequencyList = frequency_list;
vector<hidl_vec<uint8_t>> ssid_list_tmp;
for (const auto& ssid : ssid_list) {
ssid_list_tmp.push_back(ssid);
}
scan_param.ssidList = ssid_list_tmp;
return scan_param;
}
ScanFilter OffloadScanUtils::createScanFilter(
const vector<vector<uint8_t>>& ssids, const vector<uint8_t>& flags,
int8_t rssi_threshold) {
ScanFilter scan_filter;
vector<NetworkInfo> nw_info_list;
size_t i = 0;
scan_filter.rssiThreshold = rssi_threshold;
// Note that the number of ssids should match the number of security flags
for (const auto& ssid : ssids) {
NetworkInfo nw_info;
nw_info.ssid = ssid;
if (i < flags.size()) {
nw_info.flags = flags[i++];
} else {
continue;
}
nw_info_list.push_back(nw_info);
}
scan_filter.preferredNetworkInfoList = nw_info_list;
return scan_filter;
}
NativeScanStats OffloadScanUtils::convertToNativeScanStats(
const ScanStats& scanStats) {
uint32_t num_channels_scanned = 0;
uint32_t scan_duration_ms = 0;
vector<uint8_t> histogram_channels;
for (size_t i = 0; i < scanStats.scanRecord.size(); i++) {
scan_duration_ms += scanStats.scanRecord[i].durationMs;
num_channels_scanned += scanStats.scanRecord[i].numChannelsScanned;
}
for (size_t i = 0; i < scanStats.histogramChannelsScanned.size(); i++) {
histogram_channels.push_back(scanStats.histogramChannelsScanned[i]);
}
NativeScanStats native_scan_stats(
scanStats.numScansRequestedByWifi, scanStats.numScansServicedByWifi,
scanStats.subscriptionDurationMs, scan_duration_ms, num_channels_scanned,
histogram_channels);
return native_scan_stats;
}
} // namespace wificond
} // namespace android