• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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