blob: e794f538a0c22e7ad5494d75593b8efd16fddf73 [file] [log] [blame]
Roshan Pius3c4e8a32016-10-03 14:53:58 -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
17#include "wifi_chip.h"
18
19#include <android-base/logging.h>
20
21#include "failure_reason_util.h"
22
23namespace android {
24namespace hardware {
25namespace wifi {
26
27WifiChip::WifiChip(
28 WifiHalState* hal_state, wifi_interface_handle interface_handle)
29 : hal_state_(hal_state), interface_handle_(interface_handle) {}
30
31void WifiChip::Invalidate() {
32 hal_state_ = nullptr;
33 callbacks_.clear();
34}
35
36Return<void> WifiChip::registerEventCallback(
37 const sp<V1_0::IWifiChipEventCallback>& callback) {
38 if (!hal_state_) return Void();
39 // TODO(b/31632518): remove the callback when the client is destroyed
40 callbacks_.insert(callback);
41 return Void();
42}
43
44Return<void> WifiChip::getAvailableModes(getAvailableModes_cb cb) {
45 if (!hal_state_) {
46 cb(hidl_vec<ChipMode>());
47 return Void();
48 } else {
49 // TODO add implementation
50 return Void();
51 }
52}
53
54Return<void> WifiChip::configureChip(uint32_t /*mode_id*/) {
55 if (!hal_state_) return Void();
56 // TODO add implementation
57 return Void();
58}
59
60Return<uint32_t> WifiChip::getMode() {
61 if (!hal_state_) return 0;
62 // TODO add implementation
63 return 0;
64}
65
66Return<void> WifiChip::requestChipDebugInfo() {
67 if (!hal_state_) return Void();
68
69 V1_0::IWifiChipEventCallback::ChipDebugInfo result;
70 result.driverDescription = "<unknown>";
71 result.firmwareDescription = "<unknown>";
72 char buffer[256];
73
74 // get driver version
75 bzero(buffer, sizeof(buffer));
76 wifi_error ret = hal_state_->func_table_.wifi_get_driver_version(
77 interface_handle_, buffer, sizeof(buffer));
78 if (ret == WIFI_SUCCESS) {
79 result.driverDescription = buffer;
80 } else {
81 LOG(WARNING) << "Failed to get driver version: "
82 << LegacyErrorToString(ret);
83 }
84
85 // get firmware version
86 bzero(buffer, sizeof(buffer));
87 ret = hal_state_->func_table_.wifi_get_firmware_version(
88 interface_handle_, buffer, sizeof(buffer));
89 if (ret == WIFI_SUCCESS) {
90 result.firmwareDescription = buffer;
91 } else {
92 LOG(WARNING) << "Failed to get firmware version: "
93 << LegacyErrorToString(ret);
94 }
95
96 // send callback
97 for (auto& callback : callbacks_) {
98 callback->onChipDebugInfoAvailable(result);
99 }
100 return Void();
101}
102
103Return<void> WifiChip::requestDriverDebugDump() {
104 // TODO implement
105 return Void();
106}
107
108Return<void> WifiChip::requestFirmwareDebugDump() {
109 // TODO implement
110 return Void();
111}
112
113
114} // namespace wifi
115} // namespace hardware
116} // namespace android