OSDN Git Service

Better logging for GetWiphyInfo() am: 384f74dea0 am: 9a83da9411
[android-x86/system-connectivity-wificond.git] / client_interface_impl.cpp
1 /*
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
17 #include "wificond/client_interface_impl.h"
18
19 #include <vector>
20
21 #include <android-base/logging.h>
22 #include <wifi_system/supplicant_manager.h>
23 #include <wifi_system/wifi.h>
24
25 #include "wificond/client_interface_binder.h"
26 #include "wificond/net/mlme_event.h"
27 #include "wificond/net/netlink_utils.h"
28 #include "wificond/scanning/scan_result.h"
29 #include "wificond/scanning/scan_utils.h"
30 #include "wificond/scanning/scanner_impl.h"
31
32 using android::net::wifi::IClientInterface;
33 using com::android::server::wifi::wificond::NativeScanResult;
34 using android::sp;
35 using android::wifi_system::InterfaceTool;
36 using android::wifi_system::SupplicantManager;
37
38 using std::string;
39 using std::unique_ptr;
40 using std::vector;
41
42 namespace android {
43 namespace wificond {
44
45 MlmeEventHandlerImpl::MlmeEventHandlerImpl(ClientInterfaceImpl* client_interface)
46     : client_interface_(client_interface) {
47 }
48
49 MlmeEventHandlerImpl::~MlmeEventHandlerImpl() {
50 }
51
52 void MlmeEventHandlerImpl::OnConnect(unique_ptr<MlmeConnectEvent> event) {
53   if (event->GetStatusCode() == 0) {
54     client_interface_->RefreshAssociateFreq();
55     client_interface_->bssid_ = event->GetBSSID();
56   }
57 }
58
59 void MlmeEventHandlerImpl::OnRoam(unique_ptr<MlmeRoamEvent> event) {
60   if (event->GetStatusCode() == 0) {
61     client_interface_->RefreshAssociateFreq();
62     client_interface_->bssid_ = event->GetBSSID();
63   }
64 }
65
66 void MlmeEventHandlerImpl::OnAssociate(unique_ptr<MlmeAssociateEvent> event) {
67   if (event->GetStatusCode() == 0) {
68     client_interface_->RefreshAssociateFreq();
69     client_interface_->bssid_ = event->GetBSSID();
70   }
71 }
72
73 ClientInterfaceImpl::ClientInterfaceImpl(
74     uint32_t wiphy_index,
75     const std::string& interface_name,
76     uint32_t interface_index,
77     const std::vector<uint8_t>& interface_mac_addr,
78     InterfaceTool* if_tool,
79     SupplicantManager* supplicant_manager,
80     NetlinkUtils* netlink_utils,
81     ScanUtils* scan_utils)
82     : wiphy_index_(wiphy_index),
83       interface_name_(interface_name),
84       interface_index_(interface_index),
85       interface_mac_addr_(interface_mac_addr),
86       if_tool_(if_tool),
87       supplicant_manager_(supplicant_manager),
88       netlink_utils_(netlink_utils),
89       scan_utils_(scan_utils),
90       mlme_event_handler_(new MlmeEventHandlerImpl(this)),
91       binder_(new ClientInterfaceBinder(this)) {
92   netlink_utils_->SubscribeMlmeEvent(
93       interface_index_,
94       mlme_event_handler_.get());
95   if (!netlink_utils_->GetWiphyInfo(wiphy_index_,
96                                &band_info_,
97                                &scan_capabilities_,
98                                &wiphy_features_)) {
99     LOG(ERROR) << "Failed to get wiphy info from kernel";
100   }
101   scanner_ = new ScannerImpl(interface_index_,
102                              band_info_,
103                              scan_capabilities_,
104                              wiphy_features_,
105                              scan_utils_);
106 }
107
108 ClientInterfaceImpl::~ClientInterfaceImpl() {
109   binder_->NotifyImplDead();
110   scanner_->Invalidate();
111   DisableSupplicant();
112   netlink_utils_->UnsubscribeMlmeEvent(interface_index_);
113   if_tool_->SetUpState(interface_name_.c_str(), false);
114 }
115
116 sp<android::net::wifi::IClientInterface> ClientInterfaceImpl::GetBinder() const {
117   return binder_;
118 }
119
120 bool ClientInterfaceImpl::EnableSupplicant() {
121   return supplicant_manager_->StartSupplicant();
122 }
123
124 bool ClientInterfaceImpl::DisableSupplicant() {
125   return supplicant_manager_->StopSupplicant();
126 }
127
128 bool ClientInterfaceImpl::GetPacketCounters(vector<int32_t>* out_packet_counters) {
129   StationInfo station_info;
130   if (!netlink_utils_->GetStationInfo(interface_index_,
131                                       interface_mac_addr_,
132                                       &station_info)) {
133     return false;
134   }
135   out_packet_counters->push_back(station_info.station_tx_packets);
136   out_packet_counters->push_back(station_info.station_tx_failed);
137
138   return true;
139 }
140
141 bool ClientInterfaceImpl::SignalPoll(vector<int32_t>* out_signal_poll_results) {
142   StationInfo station_info;
143   if (!netlink_utils_->GetStationInfo(interface_index_,
144                                       bssid_,
145                                       &station_info)) {
146     return false;
147   }
148   out_signal_poll_results->push_back(
149       static_cast<int32_t>(station_info.current_rssi));
150   // Convert from 100kbit/s to Mbps.
151   out_signal_poll_results->push_back(
152       static_cast<int32_t>(station_info.station_tx_bitrate/10));
153   // Association frequency.
154   out_signal_poll_results->push_back(
155       static_cast<int32_t>(associate_freq_));
156
157   return true;
158 }
159
160 const vector<uint8_t>& ClientInterfaceImpl::GetMacAddress() {
161   return interface_mac_addr_;
162 }
163
164 bool ClientInterfaceImpl::requestANQP(
165       const ::std::vector<uint8_t>& bssid,
166       const ::android::sp<::android::net::wifi::IANQPDoneCallback>& callback) {
167   // TODO(nywang): query ANQP information from wpa_supplicant.
168   return true;
169 }
170
171 bool ClientInterfaceImpl::RefreshAssociateFreq() {
172   // wpa_supplicant fetches associate frequency using the latest scan result.
173   // We should follow the same method here before we find a better solution.
174   std::vector<NativeScanResult> scan_results;
175   if (!scan_utils_->GetScanResult(interface_index_, &scan_results)) {
176     return false;
177   }
178   for (auto& scan_result : scan_results) {
179     if (scan_result.associated) {
180       associate_freq_ = scan_result.frequency;
181     }
182   }
183   return false;
184 }
185
186 }  // namespace wificond
187 }  // namespace android