1/*
2 * Copyright (c) 2024 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 "power_hdf_log.h"
17#include "power_xcollie.h"
18#ifdef HICOLLIE_ENABLE
19#include "xcollie/xcollie.h"
20#endif
21
22namespace OHOS {
23namespace HDI {
24namespace Power {
25PowerXCollie::PowerXCollie(const std::string &logTag, uint32_t timeoutSeconds)
26{
27    logTag_ = logTag;
28    isCanceled_ = false;
29#ifdef HICOLLIE_ENABLE
30    id_ = HiviewDFX::XCollie::GetInstance().SetTimer(
31        logTag_, timeoutSeconds, nullptr, nullptr, HiviewDFX::XCOLLIE_FLAG_LOG | HiviewDFX::XCOLLIE_FLAG_RECOVERY);
32#else
33    id_ = -1;
34#endif
35    HDF_LOGD("Start PowerXCollie, id:%{public}d, tag:%{public}s, timeout(s):%{public}u", id_, logTag_.c_str(),
36        timeoutSeconds);
37}
38
39PowerXCollie::~PowerXCollie()
40{
41    CancelPowerXCollie();
42}
43
44void PowerXCollie::CancelPowerXCollie()
45{
46    if (!isCanceled_) {
47#ifdef HICOLLIE_ENABLE
48        HiviewDFX::XCollie::GetInstance().CancelTimer(id_);
49#endif
50        isCanceled_ = true;
51        HDF_LOGD("Cancel PowerXCollie, id:%{public}d, tag:%{public}s", id_, logTag_.c_str());
52    }
53}
54
55} // namespace Power
56} // namespace HDI
57} // namespace OHOS