blob: 6453f33b8300701fe25439753bd738feb298e8fa [file] [log] [blame]
Ruchi Kandoi8214a642016-09-29 13:56:05 -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#define LOG_TAG "android.hardware.power@1.0-impl"
18#include <hardware/hardware.h>
19#include <hardware/power.h>
Yifan Hongf9d30342016-11-30 13:45:34 -080020#include <android/log.h>
Ruchi Kandoi8214a642016-09-29 13:56:05 -070021#include "Power.h"
22
23namespace android {
24namespace hardware {
25namespace power {
26namespace V1_0 {
27namespace implementation {
28
29Power::Power(power_module_t *module) : mModule(module) {
30 if (mModule)
31 mModule->init(mModule);
32}
33
34Power::~Power() {
35 delete(mModule);
36}
37
38// Methods from ::android::hardware::power::V1_0::IPower follow.
39Return<void> Power::setInteractive(bool interactive) {
40 if (mModule->setInteractive > 0)
41 mModule->setInteractive(mModule, interactive ? 1 : 0);
42 return Void();
43}
44
45Return<void> Power::powerHint(PowerHint hint, int32_t data) {
46 int32_t param = data;
47 if (mModule->powerHint > 0)
48 mModule->powerHint(mModule, static_cast<power_hint_t>(hint), &param);
49 return Void();
50}
51
52Return<void> Power::setFeature(Feature feature, bool activate) {
53 if (mModule->setFeature > 0)
54 mModule->setFeature(mModule, static_cast<feature_t>(feature),
55 activate ? 1 : 0);
56 return Void();
57}
58
59Return<void> Power::getPlatformLowPowerStats(getPlatformLowPowerStats_cb _hidl_cb) {
60 hidl_vec<PowerStatePlatformSleepState> states;
61 ssize_t number_platform_modes;
62 size_t *voters = nullptr;
63 power_state_platform_sleep_state_t *legacy_states = nullptr;
64 int ret;
65
66 if (mModule->get_number_of_platform_modes == nullptr ||
67 mModule->get_voter_list == nullptr ||
68 mModule->get_platform_low_power_stats == nullptr)
69 {
70 _hidl_cb(states, Status::SUCCESS);
71 return Void();
72 }
73
74 number_platform_modes = mModule->get_number_of_platform_modes(mModule);
75 if (number_platform_modes > 0)
76 {
77 voters = new size_t [number_platform_modes];
78 if (voters == nullptr)
79 goto done;
80
81 ret = mModule->get_voter_list(mModule, voters);
82 if (ret != 0)
83 goto done;
84
85 legacy_states = new power_state_platform_sleep_state_t [number_platform_modes];
86 if (legacy_states == nullptr)
87 goto done;
88
89 for (int i = 0; i < number_platform_modes; i++)
90 {
91 legacy_states[i].voters = nullptr;
92 legacy_states[i].voters = new power_state_voter_t [voters[i]];
93 if (legacy_states[i].voters == nullptr)
94 goto done;
95 }
96
97 ret = mModule->get_platform_low_power_stats(mModule, legacy_states);
98 if (ret != 0)
99 goto done;
100
101 states.resize(number_platform_modes);
102 for (int i = 0; i < number_platform_modes; i++)
103 {
104 power_state_platform_sleep_state_t& legacy_state = legacy_states[i];
105 PowerStatePlatformSleepState& state = states[i];
106 state.name = legacy_state.name;
107 state.residencyInMsecSinceBoot = legacy_state.residency_in_msec_since_boot;
108 state.totalTransitions = legacy_state.total_transitions;
109 state.supportedOnlyInSuspend = legacy_state.supported_only_in_suspend;
110 state.voters.resize(voters[i]);
111 for(size_t j = 0; j < voters[i]; j++)
112 {
113 state.voters[j].name = legacy_state.voters[j].name;
114 state.voters[j].totalTimeInMsecVotedForSinceBoot = legacy_state.voters[j].total_time_in_msec_voted_for_since_boot;
115 state.voters[j].totalNumberOfTimesVotedSinceBoot = legacy_state.voters[j].total_number_of_times_voted_since_boot;
116 }
117 }
118 }
119done:
120 if (legacy_states)
121 {
122 for (int i = 0; i < number_platform_modes; i++)
123 {
124 if(legacy_states[i].voters)
125 delete(legacy_states[i].voters);
126 }
127 }
128 delete[] legacy_states;
129 delete[] voters;
130 _hidl_cb(states, Status::SUCCESS);
131 return Void();
132}
133
134IPower* HIDL_FETCH_IPower(const char* name) {
135 int ret = 0;
136 const hw_module_t* hw_module = NULL;
137 power_module_t *power_module;
138 ret = hw_get_module(name, &hw_module);
139 if (ret == 0 && hw_module->methods->open > 0) {
140 ret = hw_module->methods->open(hw_module, name,
141 reinterpret_cast<hw_device_t**>(&power_module));
142 if (ret == 0) {
143 return new Power(power_module);
144 }
145 else {
146 ALOGE("Passthrough failed to load legacy HAL.");
147 return nullptr;
148 }
149 }
150 else {
151 ALOGE ("hw_get_module %s failed: %d", name, ret);
152 return nullptr;
153 }
154}
155
156} // namespace implementation
157} // namespace V1_0
158} // namespace power
159} // namespace hardware
160} // namespace android