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 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