/* * Copyright (c) 2022-2023 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. */ #ifndef SOC_PERF_INTERFACES_INNER_API_SOCPERF_CLIENT_INCLUDE_SOCPERF_CLIENT_H #define SOC_PERF_INTERFACES_INNER_API_SOCPERF_CLIENT_INCLUDE_SOCPERF_CLIENT_H #include "i_socperf_service.h" // for ISocPerfService namespace OHOS { namespace SOCPERF { class SocPerfClient { public: /** * @brief Get the Instance object * * @return SocPerfClient& */ static SocPerfClient& GetInstance(); /** * @brief Sending a performance request. * * @param cmdId Scene id defined in config file. * @param msg Additional string info, which is used for other extensions. */ void PerfRequest(int32_t cmdId, const std::string& msg); /** * @brief Sending a performance request. * * @param cmdId Scene id defined in config file. * @param onOffTag Indicates the start of end of a long-term frequency increase event. * @param msg Additional string info, which is used for other extensions. */ void PerfRequestEx(int32_t cmdId, bool onOffTag, const std::string& msg); /** * @brief Sending a power limit boost request. * * @param onOffTag Indicates the start of end of a power limit boost event. * @param msg Additional string info, which is used for other extensions. */ void PowerLimitBoost(bool onOffTag, const std::string& msg); /** * @brief Sending a thermal limit boost request. * * @param onOffTag Indicates the start of end of a thermal limit boost event. * @param msg Additional string info, which is used for other extensions. */ void ThermalLimitBoost(bool onOffTag, const std::string& msg); /** * @brief Sending a limit request. * * @param clientId Used to indentify the caller of frequency limiting, such as * the thermal module or power consumption module. * @param configs Indicates the specific value to be limited. * @param msg Additional string info, which is used for other extensions. */ void LimitRequest(int32_t clientId, const std::vector& tags, const std::vector& configs, const std::string& msg); /** * @brief set socperf server status, enable or disable * * @param status true means enable socperfserver, false means disable socperfserver * @param msg the reason why we need change socperfserver status */ void SetRequestStatus(bool status, const std::string& msg); /** * @brief set thermal level intermal for perfquest * * @param level thermal level */ void SetThermalLevel(int32_t level); /** * @brief send the device mode, enable or disable * * @param mode the mode which will to be changed * @param status true means socperfserver enter the device mode, false quit the device mode */ void RequestDeviceMode(const std::string& mode, bool status); /** * @brief get cmd Id count, cmdID is trigger, its count++ * @param msg the reason * @return cmdId count, as 10000:xx,10001:xx */ std::string RequestCmdIdCount(const std::string& msg); /** * @brief Reset SocperfClient * */ void ResetClient(); private: SocPerfClient() {} ~SocPerfClient() {} private: bool CheckClientValid(); std::string AddPidAndTidInfo(const std::string& msg); private: class SocPerfDeathRecipient : public IRemoteObject::DeathRecipient { public: explicit SocPerfDeathRecipient(SocPerfClient &socPerfClient); ~SocPerfDeathRecipient(); void OnRemoteDied(const wptr &object) override; private: SocPerfClient &socPerfClient_; }; private: std::mutex mutex_; sptr client; sptr recipient_; }; } // namespace SOCPERF } // namespace OHOS #endif // SOC_PERF_INTERFACES_INNER_API_SOCPERF_CLIENT_INCLUDE_SOCPERF_CLIENT_H