/* * 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/scan_stats.h" #include <android-base/logging.h> #include "wificond/parcelable_utils.h" using android::status_t; namespace com { namespace android { namespace server { namespace wifi { namespace wificond { NativeScanStats::NativeScanStats(uint32_t num_scans_requested_by_wifi, uint32_t num_scans_serviced_by_wifi, uint32_t subscription_duration_ms, uint32_t scan_duration_ms, uint32_t num_channels_scanned, std::vector<uint8_t> histogram_channels) : num_scans_requested_by_wifi_(num_scans_requested_by_wifi), num_scans_serviced_by_wifi_(num_scans_serviced_by_wifi), subscription_duration_ms_(subscription_duration_ms), scan_duration_ms_(scan_duration_ms), num_channels_scanned_(num_channels_scanned), time_stamp_(0), histogram_channels_(histogram_channels) {} NativeScanStats::NativeScanStats() : num_scans_requested_by_wifi_(0), num_scans_serviced_by_wifi_(0), subscription_duration_ms_(0), scan_duration_ms_(0), num_channels_scanned_(0), time_stamp_(0) {} bool NativeScanStats::operator==(const NativeScanStats& rhs) const { if ((rhs.num_scans_requested_by_wifi_ != num_scans_requested_by_wifi_) || (rhs.num_scans_serviced_by_wifi_ != num_scans_serviced_by_wifi_) || (rhs.scan_duration_ms_ != scan_duration_ms_) || (rhs.num_channels_scanned_ != num_channels_scanned_)) { return false; } if (rhs.histogram_channels_.size() != histogram_channels_.size()) { return false; } for (size_t i = 0; i < histogram_channels_.size(); i++) { if (rhs.histogram_channels_[i] != histogram_channels_[i]) { return false; } } return true; } status_t NativeScanStats::writeToParcel(::android::Parcel* parcel) const { RETURN_IF_FAILED(parcel->writeUint32(num_scans_requested_by_wifi_)); RETURN_IF_FAILED(parcel->writeUint32(num_scans_serviced_by_wifi_)); RETURN_IF_FAILED(parcel->writeUint32(subscription_duration_ms_)); RETURN_IF_FAILED(parcel->writeUint32(scan_duration_ms_)); RETURN_IF_FAILED(parcel->writeUint32(num_channels_scanned_)); RETURN_IF_FAILED(parcel->writeByteVector(histogram_channels_)); return ::android::OK; } status_t NativeScanStats::readFromParcel(const ::android::Parcel* parcel) { RETURN_IF_FAILED(parcel->readUint32(&num_scans_requested_by_wifi_)); RETURN_IF_FAILED(parcel->readUint32(&num_scans_serviced_by_wifi_)); RETURN_IF_FAILED(parcel->readUint32(&subscription_duration_ms_)); RETURN_IF_FAILED(parcel->readUint32(&scan_duration_ms_)); RETURN_IF_FAILED(parcel->readUint32(&num_channels_scanned_)); RETURN_IF_FAILED(parcel->readByteVector(&histogram_channels_)); return ::android::OK; } void NativeScanStats::DebugLog() { LOG(INFO) << "num_scans_requested_by_wifi=" << num_scans_requested_by_wifi_; LOG(INFO) << "num_scans_serviced_by_wifi=" << num_scans_serviced_by_wifi_; LOG(INFO) << "subscription_duration=" << subscription_duration_ms_; LOG(INFO) << "scan_duration_ms_=" << scan_duration_ms_; LOG(INFO) << "num_channels_scanned=" << num_channels_scanned_; for (size_t i = 0; i < histogram_channels_.size(); i++) { if (histogram_channels_[i] > 0) { LOG(INFO) << "Channel=" << i << " ScannedTimes=" << static_cast<uint32_t>(histogram_channels_[i]); } } } } // namespace wificond } // namespace wifi } // namespace server } // namespace android } // namespace com