/* * Copyright (c) 2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "hibernate_controller.h" #include "power_log.h" #include "system_suspend_controller.h" namespace OHOS { namespace PowerMgr { HibernateStatus HibernateController::Hibernate(bool clearMemory) { if (SystemSuspendController::GetInstance().Hibernate()) { return HibernateStatus::HIBERNATE_SUCCESS; } return HibernateStatus::HIBERNATE_FAILURE; } void HibernateController::RegisterSyncHibernateCallback(const sptr& cb) { std::lock_guard lock(mutex_); callbacks_.insert(cb); pid_t pid = IPCSkeleton::GetCallingPid(); auto uid = IPCSkeleton::GetCallingUid(); cachedRegister_.emplace(cb, std::make_pair(pid, uid)); } void HibernateController::UnregisterSyncHibernateCallback(const sptr& cb) { std::lock_guard lock(mutex_); size_t eraseNum = callbacks_.erase(cb); if (eraseNum == 0) { POWER_HILOGE(FEATURE_SUSPEND, "Cannot remove the hibernate callback"); } auto iter = cachedRegister_.find(cb); if (iter != cachedRegister_.end()) { cachedRegister_.erase(iter); } } void HibernateController::PreHibernate() { std::lock_guard lock(mutex_); for (const auto &cb : callbacks_) { auto iter = cachedRegister_.find(cb); auto pidUid = ((iter != cachedRegister_.end()) ? iter->second : std::make_pair(0, 0)); if (cb != nullptr) { // PreHibernate calling callback pid uid POWER_HILOGI(FEATURE_SUSPEND, "PreCb P=%{public}dU=%{public}d", pidUid.first, pidUid.second); cb->OnSyncHibernate(); } } prepared_ = true; } void HibernateController::PostHibernate(bool hibernateResult) { std::lock_guard lock(mutex_); if (!prepared_) { POWER_HILOGE(FEATURE_SUSPEND, "No need to run OnSyncWakeup"); return; } prepared_ = false; for (const auto &cb : callbacks_) { auto iter = cachedRegister_.find(cb); auto pidUid = ((iter != cachedRegister_.end()) ? iter->second : std::make_pair(0, 0)); if (cb != nullptr) { // PostHibernate calling callback pid uid POWER_HILOGI(FEATURE_SUSPEND, "PostCb P=%{public}dU=%{public}d", pidUid.first, pidUid.second); cb->OnSyncWakeup(hibernateResult); } } } } // namespace PowerMgr } // namespace OHOS