1 /*
2 * Copyright (C) 2022 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 #ifndef FILLP_LOG_H
17 #define FILLP_LOG_H
18
19 #include "fillp_os.h"
20 #include "opt.h"
21
22 #ifdef __cplusplus
23 extern "C" {
24 #endif
25
26 #ifdef FILLP_LINUX
27
28 #ifdef PDT_UT
29
30 /* for UT statement coverage */
31 #define FILLP_LOG_IN(_level, _type, _pre, fmt, ...)
32
33 #else
34
35 #if FILLP_LOG_WITH_TIME
36
FillpLogGetNowTime(struct timeval *tv, struct tm *nowTime)37 static inline void FillpLogGetNowTime(struct timeval *tv, struct tm *nowTime)
38 {
39 (void)gettimeofday(tv, FILLP_NULL_PTR);
40 time_t sec = (time_t)tv->tv_sec;
41 (void)localtime_r(&sec, nowTime);
42 }
43
44 #define FILLP_LM_LOG_OUTPUT(_type, _level, _pre, fmt, ...) do { \
45 struct timeval tv; \
46 struct tm nowTime; \
47 FillpLogGetNowTime(&tv, &nowTime); \
48 (*g_fillpLmGlobal.lmCallbackFn.debugCallbackFunc)(_type, _level, 0, \
49 "%02d%02d %02d:%02d:%02d.%06ld %s:[%d] : <%s>" fmt "\r\n", \
50 nowTime.tm_mon + 1, nowTime.tm_mday, nowTime.tm_hour, nowTime.tm_min, nowTime.tm_sec, \
51 (long)tv.tv_usec, __func__, __LINE__, _pre, ##__VA_ARGS__); \
52 } while (0)
53
54 #else
55
56 #define FILLP_LM_LOG_OUTPUT(_type, _level, _pre, fmt, ...) ((*g_fillpLmGlobal.lmCallbackFn.debugCallbackFunc)( \
57 _type, _level, 0, "%s:[%d] : <%s>" fmt "\r\n", __func__, __LINE__, _pre, ##__VA_ARGS__))
58
59 #endif /* FILLP_LOG_WITH_TIME */
60
61 #define FILLP_LOG_IN(_level, _type, _pre, fmt, ...) \
62 do { \
63 if ((_level) >= g_fillpLmGlobal.debugLevel && \
64 (g_fillpLmGlobal.lmCallbackFn.debugCallbackFunc != FILLP_NULL_PTR)) { \
65 FILLP_LM_LOG_OUTPUT(_type, _level, _pre, fmt, ##__VA_ARGS__); \
66 } \
67 } while (0)
68
69 #endif
70
71 #else
72
73 #define FILLP_LOG_IN(_level, _type, _pre, fmt, ...)
74
75 #endif /* FILLP_LINUX */
76
77 #define FILLP_LOGERR(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_ERROR, FILLP_DBG_LOG, "F-LOGERR", fmt, ##__VA_ARGS__)
78
79 #define FILLP_LOGWAR(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_WARNING, FILLP_DBG_LOG, "F-LOGWAR", fmt, ##__VA_ARGS__)
80
81 #define FILLP_LOGINF(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_INFO, FILLP_DBG_LOG, "F-LOGINF", fmt, ##__VA_ARGS__)
82
83 #define FILLP_LOGDTL(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_DETAIL, FILLP_DBG_LOG, "F-LOGDTL", fmt, ##__VA_ARGS__)
84
85 #define FILLP_LOGDBG(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_DEBUG, FILLP_DBG_LOG, "F-LOGDBG", fmt, ##__VA_ARGS__)
86
87 #define FILLP_LOGBUTT(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_BUTT, FILLP_DBG_LOG, "F-LOGBUTT", fmt, ##__VA_ARGS__)
88
89 #define FILLP_HELPBUTT(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_BUTT, FILLP_DBG_HELP, "F-HELPBUTT", fmt, ##__VA_ARGS__)
90
91 #define FILLP_SHOWDATABUTT(fmt, ...) \
92 FILLP_LOG_IN(FILLP_DBG_LVL_BUTT, FILLP_DBG_SHOW_DATA, "F-SHOWDATABUTT", fmt, ##__VA_ARGS__)
93
94 #define FILLP_SHOWLEVELBUTT(fmt, ...) \
95 FILLP_LOG_IN(FILLP_DBG_LVL_BUTT, FILLP_DBG_SHOW_LEVEL, "F-SHOWLEVELBUTT", fmt, ##__VA_ARGS__)
96
97 #ifdef FILLP_MGT_MSG_LOG
98 #define FILLP_LOGMGTMSG(fmt, ...) FILLP_LOG_IN(FILLP_DBG_LVL_INFO, FILLP_DBG_LOG, "F-LOGMGTMSG", fmt, ##__VA_ARGS__)
99 #endif
100
101 FILLP_INT FillpApiSetMgtMsgLog(FILLP_INT enable);
102
103 #ifdef __cplusplus
104 }
105 #endif
106 #endif /* FILLP_LOG_H */
107
108