xref: /OK3568_Linux_fs/external/linux-rga/im2d_api/src/im2d_log.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright (C) 2022 Rockchip Electronics Co., Ltd.
3*4882a593Smuzhiyun  * Authors:
4*4882a593Smuzhiyun  *  Cerf Yu <cerf.yu@rock-chips.com>
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
7*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
8*4882a593Smuzhiyun  * You may obtain a copy of the License at
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
11*4882a593Smuzhiyun  *
12*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
13*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
14*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
16*4882a593Smuzhiyun  * limitations under the License.
17*4882a593Smuzhiyun  */
18*4882a593Smuzhiyun #ifndef _im2d_log_hpp_
19*4882a593Smuzhiyun #define _im2d_log_hpp_
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun #define IM_ERR_MSG_LEN 512
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun typedef enum {
24*4882a593Smuzhiyun     IM_LOG_UNKNOWN      = 0x0,
25*4882a593Smuzhiyun     IM_LOG_DEFAULT      = 0x1,
26*4882a593Smuzhiyun     IM_LOG_DEBUG        = 0x3,
27*4882a593Smuzhiyun     IM_LOG_INFO         = 0x4,
28*4882a593Smuzhiyun     IM_LOG_WARN         = 0x5,
29*4882a593Smuzhiyun     IM_LOG_ERROR        = 0x6,
30*4882a593Smuzhiyun     IM_LOG_LEVEL_MASK   = 0xff,
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun     IM_LOG_FORCE        = 0x1 << 8,         /* This will force output to stdout, not to internal error messages. */
33*4882a593Smuzhiyun } IM_LOG_LEVEL;
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #define GET_LOG_LEVEL(level) ((level) & IM_LOG_LEVEL_MASK)
36*4882a593Smuzhiyun #define LOG_LEVEL_CHECK(level) ((level) >= rga_log_level_get())
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun int rga_error_msg_set(const char* format, ...);
39*4882a593Smuzhiyun int rga_log_level_init(void);
40*4882a593Smuzhiyun void rga_log_level_update(void);
41*4882a593Smuzhiyun int rga_log_level_get(void);
42*4882a593Smuzhiyun int rga_log_enable_get(void);
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun size_t rga_get_current_time_ms(void);
45*4882a593Smuzhiyun size_t rga_get_start_time_ms(void);
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun #ifdef ANDROID
48*4882a593Smuzhiyun #define IM_LOG(level, ...) \
49*4882a593Smuzhiyun     do { \
50*4882a593Smuzhiyun         if (!((level) & IM_LOG_FORCE)) \
51*4882a593Smuzhiyun             rga_error_msg_set(__VA_ARGS__); \
52*4882a593Smuzhiyun         if ((rga_log_enable_get() > 0 && LOG_LEVEL_CHECK(level)) || \
53*4882a593Smuzhiyun             GET_LOG_LEVEL(level) == ANDROID_LOG_ERROR || \
54*4882a593Smuzhiyun             (level) & IM_LOG_FORCE) \
55*4882a593Smuzhiyun             ((void)__android_log_print(GET_LOG_LEVEL(level), LOG_TAG, __VA_ARGS__)); \
56*4882a593Smuzhiyun     } while(0)
57*4882a593Smuzhiyun #define IM_LOGD(_str, ...) IM_LOG(ANDROID_LOG_DEBUG, _str , ## __VA_ARGS__)
58*4882a593Smuzhiyun #define IM_LOGI(_str, ...) IM_LOG(ANDROID_LOG_INFO, _str , ## __VA_ARGS__)
59*4882a593Smuzhiyun #define IM_LOGW(_str, ...) IM_LOG(ANDROID_LOG_WARN, _str , ## __VA_ARGS__)
60*4882a593Smuzhiyun #define IM_LOGE(_str, ...) IM_LOG(ANDROID_LOG_ERROR, _str , ## __VA_ARGS__)
61*4882a593Smuzhiyun #define IM_LOGFD(_str, ...) IM_LOG(ANDROID_LOG_DEBUG | IM_LOG_FORCE, _str , ## __VA_ARGS__)
62*4882a593Smuzhiyun #define IM_LOGFI(_str, ...) IM_LOG(ANDROID_LOG_INFO | IM_LOG_FORCE, _str , ## __VA_ARGS__)
63*4882a593Smuzhiyun #define IM_LOGFW(_str, ...) IM_LOG(ANDROID_LOG_WARN | IM_LOG_FORCE, _str , ## __VA_ARGS__)
64*4882a593Smuzhiyun #define IM_LOGFE(_str, ...) IM_LOG(ANDROID_LOG_ERROR | IM_LOG_FORCE, _str , ## __VA_ARGS__)
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun #else
67*4882a593Smuzhiyun #define IM_LOG(level, _str, ...) \
68*4882a593Smuzhiyun     do { \
69*4882a593Smuzhiyun         if (!((level) & IM_LOG_FORCE)) \
70*4882a593Smuzhiyun             rga_error_msg_set(_str, ## __VA_ARGS__); \
71*4882a593Smuzhiyun         if ((rga_log_enable_get() > 0 && LOG_LEVEL_CHECK(level)) || \
72*4882a593Smuzhiyun             GET_LOG_LEVEL(level) == IM_LOG_ERROR || \
73*4882a593Smuzhiyun             (level) & IM_LOG_FORCE) \
74*4882a593Smuzhiyun             fprintf(stdout, "%lu " LOG_TAG " %s(%d): " _str "\n", \
75*4882a593Smuzhiyun                     (unsigned long)(rga_get_current_time_ms()-rga_get_start_time_ms()), \
76*4882a593Smuzhiyun                     __FUNCTION__, __LINE__, ## __VA_ARGS__); \
77*4882a593Smuzhiyun     } while(0)
78*4882a593Smuzhiyun #define IM_LOGD(_str, ...) IM_LOG(IM_LOG_DEBUG, _str , ## __VA_ARGS__)
79*4882a593Smuzhiyun #define IM_LOGI(_str, ...) IM_LOG(IM_LOG_INFO, _str , ## __VA_ARGS__)
80*4882a593Smuzhiyun #define IM_LOGW(_str, ...) IM_LOG(IM_LOG_WARN, _str , ## __VA_ARGS__)
81*4882a593Smuzhiyun #define IM_LOGE(_str, ...) IM_LOG(IM_LOG_ERROR, _str , ## __VA_ARGS__)
82*4882a593Smuzhiyun #define IM_LOGFD(_str, ...) IM_LOG(IM_LOG_DEBUG | IM_LOG_FORCE, _str , ## __VA_ARGS__)
83*4882a593Smuzhiyun #define IM_LOGFI(_str, ...) IM_LOG(IM_LOG_INFO | IM_LOG_FORCE, _str , ## __VA_ARGS__)
84*4882a593Smuzhiyun #define IM_LOGFW(_str, ...) IM_LOG(IM_LOG_WARN | IM_LOG_FORCE, _str , ## __VA_ARGS__)
85*4882a593Smuzhiyun #define IM_LOGFE(_str, ...) IM_LOG(IM_LOG_ERROR | IM_LOG_FORCE, _str , ## __VA_ARGS__)
86*4882a593Smuzhiyun #endif
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun #endif /* #define _im2d_log_hpp_ */
89