1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#ifndef SENSOR_TRACE_H
17094332d3Sopenharmony_ci#define SENSOR_TRACE_H
18094332d3Sopenharmony_ci
19094332d3Sopenharmony_ci#include "hitrace_meter.h"
20094332d3Sopenharmony_ci
21094332d3Sopenharmony_ci#define SENSOR_TRACE_TAG HITRACE_TAG_HDF
22094332d3Sopenharmony_ci#define SENSOR_TRACE HITRACE_METER_NAME(SENSOR_TRACE_TAG, __func__)
23094332d3Sopenharmony_ci
24094332d3Sopenharmony_ci#define SENSOR_TRACE_PID HITRACE_METER_NAME(SENSOR_TRACE_TAG, (std::string(__func__) + ":pid " + \
25094332d3Sopenharmony_ci    std::to_string(static_cast<uint32_t>(HdfRemoteGetCallingPid()))).c_str())
26094332d3Sopenharmony_ci
27094332d3Sopenharmony_ci#define SENSOR_TRACE_MSG(msg) HITRACE_METER_NAME(SENSOR_TRACE_TAG, (std::string(__func__) + ":" + (msg)).c_str())
28094332d3Sopenharmony_ci
29094332d3Sopenharmony_ci#define SENSOR_TRACE_PID_MSG(msg) HITRACE_METER_NAME(SENSOR_TRACE_TAG, (std::string(__func__) + ":pid " + \
30094332d3Sopenharmony_ci    std::to_string(static_cast<uint32_t>(HdfRemoteGetCallingPid())) + "," + (msg)).c_str())
31094332d3Sopenharmony_ci
32094332d3Sopenharmony_ci#define SENSOR_TRACE_START(msg) StartTrace(SENSOR_TRACE_TAG, (std::string(__func__) + ":" + (msg)).c_str())
33094332d3Sopenharmony_ci
34094332d3Sopenharmony_ci#define SENSOR_TRACE_FINISH FinishTrace(SENSOR_TRACE_TAG)
35094332d3Sopenharmony_ci
36094332d3Sopenharmony_ci#endif //SENSOR_TRACE_H
37