1 /*
2 * Copyright (c) 2021 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "sensor_service_client.h"
17
18 #include <sys/socket.h>
19 #include <thread>
20 #include <unistd.h>
21 #include <vector>
22
23 #include "death_recipient_template.h"
24 #include "hisysevent.h"
25 #include "hitrace_meter.h"
26 #include "ipc_skeleton.h"
27 #include "sensor_service_proxy.h"
28 #include "sensors_errors.h"
29 #include "system_ability_definition.h"
30
31 namespace OHOS {
32 namespace Sensors {
33 using namespace OHOS::HiviewDFX;
34
35 namespace {
36 constexpr HiLogLabel LABEL = { LOG_CORE, SENSOR_LOG_DOMAIN, "SensorServiceClient" };
37 constexpr int32_t GET_SERVICE_MAX_COUNT = 30;
38 constexpr uint32_t WAIT_MS = 200;
39 } // namespace
40
InitServiceClient()41 int32_t SensorServiceClient::InitServiceClient()
42 {
43 CALL_LOG_ENTER;
44 std::lock_guard<std::mutex> clientLock(clientMutex_);
45 if (sensorServer_ != nullptr) {
46 SEN_HILOGD("already init");
47 return ERR_OK;
48 }
49 if (sensorClientStub_ == nullptr) {
50 sensorClientStub_ = new (std::nothrow) SensorClientStub();
51 }
52 auto systemAbilityManager = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
53 CHKPR(systemAbilityManager, SENSOR_NATIVE_SAM_ERR);
54 int32_t retry = 0;
55 while (retry < GET_SERVICE_MAX_COUNT) {
56 sensorServer_ = iface_cast<ISensorService>(systemAbilityManager->GetSystemAbility(SENSOR_SERVICE_ABILITY_ID));
57 if (sensorServer_ != nullptr) {
58 SEN_HILOGD("get service success, retry:%{public}d", retry);
59 serviceDeathObserver_ = new (std::nothrow) DeathRecipientTemplate(*const_cast<SensorServiceClient *>(this));
60 if (serviceDeathObserver_ != nullptr) {
61 sensorServer_->AsObject()->AddDeathRecipient(serviceDeathObserver_);
62 }
63 sensorList_ = sensorServer_->GetSensorList();
64 return ERR_OK;
65 }
66 SEN_HILOGW("get service failed, retry:%{public}d", retry);
67 std::this_thread::sleep_for(std::chrono::milliseconds(WAIT_MS));
68 retry++;
69 }
70 HiSysEvent::Write(HiviewDFX::HiSysEvent::Domain::SENSOR, "SENSOR_SERVICE_EXCEPTION",
71 HiSysEvent::EventType::FAULT, "PKG_NAME", "InitServiceClient", "ERROR_CODE", SENSOR_NATIVE_GET_SERVICE_ERR);
72 SEN_HILOGE("get service failed");
73 return SENSOR_NATIVE_GET_SERVICE_ERR;
74 }
75
IsValid(uint32_t sensorId)76 bool SensorServiceClient::IsValid(uint32_t sensorId)
77 {
78 int32_t ret = InitServiceClient();
79 if (ret != ERR_OK) {
80 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
81 return false;
82 }
83 if (sensorList_.empty()) {
84 SEN_HILOGE("sensorList_ cannot be empty");
85 return false;
86 }
87 for (auto &sensor : sensorList_) {
88 if (sensor.GetSensorId() == sensorId) {
89 return true;
90 }
91 }
92 return false;
93 }
94
EnableSensor(uint32_t sensorId,int64_t samplingPeriod,int64_t maxReportDelay)95 int32_t SensorServiceClient::EnableSensor(uint32_t sensorId, int64_t samplingPeriod, int64_t maxReportDelay)
96 {
97 CALL_LOG_ENTER;
98 int32_t ret = InitServiceClient();
99 if (ret != ERR_OK) {
100 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
101 return ret;
102 }
103 CHKPR(sensorServer_, ERROR);
104 StartTrace(HITRACE_TAG_SENSORS, "EnableSensor");
105 ret = sensorServer_->EnableSensor(sensorId, samplingPeriod, maxReportDelay);
106 FinishTrace(HITRACE_TAG_SENSORS);
107 if (ret == ERR_OK) {
108 UpdateSensorInfoMap(sensorId, samplingPeriod, maxReportDelay);
109 }
110 return ret;
111 }
112
DisableSensor(uint32_t sensorId)113 int32_t SensorServiceClient::DisableSensor(uint32_t sensorId)
114 {
115 CALL_LOG_ENTER;
116 int32_t ret = InitServiceClient();
117 if (ret != ERR_OK) {
118 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
119 return ret;
120 }
121 CHKPR(sensorServer_, ERROR);
122 StartTrace(HITRACE_TAG_SENSORS, "DisableSensor");
123 ret = sensorServer_->DisableSensor(sensorId);
124 FinishTrace(HITRACE_TAG_SENSORS);
125 if (ret == ERR_OK) {
126 DeleteSensorInfoItem(sensorId);
127 }
128 return ret;
129 }
130
GetSensorList()131 std::vector<Sensor> SensorServiceClient::GetSensorList()
132 {
133 CALL_LOG_ENTER;
134 int32_t ret = InitServiceClient();
135 if (ret != ERR_OK) {
136 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
137 return {};
138 }
139 if (sensorList_.empty()) {
140 SEN_HILOGE("sensorList_ cannot be empty");
141 }
142 return sensorList_;
143 }
144
TransferDataChannel(sptr<SensorDataChannel> sensorDataChannel)145 int32_t SensorServiceClient::TransferDataChannel(sptr<SensorDataChannel> sensorDataChannel)
146 {
147 CALL_LOG_ENTER;
148 dataChannel_ = sensorDataChannel;
149 int32_t ret = InitServiceClient();
150 if (ret != ERR_OK) {
151 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
152 return ret;
153 }
154 CHKPR(sensorServer_, ERROR);
155 StartTrace(HITRACE_TAG_SENSORS, "TransferDataChannel");
156 ret = sensorServer_->TransferDataChannel(sensorDataChannel, sensorClientStub_);
157 FinishTrace(HITRACE_TAG_SENSORS);
158 return ret;
159 }
160
DestroyDataChannel()161 int32_t SensorServiceClient::DestroyDataChannel()
162 {
163 CALL_LOG_ENTER;
164 int32_t ret = InitServiceClient();
165 if (ret != ERR_OK) {
166 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
167 return ret;
168 }
169 CHKPR(sensorServer_, ERROR);
170 StartTrace(HITRACE_TAG_SENSORS, "DestroyDataChannel");
171 ret = sensorServer_->DestroySensorChannel(sensorClientStub_);
172 FinishTrace(HITRACE_TAG_SENSORS);
173 return ret;
174 }
175
ProcessDeathObserver(const wptr<IRemoteObject> & object)176 void SensorServiceClient::ProcessDeathObserver(const wptr<IRemoteObject> &object)
177 {
178 CALL_LOG_ENTER;
179 (void)object;
180 CHKPV(dataChannel_);
181 // STEP1 : Destroy revious data channel
182 dataChannel_->DestroySensorDataChannel();
183 // STEP2 : Restore data channel
184 dataChannel_->RestoreSensorDataChannel();
185
186 // STEP3 : Clear sensorlist and sensorServer_
187 sensorList_.clear();
188 sensorServer_ = nullptr;
189 // STEP4 : ReGet sensors 3601 service
190 int32_t ret = InitServiceClient();
191 if (ret != ERR_OK) {
192 SEN_HILOGE("InitServiceClient failed, ret:%{public}d", ret);
193 dataChannel_->DestroySensorDataChannel();
194 return;
195 }
196 // STEP5 : Retransfer new channel to sensors
197 sensorServer_->TransferDataChannel(dataChannel_, sensorClientStub_);
198 // STEP6 : Restore Sensor status
199 std::lock_guard<std::mutex> mapLock(mapMutex_);
200 for (const auto &it : sensorInfoMap_) {
201 sensorServer_->EnableSensor(it.first, it.second.GetSamplingPeriodNs(), it.second.GetMaxReportDelayNs());
202 }
203 }
204
UpdateSensorInfoMap(uint32_t sensorId,int64_t samplingPeriod,int64_t maxReportDelay)205 void SensorServiceClient::UpdateSensorInfoMap(uint32_t sensorId, int64_t samplingPeriod, int64_t maxReportDelay)
206 {
207 CALL_LOG_ENTER;
208 std::lock_guard<std::mutex> mapLock(mapMutex_);
209 SensorBasicInfo sensorInfo;
210 sensorInfo.SetSamplingPeriodNs(samplingPeriod);
211 sensorInfo.SetMaxReportDelayNs(maxReportDelay);
212 sensorInfo.SetSensorState(true);
213 sensorInfoMap_[sensorId] = sensorInfo;
214 return;
215 }
216
DeleteSensorInfoItem(uint32_t sensorId)217 void SensorServiceClient::DeleteSensorInfoItem(uint32_t sensorId)
218 {
219 CALL_LOG_ENTER;
220 std::lock_guard<std::mutex> mapLock(mapMutex_);
221 auto it = sensorInfoMap_.find(sensorId);
222 if (it != sensorInfoMap_.end()) {
223 sensorInfoMap_.erase(it);
224 }
225 return;
226 }
227 } // namespace Sensors
228 } // namespace OHOS
229